中央处理器如何区分CALL rel16 (E8 cw)和CALL rel32 (E8 cd)?
根据this site提供的英特尔体系结构手册,CALL rel16和CALL rel32的操作码分别为E8 cw和E8 cd。
这让我想知道,既然E8 cw可能是E8 cw的前缀,那么CPU如何区分这些操作码呢
发布于 2017-07-03 17:46:23
前缀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。
https://stackoverflow.com/questions/44882315
复制相似问题