第2章5微处理器指令系统.ppt
文本预览下载声明
第二章 微处理器指令系统 华北电力大学 计算机系 刘丽 2.6 控制转移类指令 8088CPU中,程序代码放在代码段,由CS:IP获得物理地址 程序顺序执行时,CPU自动增量IP值 当程序遇到分支、循环、子程序调用时,采用控制转移类指令修改CS和IP寄存器的值改变程序的执行顺序 控制转移类指令重点掌握: JMP/Jcc/LOOP/JCXZ CALL/RET INT n/IRET 常用系统功能调用 目标地址的寻址方式 目标地址的寻址范围:段内寻址 目标地址的寻址范围:段间寻址 2.6.1 无条件转移指令 无条件转移指令JMP(jump) 2.6.2 条件转移指令 条件转移指令Jcc根据指定的条件确定程序是否发生转移。其通用格式为: Jcc label ;条件满足,发生转移 ;IP←IP+8位位移量; ;否则,顺序执行 label是一个标号、一个8位位移量,表示Jcc指令后的那条指令的偏移地址,到目标指令的偏移地址的地址位移 Jcc只支持短转移的相对寻址方式,因而只能实现段内-128~127的跳转 Jcc指令的分类 1. 判断单个标志位状态 ⑴ JZ/JE和JNZ/JNE 利用零标志ZF,判断结果是否为零(或相等) ⑵ JS和JNS 利用符号标志SF,判断结果是正是负 ⑶ JO和JNO 利用溢出标志OF,判断结果是否产生溢出 ⑷ JP/JPE和JNP/JPO 利用奇偶标志PF,判断结果中“1”的个数是偶是奇 ⑸ JC/JB/JNAE和JNC/JNB/JAE 利用进位标志CF,判断结果是否进位或借位 例2.19将AX中存放的无符号数除以2,如果是奇数则加1后除以2 问题:如何判断AX中的数据是奇数还是偶数? 解答:判断AX最低位是“0”(偶数),还是“1”(奇数)。可以用位操作类指令 用逻辑与指令将除最低位外的其他位变成0,保留最低位不变。判断这个数据是0,AX就是偶数;否则,为奇数 将最低位用移位指令移至进位标志,判断进位标志是0,AX就是偶数;否则,为奇数 将最低位用移位指令移至最高位(符号位),判断符号标志是0,AX就是偶数;否则,为奇数 解答1 用JZ指令实现 test ax,01h ;测试AX的最低位D0(不用AND指令,以免改变AX) jz even ;标志ZF=1,即D0=0:AX内是偶数,程序转移 add ax,1 ;标志ZF=0,即D0=1:AX内的奇数,加1 even: shr ax,1 ;AX←AX÷2 解答2 用JNC指令实现 mov bx,ax shr bx,1 ;将AX的最低位D0移进CF jnc even ;标志CF=0,即D0=0:AX是偶数,程序转移 add ax,1 ;标志CF=1,即D0=1:AX内的奇数,加1 even: shr ax,1 ;AX←AX÷2 解答3 用JNS指令实现 例2.20 判断是否为字母Y 例2.21 偶校验 2. 比较无符号数高低 无符号数的大小用高(Above)、低(Below)表示,需要利用CF确定高低、利用ZF标志确定相等(Equal) 两数的高低分成4种关系,对应4条指令 JB(JNAE):目的操作数低于(不高于等于)源操作数 JNB(JAE):目的操作数不低于(高于等于)源操作数 JBE(JNA):目的操作数低于等于(不高于)源操作数 JNBE(JA):目的操作数不低于等于(高于)源操作数 3. 比较有符号数大小 判断有符号数的大(Greater)、小(Less),需要组合OF、SF标志、并利用ZF标志确定相等与否 两数的大小分成4种关系,分别对应4条指令 JL(JNGE):目的操作数小于(不大于等于)源操作数 JNL(JGE):目的操作数不小于(大于等于)源操作数 JLE(JNG):目的操作数小于等于(不大于)源操作数 JNLE(JG):目的操作数不小于等于(大于)源操作数 例2.22 求AX和BX的较大值,并将较大值放在WMAX内存单元 例2.22 求较大值(另解) 例2.22 求较大值(另解对比) 2.6.3 循环指令 一段代码序列多次重复执行就是循环 8088设计有针对CX计数器的计数循环指令 循环指令中的操作数label只能采用相对短转移寻址方式,转移范围较小(-128~127) 循环指令不影响标志 2.6.3 循环指令 LOOP label ;循环指令;首先CX←CX-1;然后判断,若CX≠0,转移 ;相当于两条指令dec cx ;jnz label LOOPE label ;相等循环:CX←CX-1;若CX≠0且ZF=1,转移 ;同LOOPZ label
显示全部