Confused with CMPSB instruction

2019-06-21 19:19发布

I have been looking at this code and I'm confused about the rep cmpsb line.

.LOOP:
      push    cx
      mov     cx, 0x000B                            ; eleven character name
      mov     si, ImageName                         ; image name to find
      push    di
 rep  cmpsb                                         ; test for entry match
      pop     di
      je      LOAD_FAT
      pop     cx
      add     di, 0x0020                            ; queue next directory entry
      loop    .LOOP
      jmp     FAILURE

I understand that it repeats cmpsb cx times but how does this compare the two strings? Say for example was comparing "Hey\0" and "hey\0" and this loop was comparing 4 character strings. The first characters are different and the EFlags register would be set accordingly. However, the cmpsb instruction is repeated and the next characters would be the same. I may be misunderstanding how cmpsb works but it looks like this loop does not correctly compare two strings. Does this loop in fact work?

4条回答
孤傲高冷的网名
2楼-- · 2019-06-21 19:33

The reason REP works is because rep has the same encoding as REPE (F3h). In principle REPE is the right thing to use here, but depending on your assembler it might just take REP as correct.

So in reality you have a REPE cmpsb there, it's just that your (dis)assembler doesn't really know.

查看更多
Animai°情兽
3楼-- · 2019-06-21 19:39

You are right, this code will not work. You need to use repe cmpsb (repeat while equal compare string bytewise).

查看更多
【Aperson】
4楼-- · 2019-06-21 19:48

I think you have to use the REPE or REPNE prefix with cmpsb (It's been a while).

查看更多
走好不送
5楼-- · 2019-06-21 19:54

From my understanding, since I'm going through the same tutorial on brokenthorn, it will compare the first byte of Imagename with the first byte of the fat entry if they are the same.

It will continue until all 11 characters (filename and extension) at the first difference. It will set the ZF flag if they are the same, and the ZF flag will stay cleared.

So after comparing the entire filename, it will then jump to load that fat entry if they are the same. If not, it will load the next entry and compare that filename.

查看更多
登录 后发表回答