讲课用的微机原理指令系统_第1页
讲课用的微机原理指令系统_第2页
讲课用的微机原理指令系统_第3页
讲课用的微机原理指令系统_第4页
讲课用的微机原理指令系统_第5页
已阅读5页,还剩30页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、12.2.5 程序控制指令控制转移指令分为:转移指令循环控制指令调用和返回指令中断指令2转移指令的实质:改变IP(或CS)的内容。所有转移指令不会影响标志位。分为无条件转移和条件转移两种。1.转移指令3(1) 无条件转移指令 - JMP本指令无条件转移到指定的目标地址,以执行从该地址开始的程序段。根据设置CS、IP的方法,JMP指令分成4种情况。 段内直接转移: JMP disp 指令中给出的8/16位的位移量加到IP。CS保持不变。 段内间接转移: JMP reg/mem reg/mem中的16位偏移地址送IP。CS保持不变。 段间直接转移 JMP segment:offset 指令中给出的

2、16位的段和16位的偏移地址送到CS和IP。 段间间接转移 JMP mem32 mem32中的16位的段和16位的偏移地址送到CS和IP。4转移的目标地址由指令直接给出。指令中给出的目标地址实际上是一个相对于IP的位移量: 位移量 转移范围 汇编语言中格式 8位 -128+127 JMP SHORT OPRD 16位 -32768 JMP NEAR PTR OPRD例:JMP0120H ;直接转向0120H JMPSHORT LP ;转向LP JMPNEAR PTR BBB;转向BBB由于是段内转移,故转移后CS内容保持不变 段内直接转移5段内间接转移转移的目标地址由寄存器或存储单元的内容给出

3、。 例1:JMP SI若(SI)=1200H,则指令执行后,(IP)=1200H,于是转向代码段的偏移地址1200H处开始执行。注意:目标地址以段内偏移的形式给出,而不是相对于IP的位移量,所以它是一个16位的操作数。6例2:JMP BX+DI设指令执行前: (DS)=3000H,(BX)=1300H, (DI)=1200H,(32500H)=2350H; 则指令执行后:(IP)=2350H在汇编语言中,段内间接寻址通常写成:JMPWORD PTRBX+DI表示所取得的目标地址是一个字。7段间直接转移在指令中直接给出要转移到的目的段地址和偏移地址。 例:JMP2000H:1000H执行时,(I

4、P)1000H,(CS)2000H注:直接地址为符号地址时,段间直接转移指令中的符号地址前应加操作符FAR PTR。 例:JMP FAR PTR far_label其中的far_label为远类型的标号。8转移的目的地址(段和偏移)在两个相邻的字存储单元中。例如:JMPDWORD PTRSI设指令执行前:(DS)=4000H,(SI)=1212H, (41212H)=1000H,(41214H)=4A00H则指令执行后:(IP)=1000H,(CS)=4A00H于是转到4B000H处开始执行指令。例中的DWORD PTR表示转移地址是一个双字。段间间接转移940001212+) 41212DS

5、SI0010004A 4121241213412144121510004A00IPCS段间间接转移操作示意图1111111111101100JMP DWORD PTR SI的机器码DS:SI10条件转移指令可实现程序的条件分支。条件转移指令根据标志位的状态来决定是否进行分支转移。格式: JXX label;xx为条件名称缩写指令的转移范围为-128+127字节。主要的条件转移指令参见p112表2-7。(2)条件转移指令 - JXX11 根据单个标志位设置的条件转移指令JB/JC ;低于,或CF=1,则转移JNB/JNC/JAE ;高于或等于,或CF=0,则转移JP/JPE ;奇偶标志PF=1(

6、偶),则转移JNP/JPO ;奇偶标志PF=0(奇),则转移JZ/JE ;结果为零(ZF=1),则转移JNZ/JNE ;结果不为零(ZF=0),则转移JS ;SF=1,则转移JNS ;SF=0,则转移JO ;OF=1,则转移JNO ;OF=0,则转移12这类指令主要用来判断两个数的大小。一般指令序列为: CMP dist,src ;比较 Jxx label ;根据比较结果转移 判断无符号数的大小JA 高于则转移(distsrc) 转移条件为: CF=0ZF=0JNA/JBE 低于或等于则转移(distsrc) 转移条件为: CF=1ZF=1 根据组合条件设置的条件转移指令13JG ;大于则转移

7、(distsrc) 转移条件为: (SFOF=0)ZF=0JGE ;大于或等于则转移(distsrc) 转移条件为: (SFOF=0)ZF=1JL ;小于则转移(distsrc) 转移条件为: (SFOF=1)ZF=0JLE ;小于或等于则转移(distsrc) 转移条件为: (SFOF=1)ZF=1 判断有符号数的大小14根据CX内容来决定是否转移的转移指令 JCXZ label 若(CX)=0,则转移到label处开始执行。152.循环控制指令用在循环程序中以确定是否要继续循环。循环次数通常置于CX中。转移的目标应在距离本指令-128+127的范围之内。循环控制指令不影响标志位。16(1)

