8086指令系统---控制转移指令(一)
条件转移指令是在满足了规定的条件后才控制程序转移的一类指令,8086的条件转移指令总结在表3.4中。
所有条件转移指令都是短转移指令,转移的目标地址必须在当前IP地址的-128至+127字节范围之内,因此条件转移指令是2字节指令。
计算转向地址的方法和无条件短转移指令是一样的,看例3.40的反汇编代码。
例3.40程序中的"JNZ AGAIN"汇编成"JNZ 000D",000D是标号AGAIN的地址,指令"JNZ 000D"的机器代码是75FA,75是操作码,FA是位移量。当CPU读取JNZ指令后,IP寄存器自动加2(JNZ的指令长度)指向了下一条指令(MOV),此时IP的当前值是0013。计算转向地址时,(IP)当前+位移量 = 0013+FA = 0013+FFFA = 000D,这正是AGAIN的偏移地址。实际上FA是-6的补码,8位的FA与16位的0013相加时,FA符号扩展成为FFFA,相加的加结果为000D。
分类
|
指 令
|
转 移 条 件
|
说 明
|
(Ⅰ)
|
JZ/JE
|
ZF=1
|
为零/相等, 则转移
|
JNZ/JNE
|
ZF=0
|
不为零/不相等, 则转移
|
|
JS
|
SF=1
|
为负, 则转移
|
|
JNS
|
SF=0
|
为正, 则转移
|
|
JO
|
OF=1
|
溢出, 则转移
|
|
JNO
|
OF=0
|
不溢出, 则转移
|
|
JP
|
PF=1
|
奇偶位为1, 则转移
|
|
JNP
|
PF=0
|
奇偶位为0, 则转移
|
|
JC
|
CF=1
|
进位位为1, 则转移
|
|
JNC
|
CF=0
|
进位位为0, 则转移
|
|
(Ⅱ)
|
JB/JNAE/JC
|
CF=1
|
低于/不高于等于, 则转移
|
JNB/JAE/JNC
|
CF=0
|
不低于/高于等于, 则转移
|
|
JBE/JNA
|
(CFZF)=1
|
低于等于/不高于, 则转移
|
|
JNBE/JA
|
(CFZF)=0
|
不低于等于/高于, 则转移
|
|
(Ⅲ)
|
JL/JNGE
|
(SFOF)=1
|
小于/不大于等于, 则转移
|
JNL/JGE
|
(SFOF)=0
|
不小于/大于等于, 则转移
|
|
JLE/JNG
|
((SFOF)ZF)=1
|
小于等于/不大于, 则转移
|
|
JNLE/JG
|
((SFOF)ZF)=0
|
不小于等于/大于, 则转移
|
|
(Ⅳ)
|
JCXZ
|
(CX)=0
|
CX的内容为0, 则转移
|
注:(Ⅰ)根据条件码的值转移 (Ⅱ)比较两个无符号数,根据比较的结果转移
(Ⅲ)比较两个带符号数,根据比较的结果转移 (Ⅳ)根据CX寄存器的值转移
1050:0003 8ED8 MOV DS,AX
1050:0005 B90500 MOV CX,0005
1050:0008 BB0000 MOV BX,0000
1050:000D 0207 AGAIN: ADD AL,[BX]
1050:000F 43 INC BX
1050:0010 49 DEC CX
1050:0011 75FA JNZ 000D
1050:0013 A20500 MOV [0005],AL
1050:0016 B44C MOV AH,4C
1050:0018 CD21 INT 21
例假设程序进行两个带符号数的比较,并根据比较结果转移,其中(AL)=80H,(BL)=01,请指出下面 两组指令的转向地址。
⑴ CMP AL,BL ⑵ CMP AL,BL
JL XY JB XY
答:⑴ 转向目标地址XY;⑵不能实现转移。
执行CMP指令时,(AL)-(BL)=80-01=7F,条件码设置为:SF=0,OF=1,CF=0。执行JL指令时,测试转移条件:SFOF = 01 =1,说明满足(AL)<(BL)的转移条件,因此,(IP)←XY的偏移地址,程序即转移到XY单元执行新的指令。
JB指令的转移条件为CF=1,而CMP的执行结果使CF=0,所以不能引起转移。
评论