jmp指令
程序员文章站
2022-05-03 15:54:05
...
功能:
无条件转移指令
jmp指令要给出两种信息:
- 转移的目标地址
- 转移的距离(段间转移、段内短转移、段内近转移)
段内短转移:
jmp short 标号)
assume cs:code
code segment
start:mov ax,0
jmp short s
add ax,1
s: inc ax
code ends
end start
上面的程序执行后ax为1,add ax,1没有执行
CPU在执行jmp指令时候并不需要转移的地址,CPU的执行过程如下:
-
从CS:IP执行的内存单元读取指令,读取的指令进入指令缓冲器
-
IP=IP+所读取的指令长度,从而指向下一条指令
-
执行指令
简单来说就是:读取---------修改IP----------执行
jmp short 标号指令所对应的机器码中,并不包含转移的目的地址,而是包含转移的移位。这移位是编译器根据汇编指令中的标号计算出来的
jmp short 标号的功能实际上为:IP=IP+8位位移 -
8位位移=标号处的地址-jmp指令后的第一个字节地址
比如上图中执行jmp s0,标号s0的地址是0006,jmp指令后的第一个字节地址是0003,所以8位位移是3,IP=3+3=6,此时偏移地址为0006,CS没有变,根据CS:IP,CPU会找到要执行的代码是inc bx
jmp near ptr 标号
功能:IP=IP+16位地址