【问题标题】:What does cmp %eax,0x80498d4(,%ebx,4) mean?cmp %eax,0x80498d4(,%ebx,4) 是什么意思?
【发布时间】:2015-03-02 02:52:21
【问题描述】:

我知道还有一些与此类似的其他问题,但我仍然无法理解其中的 () 部分。有人可以为我拼出这个语法吗?谢谢。

【问题讨论】:

  • 用 Intel 语法会更容易理解:cmp [ebx*4 + 0x80498d4], eax

标签: c assembly x86 gdb att


【解决方案1】:
cmp %eax,0x80498d4(,%ebx,4)

cmp 是比较汇编指令。它通过从左边减去右边的参数来执行两个参数之间的比较,并设置一个 CPU EFLAGS 寄存器。然后可以使用这个 EFLAGS 寄存器进行条件分支/移动等。

第一个参数: `%eax(%eax 寄存器中的值)

第二个参数: 0x80498d4(,%ebx,4)。这读作offset ( base, index, scale ) 在您的示例中,第二个参数的值是内存位置偏移量0x80498d4 + base (which I believe defaults to zero if not included) + value in %ebx register * 4 (scaling factor)

注意:我认为这里的 base 是空的,默认值为 0。

您可以查看http://docs.oracle.com/cd/E19120-01/open.solaris/817-5477/ennby/index.html,了解有关 Intel x86 汇编指令语法的更多信息。

【讨论】:

    猜你喜欢
    • 2012-05-21
    • 2011-02-02
    • 1970-01-01
    • 1970-01-01
    • 2011-10-12
    • 2012-08-08
    • 2013-01-31
    相关资源
    最近更新 更多