曲径通幽论坛
标题:
无条件跳转指令 JMP
[打印本页]
作者:
beyes
时间:
2010-11-11 00:08
标题:
无条件跳转指令 JMP
JMP 是无条件跳转指令,有直接跳转和间接跳转两种。
直接跳转指令,跳转到的目标地址作为跳转指令的一部分直接编码到跳转指令中,其写法是给出跳转目标处的标号。
间接跳转指令,跳转的目的位置取自于某个寄存器或某个内存位置中,其写法是必须以一个星字符 '*' 作为操作指示符的前缀字符。
举例:
JMP GO_TO_THERE # 直接跳转,无条件直接跳转到标号 GO_TO_THERE 处继续执行
JMP *%eax # 间接跳转,寄存器 eax 的值就是要跳转到的目标位置
JMP *(%eax) # 间接跳转,eax 中的值作为地址,这个地址存放着的值就是要转到的目标位置
JMPI 是段间跳转,比如在 linux 0.11 的 bootsec.s 里有:
INITSEG 0x9000
...
jmpi go, INITSEG
go: mov ax, cs
这里,在执行 jmpi 后,使得 cs 的值为 INITSEG,而 IP 为 go 处的地址。
欢迎光临 曲径通幽论坛 (http://www.groad.net/bbs/)
Powered by Discuz! X3.2