cmp 指令

Posted sky-view

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了cmp 指令相关的知识,希望对你有一定的参考价值。

(lldb) disassemble -n comp2
untitled6`comp2:
    0x10d065f40 <+0>:  pushq  %rbp
    0x10d065f41 <+1>:  movq   %rsp, %rbp
    0x10d065f44 <+4>:  movl   %edi, -0x4(%rbp)
    0x10d065f47 <+7>:  movl   %esi, -0x8(%rbp)
    0x10d065f4a <+10>: movl   -0x4(%rbp), %esi
    0x10d065f4d <+13>: cmpl   -0x8(%rbp), %esi
    0x10d065f50 <+16>: seta   %al
    0x10d065f53 <+19>: andb   $0x1, %al
    0x10d065f55 <+21>: movzbl %al, %eax
    0x10d065f58 <+24>: popq   %rbp
    0x10d065f59 <+25>: retq   

(lldb) disassemble -n comp
untitled6`comp:
    0x10d065f20 <+0>:  pushq  %rbp
    0x10d065f21 <+1>:  movq   %rsp, %rbp
    0x10d065f24 <+4>:  movl   %edi, -0x4(%rbp)
    0x10d065f27 <+7>:  movl   %esi, -0x8(%rbp)
    0x10d065f2a <+10>: movl   -0x4(%rbp), %esi
    0x10d065f2d <+13>: cmpl   -0x8(%rbp), %esi
    0x10d065f30 <+16>: setg   %al
    0x10d065f33 <+19>: andb   $0x1, %al
    0x10d065f35 <+21>: movzbl %al, %eax
    0x10d065f38 <+24>: popq   %rbp
    0x10d065f39 <+25>: retq   

这个指令相当于  sub 指令,除了它不改变 flag寄存器之外的寄存器

而 sub 因为 在二进制层面上的位操作都是相同的,也就是说, unsigned subtract 和 signed substract 是同时执行的,所以无论 unsigned compare 还是 signed compare 都是使用 comp 指令。

以上是关于cmp 指令的主要内容,如果未能解决你的问题,请参考以下文章

汇编 - CMP 后的 JZ 指令

汇编语言 CMP指令

《汇编语言(第三版)》cmp指令

Android 逆向x86 汇编 ( cmp 比较指令 | test 比较指令 )

Android 逆向x86 汇编 ( cmp 比较指令 | test 比较指令 )

汇编指令之CMP, TEST指令