8、LOOP格式:LOOP label操作:(CX)-1CX; 若(CX)0,则转至label处执行; 否则退出循环,执行LOOP后面的指令。 注:LOOP指令与下面的指令段等价: DEC CX JNZ label17(2)LOOPZ (LOOPE)格式:LOOPZ label操作:(CX)-1CX; 若(CX)0ZF=1,则转至label处执行; 否则退出循环,执行LOOP后面的指令。(3)LOOPNZ (LOOPNE)格式:LOOPNZ label操作:(CX)-1CX; 若(CX)0ZF=0,则转至label处执行; 否则退出循环,执行LOOP后面的指令。183. 过程调用和返回指令过程(子

9、程序) 一段具有特定功能的,供其它程序调用的公用程序。特点调用子程序时,IP(CS)的内容被压入堆栈栈顶。从子程序返回时,栈顶的内容又被弹出到IP(CS)。子程序执行结束后一般均要返回调用程序。一次定义,多次调用;可带参数调用,以完成不同的功能。优点 程序代码短,结构清晰,便于编程、调试、修改和阅读。 两条相关指令: 子程序调用指令 CALL 子程序返回指令 RET19一般格式:CALL sub ;sub为子程序的入口根据子程序入口的寻址方式,子程序调用有四类。段内直接调用子程序的偏移地址直接由CALL指令给出。 格式:CALL near_proc CALL执行时,它首先将IP内容压栈,然后把

10、指令中给出的位移量加到IP上。 注:汇编以后的调用地址是相对于CALL的下一条指令的位移量。例:CALL 0120H ;子程序偏移地址由指令给出(1)调用指令CALL20位移量由汇编程序在汇编时进行计算,如下例: CS:0102CALL 0120H;3字节 CS:0105 则位移量为: 0120-0105H=001BH于是CALL0120H的机器码为E8 1B 00 CS:0102E8 CS:01031B CALL 0120H CS:010400 CS:0105 21子程序的偏移地址在寄存器或存储器中。 格式:CALL mem16/reg16 CALL执行时,它首先将IP内容压栈,然后把指定的

11、寄存器/存储器的内容送入IP。 例: CALLBX ;子程序地址由BX给出 CALLWORD PTRSI ;子程序地址在存储器中段内间接调用22子程序的段地址和偏移地址直接由CALL指令给出。 格式:CALL far_proc ;far_proc为远过程的地址指令的操作为: CS内容压栈 IP内容压栈 CS段地址 IP偏移地址例:CALL 2000H:1000H CALL TIMER ;TIMER为远过程段间直接调用23子程序的段和偏移地址为存储器的连续4个单元中的内容。 格式:CALL mem32指令的操作为: SP(SP)-2 (SP)+1,(SP)(CS) ;CS压栈 CS(mem32+

12、2) SP(SP)-2 (SP)+1,(SP)(IP) ;IP压栈 IP(mem32)例:CALL DWORD PTRDI调用地址在DI,DI+1,DI+2,DI+3四个存储单元中。低字内容为偏移地址,高字内容为段地址。段间间接调用24段内返回指令RET的操作为: 恢复子程序执行前IP的内容。段间返回指令RET的操作为: 恢复子程序执行前IP和CS的内容。 另有一种带立即数的返回指令 “ RET n ”,其中n为偶数,表示从栈顶弹出地址后另外丢弃的字节数。例:RET 4 ;返回后再丢弃栈顶的4个字节(2)返回指令RET25例:下面的程序执行后,(AX)=? (DX)=? CS:2000H MO

13、V AX, 2012H 2003H MOV CX, 200CH 2006H PUSH CX 2007H CALL 4000H 200AH ADD AX, BX 200CH ADD AX, DX 200EH HLT CS:4000H MOV BX, 200AH POP DX RET264.中断指令8086/8088 CPU在程序中允许安排一条中断指令来引起一个中断过程,这种中断叫内部中断,或叫软中断。被中断的指令地址处称为“断点”。有关中断的详细情况将在第六章讨论。 中断指令共有三条: (1)INT n 执行类型n的中断服务程序,N=0255 (2)INTO 执行溢出中断的中断服务程序 (3)I

14、RET 从中断服务程序返回调用程序27(1) INT n格式: INT n说明: n4 = 向量地址。该向量地址中的内容即为中断服务程序入口地址(段:偏移),入口地址也称为“中断向量”。0000 : n4 XXHXXHYYHYYH中断服务程序入口的偏移地址(IP)中断服务程序入口的段地址(CS)中断类型码n = 0255内存中断向量28INT指令的操作:将FLAGS压入堆栈;将INT指令下一条指令的地址压栈(即把CS和IP的内容压栈);取中断服务程序入口地址送入CS和IP。 INT指令只影响IF和TF, 对其余标志位无影响INT指令可用于调用系统服务程序,如INT 21H29INT指令的操作例

15、:INT 21HIPLIPHCSLCSHSP=1200FLAGSLFLAGSHSP=11FA执行INT 21H指令后保护断点堆栈执行INT 21H指令前30INT指令的操作例(续):执行INT 21H指令后, CS=? IP=?因为n=21H,所以n4=84H。下图中,(0:0084H)=2000H:1123H所以: CS=2000H IP=1123H0000:0084H 23H11H00H20HIP CS0000 : 21H431 INTO检查溢出标志OF,如果OF=1,则启动一个类型4的中断过程;如果OF=0,不做任何操作。 通常INTO指令安排在有符号数算术运算指令后面。如IMULDXI

16、NTO ;若溢出,则启动INT 4, 否则往下执行MOVRESULT,AXMOVRESULT+2,DX (2)溢出中断INTO32用于从中断服务程序返回被中断的程序。IRET负责恢复断点(CS和IP)和恢复标志寄存器内容。任何中断服务程序不管是外部中断引起的,还是内部中断引起的,最后都要用IRET返回。IRET指令执行的操作为: 栈顶内容弹出到IP 栈顶内容弹出到CS 栈顶内容弹出到FLAG(3)中断返回指令IRET332.2.6 处理器控制指令1.标志操作指令 用来设置标志位的状态。 (1)CF设置指令 CLC 0CF STC 1CF CMC CF变反 (2)DF设置指令 CLD 0DF (串操作的指针移动方向从低到高)STD 1DF

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论