Regarding cmp / jg, jle, etc in AT&T syntax assembly

前端 未结 2 399
说谎
说谎 2021-01-22 16:23

So every single resource online tells me that something like this:

cmp %eax, %ebx
jg < something >

would jump to < something > if eax

相关标签:
2条回答
  • 2021-01-22 16:50

    When we read something like

    cmp $0x2, %eax
    jg  < something >
    

    we know the assembler used is one that reverses the position of the operands of an instruction. That's because Intel's syntax dictates that the destination operand comes before the source operand and clearly an immediate value like $0x2 can't ever be a destination!

    Knowing the order of things we now interpret your first code snippet as

    cmp ebx, eax
    jg < something >  ;jump if EBX > EAX
    

    and the second code snippet as

    cmp eax, 2
    jg < something >  ;jump if EAX > 2
    

    And does this apply to other jump statements as well?

    It does.

    0 讨论(0)
  • 2021-01-22 16:58

    See if THIS ANSWER helps you. If not, ask for clarification.

    Scroll down past the other guy's source code and stuff in that answer to search for this string...

    This biz, the cmpl %eax,%edx instruction, is one of the forms of the "compare" instructions

    I wrote an explanation of the "sense" of CMP and various conditional jumps. See if it answers your questions here.

    If you are still confused, post a note here and someone else may give you a better answer.

    Hope it helps.

    0 讨论(0)
提交回复
热议问题