曲径通幽论坛

标题: 无条件跳转指令 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