当您使用内存覆盖前缀但所有操作数都是寄存器时会发生什么?
那么,假设您编写了代码mov eax, ebx
or add eax, ebx
默认值为 32 位,但您使用 67h 覆盖。
处理器如何处理这种情况?
英特尔软件开发人员手册*,第 2 卷,第 2.1 节详细介绍了每个指令前缀的行为。它表示,在没有内存操作数的指令中使用地址大小前缀(67h)是被保留的,并且可能会导致不可预测的行为。
操作数大小前缀 (66h) 可用于在 16 位和 32 位操作数大小之间切换,也可作为某些 SSE2/SSE3/SSSE3/SSE4 指令的强制前缀。保留其他用途,并可能导致不可预测的行为。
段覆盖前缀是为任何分支指令保留的。
* https://software.intel.com/en-us/articles/intel-sdm
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)