微处理器指令系统.ppt
《微处理器指令系统.ppt》由会员分享,可在线阅读,更多相关《微处理器指令系统.ppt(58页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、 第二章第二章 微处理器指令系统微处理器指令系统 华北电力大学华北电力大学 计算机系计算机系 刘丽刘丽12.6 控制转移类指令n8088CPU中,程序代码放在代码段,由CS:IP获得物理地址q程序顺序执行时,CPU自动增量IP值q当程序遇到分支、循环、子程序调用时,采用控制转移类指令修改CS和IP寄存器的值改变程序的执行顺序n控制转移类指令重点掌握:qJMP/Jcc/LOOP/JCXZCALL/RETqINTn/IRET常用系统功能调用2目标地址的寻址方式用于改变用于改变CS和和IP,使程序跳转到目标地址,使程序跳转到目标地址n相对寻址方式q指令代码中提供目的地址相对于当前IP的位移量,转移到
2、的目的地址(转移后的IP值)就是当前IP值加上位移量n直接寻址方式q指令代码中提供目的逻辑地址,转移后的CS和IP值直接来自指令操作码后的目的地址操作数n间接寻址方式q指令代码中指示寄存器或存储单元,目的地址从寄存器或存储单元中间接获得用标号表达用标号表达用标号表达用标号表达用寄存器或存储器操作数表达用寄存器或存储器操作数表达3目标地址的寻址范围:段内寻址n段内转移近转移(nearjump)q在当前代码段64KB范围内转移(32KB范围)q不需要更改CS段地址,只要改变IP偏移地址n段内转移短转移(shortjump)q转移范围可以用一个字节表达,在段内128127范围的转移代代码码段段代代码
3、码段段4目标地址的寻址范围:段间寻址n段间转移远转移(farjump)q从当前代码段跳转到另一个代码段,8088支持在1MB范围内跳转q需要更改CS段地址和IP偏移地址q目标地址必须用一个32位数表达,叫做32位远指针,它就是逻辑地址(CS:IP)代代码码段段代代码码段段 实实际际编编程程时时,汇汇编编程程序序根根据据目目标标地地址址的的属属性,性,自动处理自动处理成短转移、近转移或远转移成短转移、近转移或远转移 程程序序员员可可用用操操作作符符short、near ptr 或或far ptr 强制成为需要的转移类型强制成为需要的转移类型52.6.1 无条件转移指令n只要执行无条件转移指令JM
4、P,就使程序转到指定的目标地址,从目标地址处开始执行指令n操作数label是要转移到的目标地址(目的地址、转移地址)nJMP指令分成4种类型:段内转移、相对寻址段内转移、相对寻址 段内转移、间接寻址段内转移、间接寻址 段间转移、直接寻址段间转移、直接寻址 段间转移、间接寻址段间转移、间接寻址JMP labelJMP label;程序转向;程序转向labellabel标号指定的地址标号指定的地址6无条件转移指令JMP(jump)JMPlabel;段内转移、相对寻址;IPIP位移量JMPr16/m16;段内转移、间接寻址;IPr16/m16JMPfarptrlabel;段间转移、直接寻址;IP偏移
5、地址,CS段地址JMPfarptrmem;段间转移,间接寻址;IPmem,CSmem2演示演示演示演示演示演示演示演示演示演示72.6.2 条件转移指令n条件转移指令Jcc根据指定的条件确定程序是否发生转移。其通用格式为:Jcclabel;条件满足,发生转移;IPIP8位位移量;否则,顺序执行nlabel是一个标号、一个8位位移量,表示Jcc指令后的那条指令的偏移地址,到目标指令的偏移地址的地址位移nJcc只支持短转移的相对寻址方式,因而只能实现段内-128127的跳转8Jcc指令的分类nJcc指令不影响标志,但要利用标志(表2-3)n在Jcc之前,通常有CMP、TEST、加减运算、逻辑运算等
6、指令n根据利用的标志位不同,分成三种情况:判断单个标志位状态判断单个标志位状态 比较无符号数高低比较无符号数高低 比较有符号数大小比较有符号数大小 Jcc指令实际虽然只有指令实际虽然只有16条,但却有条,但却有30个助记符个助记符 采用多个助记符,目的是为了方便记忆和使用采用多个助记符,目的是为了方便记忆和使用91.判断单个标志位状态JZ/JE和JNZ/JNE利用零标志ZF,判断结果是否为零(或相等)JS和JNS利用符号标志SF,判断结果是正是负JO和JNO利用溢出标志OF,判断结果是否产生溢出JP/JPE和JNP/JPO利用奇偶标志PF,判断结果中“1”的个数是偶是奇JC/JB/JNAE和J
7、NC/JNB/JAE利用进位标志CF,判断结果是否进位或借位10例2.19将AX中存放的无符号数除以2,如果是奇数则加1后除以2 问题问题:如何判断AX中的数据是奇数还是偶数?解答解答:判断AX最低位是“0”(偶数),还是“1”(奇数)。可以用位操作类指令用逻辑与指令将除最低位外的其他位变成0,保留最低位不变。判断这个数据是0,AX就是偶数;否则,为奇数将最低位用移位指令移至进位标志,判断进位标志是0,AX就是偶数;否则,为奇数将最低位用移位指令移至最高位(符号位),判断符号标志是0,AX就是偶数;否则,为奇数11解答1 用JZ指令实现testax,01h;测试AX的最低位D0(不用AND指令
8、,以免改变AX)jzeven;标志ZF1,即D00:AX内是偶数,程序转移addax,1;标志ZF0,即D01:AX内的奇数,加1even:shrax,1;AXAX2用右移一位的方法实现除以用右移一位的方法实现除以2本例中用本例中用RCR指令比指令比SHR指令更好指令更好(AX=FFFFH)Incadd?12解答2 用JNC指令实现movbx,axshrbx,1;将AX的最低位D0移进CFjnceven;标志CF0,即D00:AX是偶数,程序转移addax,1;标志CF1,即D01:AX内的奇数,加1even:shrax,1;AXAX2还可用还可用SAR、ROR和和RCR指令指令13解答3 用
9、JNS指令实现movbx,axrorbx,1;将AX的最低位D0移进最高位(符号位SF)jnseven;标志SF0,即D00:AX内是偶数,程序转移addax,1;标志SF1,即D01:AX内的奇数,加1even:shrax,1;AXAX2错误!错误!循环指令不影响循环指令不影响SF等标志等标志ADD BX,0;增加一条指令;增加一条指令14例2.20 判断是否为字母Y;寄存器AL中是字母Y(含大小写),则令AH0,否则令AH1cmp al,y;比较;比较AL与小写字母与小写字母yje next;相等,转移;相等,转移cmp al,Y;不相等,;不相等,;继续比较;继续比较AL与大写字母与大写
10、字母Yje next;相等,转移;相等,转移mov ah,-1;不相等,令;不相等,令AH1jmp done;无条件转移指令;无条件转移指令next:mov ah,0;相等的处理:令;相等的处理:令AH0done:15例2.21 偶校验;对DL寄存器中8位数据进行偶校验;校验位存入CF标志testdl,0ffh;使CF0,同时设置PF标志jpedone;DL中“1”的个数为偶数;正好CF0,转向donestc;DL中“1”的个数为奇数,设置CF1done:;完成162.比较无符号数高低n无符号数的大小用高(Above)、低(Below)表示,需要利用CF确定高低、利用ZF标志确定相等(Equa
11、l)n两数的高低分成4种关系,对应4条指令JB(JNAE):目的操作数低于(不高于等于)源操作数JNB(JAE):目的操作数不低于(高于等于)源操作数JBE(JNA):目的操作数低于等于(不高于)源操作数JNBE(JA):目的操作数不低于等于(高于)源操作数173.比较有符号数大小n判断有符号数的大(Greater)、小(Less),需要组合OF、SF标志、并利用ZF标志确定相等与否n两数的大小分成4种关系,分别对应4条指令JL(JNGE):目的操作数小于(不大于等于)源操作数JNL(JGE):目的操作数不小于(大于等于)源操作数JLE(JNG):目的操作数小于等于(不大于)源操作数JNLE(
12、JG):目的操作数不小于等于(大于)源操作数18例2.22 求AX和BX的较大值,并将较大值放在WMAX内存单元 cmpax,bx;比较AX和BXjaenext;若AXBX,转移xchgax,bx;若AXBX,交换next:movwmax,ax如果如果AX和和BX存放的是有符号数,存放的是有符号数,则条件转移指令应采用则条件转移指令应采用JGE指令指令19例2.22 求较大值(另解)cmpax,bx;比较AX和BXjaenextmovwmax,bx;若AXBX,wmaxBXjmpdonenext:movwmax,ax;若AXBX,wmaxAXdone:20例2.22 求较大值(另解对比)cmp
13、ax,bx;比较AX和BXjbenextmovwmax,ax;若AXBX,wmaxAXjmpdonenext:movwmax,bx;若AXBX,wmaxBXdone:212.6.3 循环指令n一段代码序列多次重复执行就是循环n8088设计有针对CX计数器的计数循环指令n循环指令中的操作数label只能采用相对短转移寻址方式,转移范围较小(-128127)n循环指令不影响标志222.6.3 循环指令nLOOPlabel;循环指令;首先CXCX1;然后判断,若CX0,转移;相当于两条指令deccx;jnzlabelnLOOPElabel;相等循环:CXCX-1;若CX0且ZF=1,转移;同LOOP
14、ZlabelnLOOPNElabelq;不等循环:CXCX-1;若CX0且ZF=0,转移q;同LOOPNZlabelnJCXZlabel;为0循环指令:如果CX0,则转移;JCXZ常用作循环程序的开始,使得在循环次数为0时跳过循环体23例2.23 数据块传送(字节);将数据段;将数据段Sbuf指示的指示的1KB数据传送到附加段的数据传送到附加段的Dbuf缓冲区缓冲区mov cx,400h;设置循环次数:;设置循环次数:1K1024400Hmov si,offset sbuf;设置循环初值:;设置循环初值:SI指向数据段源缓冲区开始指向数据段源缓冲区开始mov di,offset dbuf;DI
15、指向附加段目的缓冲区开始(附加段)指向附加段目的缓冲区开始(附加段)again:mov al,si;循环体:实现数据传送;循环体:实现数据传送mov es:di,al;每次传送一个字节;每次传送一个字节inc si;SI和和DI指向下一个单元指向下一个单元inc diloop again;循环条件判定:循环次数减;循环条件判定:循环次数减1,不为,不为0转移(循环)转移(循环)24例2.23 数据块传送(字)mov cx,200h;设置循环次数:;设置循环次数:1K2200Hmov si,offset sbuf;设置循环初值:;设置循环初值:SI指向数据段源缓冲区开始指向数据段源缓冲区开始mo
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 微处理器 指令系统
限制150内