How to interpret this address -0x80(%rbp,%rax,4)

空扰寡人 提交于 2019-12-29 08:03:38

问题


I'm currently trying to learn assembly language (and the effects of different compiler options) by analyzing simple C code snippets. Now I stumpled across the following instruction:

mov %edx,-0x80(%rbp,%rax,4)

What I do not understand is the expression for the target address -0x80(%rbp,%rax,4). The instruction assigns a value to a local array in a loop.


回答1:


The machine command will copy the content of %edx to the address given by %rbp + 4 * %rax - 0x80. It seems %rax is holding the index to that array and %rbp - 0x80 is the base address.

Take a look here to get a better understanding for the AT&T syntax.




回答2:


-0x80(%rbp,%rax,4) = *(%rbp + %rax * 4 + (-0x80))

So the following insruction:

mov %edx,-0x80(%rbp,%rax,4)

means let CPU move the value of register %edx to memory at address (%rbp + %rax * 4 + (-0x80)), this is AT&T-style assembly.



来源:https://stackoverflow.com/questions/13359068/how-to-interpret-this-address-0x80rbp-rax-4

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!