CPU如何区分CALL rel16
(E8 cw)和CALL rel32
(E8 cd)?
根据this site镜像英特尔架构手册,CALL rel16
和CALL rel32
的操作码分别为E8 cw
和E8 cd
。
这让我很奇怪,CPU如何区分这些操作码,因为E8 cw
可能是E8 cw
的前缀?
答案 0 :(得分:11)
前缀66
用于在16位和32位操作数大小之间切换。因此,在16位操作模式下,E8 cw
为CALL rel16
而66 E8 cd
为CALL rel32
,而在32位操作模式下,E8 cd
为CALL rel32
66 E8 cw
为CALL rel16
。
在长模式(64位模式)下,根据英特尔手册,CALL rel16
似乎不可用。 CALL rel32
与32位模式类似,但rel32
立即符号扩展为64位,并添加到rip
而不是eip
。