最近,我一直在尝试学习逆向工程。因此,我一直在钻研大量的汇编代码。我对以下几点感到困惑:
movq %rax,0xf8(%rbp)
movq 0xf8(%rbp),%rax我已经看过好几次了。这不是多余的吗?为什么编译器要这样做?我看到的二进制文件是用gcc编译的。
发布于 2011-02-22 13:59:59
您可能在没有优化的情况下进行了编译(-O)。您所看到的是对中间表示的直接、天真的翻译。像这样的代码片段通常是由于值存储在本地变量中,在本例中为0xf8(%rbp)。然后立即使用该值,因此它再次将其加载到寄存器%rax中。优化器会发现从%rax中存储只是为了恢复回相同的寄存器是多余的,并将序列完全删除。如果所有优化阶段都失败了,至少一个窥视孔会发现这两条指令是连续的。
如果你真的启用了优化,那么这确实很奇怪,但如果你发布了一个更大(但不是太大)的序列,就可以解释这一点。仍然有很多情况下会产生明显的次优结果,但没有像这样明显的情况。
https://stackoverflow.com/questions/5074447
复制相似问题