微处理器指令系统.ppt
第二章第二章 微处理器指令系统微处理器指令系统 华北电力大学华北电力大学 计算机系计算机系 刘丽刘丽12.6 控制转移类指令n8088CPU中,程序代码放在代码段,由CS:IP获得物理地址q程序顺序执行时,CPU自动增量IP值q当程序遇到分支、循环、子程序调用时,采用控制转移类指令修改CS和IP寄存器的值改变程序的执行顺序n控制转移类指令重点掌握:qJMP/Jcc/LOOP/JCXZCALL/RETqINTn/IRET常用系统功能调用2目标地址的寻址方式用于改变用于改变CS和和IP,使程序跳转到目标地址,使程序跳转到目标地址n相对寻址方式q指令代码中提供目的地址相对于当前IP的位移量,转移到的目的地址(转移后的IP值)就是当前IP值加上位移量n直接寻址方式q指令代码中提供目的逻辑地址,转移后的CS和IP值直接来自指令操作码后的目的地址操作数n间接寻址方式q指令代码中指示寄存器或存储单元,目的地址从寄存器或存储单元中间接获得用标号表达用标号表达用标号表达用标号表达用寄存器或存储器操作数表达用寄存器或存储器操作数表达3目标地址的寻址范围:段内寻址n段内转移近转移(nearjump)q在当前代码段64KB范围内转移(32KB范围)q不需要更改CS段地址,只要改变IP偏移地址n段内转移短转移(shortjump)q转移范围可以用一个字节表达,在段内128127范围的转移代代码码段段代代码码段段4目标地址的寻址范围:段间寻址n段间转移远转移(farjump)q从当前代码段跳转到另一个代码段,8088支持在1MB范围内跳转q需要更改CS段地址和IP偏移地址q目标地址必须用一个32位数表达,叫做32位远指针,它就是逻辑地址(CS:IP)代代码码段段代代码码段段 实实际际编编程程时时,汇汇编编程程序序根根据据目目标标地地址址的的属属性,性,自动处理自动处理成短转移、近转移或远转移成短转移、近转移或远转移 程程序序员员可可用用操操作作符符short、near ptr 或或far ptr 强制成为需要的转移类型强制成为需要的转移类型52.6.1 无条件转移指令n只要执行无条件转移指令JMP,就使程序转到指定的目标地址,从目标地址处开始执行指令n操作数label是要转移到的目标地址(目的地址、转移地址)nJMP指令分成4种类型:段内转移、相对寻址段内转移、相对寻址 段内转移、间接寻址段内转移、间接寻址 段间转移、直接寻址段间转移、直接寻址 段间转移、间接寻址段间转移、间接寻址JMP labelJMP label;程序转向;程序转向labellabel标号指定的地址标号指定的地址6无条件转移指令JMP(jump)JMPlabel;段内转移、相对寻址;IPIP位移量JMPr16/m16;段内转移、间接寻址;IPr16/m16JMPfarptrlabel;段间转移、直接寻址;IP偏移地址,CS段地址JMPfarptrmem;段间转移,间接寻址;IPmem,CSmem2演示演示演示演示演示演示演示演示演示演示72.6.2 条件转移指令n条件转移指令Jcc根据指定的条件确定程序是否发生转移。其通用格式为:Jcclabel;条件满足,发生转移;IPIP8位位移量;否则,顺序执行nlabel是一个标号、一个8位位移量,表示Jcc指令后的那条指令的偏移地址,到目标指令的偏移地址的地址位移nJcc只支持短转移的相对寻址方式,因而只能实现段内-128127的跳转8Jcc指令的分类nJcc指令不影响标志,但要利用标志(表2-3)n在Jcc之前,通常有CMP、TEST、加减运算、逻辑运算等指令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和JNC/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指令,以免改变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 用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与大写字母与大写字母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标志确定相等(Equal)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(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 求较大值(另解对比)cmpax,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,转移;同LOOPZlabelnLOOPNElabelq;不等循环: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指向附加段目的缓冲区开始(附加段)指向附加段目的缓冲区开始(附加段)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指向数据段源缓冲区开始指向数据段源缓冲区开始mov di,offset dbuf;DI指向附加段目的缓冲区开始(附加段)指向附加段目的缓冲区开始(附加段)again:mov ax,si;循环体:实现数据传送;循环体:实现数据传送mov es:di,ax;每次传送一个字;每次传送一个字add si,2;指向下一个(字)单元;指向下一个(字)单元add di,2loop again;循环条件判定:循环次数减;循环条件判定:循环次数减1,不为,不为0转移(循环)转移(循环)252.6.4 子程序指令n子程序是完成特定功能的一段程序n当主程序(调用程序)需要执行这个功能时,采用CALL调用指令转移到该子程序的起始处执行n当运行完子程序功能后,采用RET返回指令回到主程序继续执行演示演示 转移转移指令指令有去无回有去无回 子程序子程序调用需要返回调用需要返回,其其中中利利用用堆堆栈栈保保存存返返回回地地址址261.子程序调用指令CALLn根据子程序的调用范围和寻址方式,CALL指令分成4种类型(类似JMP)q相对寻址的段内调用CALL指令,需要将IP压入堆栈,然后转移CALLlabel;段内调用、直接寻址;IP入栈:SPSP-2,SS:SPIP;实现转移:IPIP+16位偏移量q间接寻址的段内调用CALL指令,需要将IP压入堆栈,然后转移CALLr16/m16;段内调用、间接寻址;IP入栈:SPSP-2,SS:SPIP;实现转移:IPr16/m16271.子程序调用指令CALLq直接寻址的段间调用CALL指令,需要将CS和IP压入堆栈,然后转移CALLfarptrlabel;段间调用、直接寻址;CS入栈:SPSP-2,SS:SPCS;IP入栈:SPSP-2,SS:SPIP;实现转移:IPlabel偏移量,CSlabel段地址q间接寻址的段间调用CALL指令,需要将CS和IP压入堆栈,然后转移CALLfarptrmem;段间调用、间接寻址;CS入栈:SPSP-2,SS:SPCS;IP入栈:SPSP-2,SS:SPIP;实现转移:IPmem,CSmem+2n实际编程中,汇编程序自动确定是段内还是段间,也可以采用nearprt或farptr强制成为近调用或远调用282.子程序返回指令RETn根据返回范围和有无参数,分成4种类型qRET;无参数段内返回;弹出IP:IPSS:SP,SPSP2qRETi16;有参数段内返回;弹出IP:IPSS:SP,SPSP2;调整指针:SPSP+i16,可以方便地废除若干执;行CALL指令以前的入栈操作qRET;无参数段间返回;弹出IP:IPSS:SP,SPSP2;弹出CSSS:SP,SPSP2qRETi16;有参数段间返回;弹出IP:IPSS:SP,SPSP2;弹出CSSS:SP,SPSP2;调整指针:SPSP+i16,可以方便地废除若干执;行CALL指令以前的入栈操作29例2.24 编写一个子程序,将DL低4位中的一位16进制数转换成ASCII码;子程序:将DL低4位的一位16进制数转换成ASCII码htoascprocand dl,0fh;只取DL的低4位or dl,30h;DL高4位变成3cmp dl,39h;是09,还是0Ah0Fh?jbe htoend;是09,转移add dl,7;是0Ah0Fh,加上7htoend:ret;子程序返回htoascendp转换原理转换原理转换原理转换原理;主程序:调用;主程序:调用子程序子程序mov dl,28hcall htoasc302.6.5 中断指令和系统功能调用n中断(Interrupt)是又一种改变程序执行顺序的方法n8088CPU支持256个中断,每个中断用一个编号(中断向量号)区别n中断指令有3条:INTi8IRETINTOn本节主要掌握类似子程序调用指令的中断调用指令INTi8,进而掌握系统功能调用311.中断指令n8088中断指令的地址寻址方法不同于其他控制转移类指令n中断服务程序本身可以放在内存内任何位置,但起始地址则按照向量号顺序存放在最低000H3FFH的1KB物理存储器中,形成一个中断向量表n指令中只要指明是第几个中断就可以转入该中断服务程序32INT i8 nINTi8;中断调用指令:产生i8号中断;主程序使用,i8表示中断向量号n执行操作:入栈保存FLAGS:SPSP2,ss:spFLAGS入栈保存返回地址:SPSP2,ss:spCSSPSP2,ss:spIP转中断处理程序:IPn4CSn4233IRET nIRET;中断返回指令:实现中断返回;中断服务程序使用;指令执行的过程基本上是INT指令的逆过程n执行操作:从栈顶弹出内容送入IP,IPss:sp,SPSP2再从新栈顶弹出内容送入CS,返回地址出栈:csss:sp,SPSP2从新栈顶弹出内容送入标志寄存器:FLAGSss:SP,SPSP234INTO nINTO;溢出中断指令;若溢出标志OF=1,产生4号中断,否则顺序执行;中断类型为4n执行操作:若OF=1(有溢出),才引起中断,则:入栈保存FLAGS:SPSP2,SP:SPFLAGS入栈保存返回地址:SPSP2,SP:SPCSSPSP2,SP:SPIP转中断处理程序:IP44=10H,CS442=12H352.系统功能调用方法nIBMPC系列机中的ROM-BIOS和DOS操作系统提供了丰富的中断服务程序让程序员使用n汇编程序提供给汇编语言程序员的功能非常有限n程序员需要利用ROM-BIOS和操作系统提供的资源n系统功能调用是程序设计的一个重要方面裸机裸机汇编语言程序36系统功能调用步骤nROM-BIOS和DOS系统功能调用步骤的方法一样,通常按照如下4个步骤进行:在AH寄存器中设置系统功能调用号在指定寄存器中设置入口参数用中断调用指令(INTi8)执行功能调用根据出口参数分析功能调用执行情况373.DOS输入输出功能调用nDOS利用21H号中断提供给用户近百个系统功能,主要包括设备管理、目录管理和文件管理三个方面子功能号功能入口参数出口参数AH=01H从标准输入设备输入一个字符AL=输入字符的ASCII码AH=02H向标准输出设备输出一个字符DL=欲显示字符的ASCII码AH=09H向标准输出设备输出一个字符串DS:DX=欲显示的字符转在内存中的首地址AH=0AH从标准输入设备输入一个字符串DS:DX=输入字符串将在内存缓冲区的首地址AH=0BH判定标准输入设备是否有输入AL=0,没有输入AL=FFH,有输入3802H号DOS功能调用n将在显示器当前光标位置显示DL给定的字符,且光标移动到下一个位置n当输出响铃字符(ASCII码为07H),退格字符(08H),回车字符(0DH)和换行字符(0AH),该功能调用可以自动识别并进行相应处理n该调用会破坏AX内容;显示一个问号;显示一个问号“?”mov ah,02h;设置功能调用号;设置功能调用号mov dl,?;设置入口参数;设置入口参数int 21h;功能调用;功能调用39例2.25 回车换行的子程序crlfprocpushax;保护寄存器pushdxmovah,2movdl,0dh;回车功能的ASCII码是0DHint21hmovah,2movdl,0ah;换行功能的ASCII码是0AHint21hpopdx;恢复寄存器popaxretcrlfendp4009H号DOS功能调用n输出一个字符串功能调用号:AH09H入口参数:DS:DX欲显示字符串在内存中的首地址(逻辑地址形式:DS段地址,DX偏移地址)内存中的字符串以ASCII码形式保存,最后必须添加一个“$”结尾(并不显示)功能调用:INT21H出口参数:无n会破环DX内容。无出口参数41例2.26 提示按任意键继续;在数据段定义要显示的字符串;在数据段定义要显示的字符串msgkeydb Press any key to contiune,$;在代码段编写程序;在代码段编写程序mov ah,9mov dx,offset msgkey;设置入口参数:;设置入口参数:;DS数据段地址(假设已经设置好)数据段地址(假设已经设置好);DX字符串的偏移地址字符串的偏移地址int 21h420aH号DOS功能调用n等待用户输入一个或多个字符,最后用回车确认,输入字符的ASCII码顺序放在DS:DX指定的内存缓冲区,并在屏幕回显n使用0AH调用,应事先定义好缓冲区,并注意缓冲区格式q第一字节填入最多欲接受的字符(1255,包括最后回车)q留出第二字节用于存放功能调用时实际输入的字符个数(不包括回车)q第三字节开始为实际输入字符的ASCII码,应留够最大字符数所要求的空间q实际输入的字符多于定义数时,多出字符被丢掉,最后一个字符是回车符(0DH)43例:定义0A功能使用的缓冲区bufferdf9;最大字符9(含回车)db0;实际输入字符(不含回车)db9dup(0);开始存放,dup是重复操作,重复内容在括号内n假设某次执行0AH功能调用时,从键盘按下“abcd”和回车q则buffer内依次是09H04H61H62H63H64H0DH00H00H00H00H444.ROM-BIOS输入输出功能调用nROM-BIOS也以中断服务程序的形式,向程序员提供系统的基本输入输出程序nROM-BIOS功能更基本,且与操作系统无关n当DOS没有启动或不允许使用DOS功能调用时,可以使用ROM-BIOS功能调用子功能号功能入口参数出口参数对应DOS功能号AH=00HInt 16H从键盘输入一个字符AX=键值代码01HAH=01HInt 16H判定键盘是否有输入ZF=1,没有输入ZF=0,有输入0BHAH=0EHInt 10H向屏幕输出一个字符AL=欲显示字符的ASCII码,BH=显示页号02H当用户按键后,该调用返回键值代码AX,如果按下标准ASCII码键,AL=ASCII码,AH=扫描码按下扩展键:AL=00H,AH=键扩展码;按下“ALT+小键盘数字按键”:AL=ASCII码,AH=00H通常使BX=045例2.27 用ROM-BIOS功能调用显示按下的标准ASCII码字符movah,0;子功能号:AH0int16H;键盘功能调用(INT16H);出口参数(也是下一个功能调用的入口参;数):AL按键的ASCII码movbx,0;入口参数:BX0movah,0eH;功能号:AH0EHint10H462.7 处理器控制类指令n用来控制CPU的状态,使CPU暂停、等待或空操作等qNOP;空操作指令,等同于“xchgax,ax”指令;不执行任何操作,但占用一个字节存储单元,空耗一个;指令执行周期,常用于程序调试;如需预留指令空间用NOP填充,代码空间多余也用其填充;还可以实现软件延时qSEG:;段超越前缀指令:CS:,SS:,DS:,ES:qHLT;暂停指令:CPU进入暂停状态,CPU不进行任何操作;CPU发生复位或发生外部中断时,CPU脱离暂停状态。;中断使CPU脱离暂停状态,返回执行HLT的下一条指令;HLT可用于程序等待中断;当程序必须等待中断时,可用HLT,而无需软件死循环q还有其他指令:LOCKESCWAIT4748