CPU如何区分' CALL rel16' (E8 cw)和' CALL rel32' (E8 cd)?

时间:2017-07-03 09:40:38

标签: assembly x86 isa

CPU如何区分CALL rel16(E8 cw)和CALL rel32(E8 cd)?

根据this site镜像英特尔架构手册,CALL rel16CALL rel32的操作码分别为E8 cwE8 cd

这让我很奇怪,CPU如何区分这些操作码,因为E8 cw可能是E8 cw的前缀?

1 个答案:

答案 0 :(得分:11)

前缀66用于在16位和32位操作数大小之间切换。因此,在16位操作模式下,E8 cwCALL rel1666 E8 cdCALL rel32,而在32位操作模式下,E8 cdCALL rel32 66 E8 cwCALL rel16

在长模式(64位模式)下,根据英特尔手册,CALL rel16似乎不可用。 CALL rel32与32位模式类似,但rel32立即符号扩展为64位,并添加到rip而不是eip