当我和GCC一起分解简单的C代码时,我发现:
mov (%eax), eax我对程序集的理解是,当()围绕寄存器时,您将向内存地址添加一些数字,也就是说,0x4(%eax)意味着寄存器%eax上的4个字节。
但是,在这里,在()之前没有数字,因此它似乎在将寄存器中的值复制到自己。
我已经注意到,%eax寄存器通常用于返回变量,这一行在函数调用之后立即发生,因此,我的猜测是,这条指令实际上是告诉机器接受被调用函数的%eax寄存器中的任何内容(即返回值),并将其放入当前函数的%eax寄存器中。
这是正确的吗?如果没有,我做错了什么,它到底在做什么?
发布于 2014-07-27 13:28:41
()在at&t语法中表示内存取消引用,您可能应该阅读有关有效地址语法的内容。等效的C代码是eax=*eax;,使用eax的当前值作为地址从内存中加载4个字节,并用获取的值覆盖eax。
函数调用和返回不影响寄存器的值(当然,堆栈和指令指针除外),没有调用者或被调用者的eax的概念。
PS:如果您对at&t不满意,可以使用gdb将set disassembly-flavor intel转换为英特尔语法模式。
https://stackoverflow.com/questions/24981252
复制相似问题