我对
Linux内核的一个头文件
arch/x86/include/asm/nops.h中的注释感到有点困惑.它说明了这一点
<…> the following instructions are NOT nops in 64-bit mode,for 64-bit mode use K8 or P6 nops instead
movl %esi,%esi
leal 0x00(%esi),%esi
<…>
我想作者暗示机器指令(分别是’89 F6’和’8D 76 00′)而不是汇编指令.根据英特尔软件开发人员手册第2A卷中对LEA的描述,后一条指令(lea 0x00(%rsi),%esi)与前者,mov%esi,%esi相同.
所以这简化了问题,无论是mov%esi,%esi实际上是x86-64上的无操作.
mov不会改变标志.这种mov也不会改变记忆.似乎,如果它改变除了%rip之外的东西,它应该是通用寄存器.但我不知道它如何改变%rsi的内容或其他什么.如果操纵通用寄存器的下半部分,上半部分不应该改变,对吧?
解决方法
mov %esi,%esi
将%rsi的高32位归零,因此不是x86_64上的无操作.