在调查一次崩溃时,我偶然看到以下代码片段,并立即认识到mov指令实际上应该是movq才能获得正确的64位寄存器操作。
#elif defined(__x86_64__)
unsigned long rbp;
__asm__ volatile ("mov %%rbp, %0" : "=r" (rbp));
sp = (void **) rbp;
#else此外,我还发现一些文档声称x86-64的rbp寄存器是通用的,不包含当前帧的地址。我还找到了一些文档,这些文档声称rbp确实包含当前帧的地址。有人能澄清一下吗?
发布于 2012-02-21 22:29:09
关于您问题的第一部分(movq而不是mov),汇编程序(在本例中为as)将识别出您的操作数是64位,并将正确地使用movq。mov不是一个有效的指令,它是一种告诉汇编器“根据操作数使用正确的mov变量”的方法。
关于第二部分,它实际上是两者兼而有之:它是一个通用寄存器,在某种意义上,它可以容纳任何值。它还用作堆栈帧基指针。AMD64 Application programming手册的'2.4堆栈操作‘部分写道:
堆栈是内存中堆栈段的一部分,用于链接过程。软件约定通常使用堆栈帧定义堆栈,堆栈帧由两个寄存器组成-堆栈-帧基址指针(rBP)和堆栈指针(RSP)-
https://stackoverflow.com/questions/9379089
复制相似问题