微机原理与接口技术 西安邮电大学计算机学院 宁晓菊
第四章 80x86 指令系统(第八讲) 第一章 微型计算机系统导论(第一讲) 本讲主要内容 控制转移指令 1 2 处理器控制指令
第四章 80x86 指令系统—控制转移指令 控制转移类指令 能够使程序的执行流程发生改变的指令 1.无条件转移 JMP 转移指令 操作:有以下几种类型 ⑴ 段内直接短转移 JMP SHORT opr ;(IP)←(IP) + Data8 Data8是一个字节的补码数 范围:-128+127
第四章 80x86 指令系统—控制转移指令 ⑵ 段内直接近转移 JMP NEAR PTR opr ;(IP)←(IP)+Data16 范围:-32768 +32767 ⑶ 段内间接转移 JMP WORD PTR opr (IP)←寄存器或存储器操作数 ⑷ 段间直接转移 JMP FAR PTR opr 指令中用立即数的形式指出目标位置的段地址和偏移量
第四章 80x86 指令系统—控制转移指令 ⑸ 段间间接转移 JMP DWORD PTR opr 目标位置的段地址和偏移量保存在存储器中。 说明: ① 在汇编语言中通常使用标号表示要转移到的位置。 ② 使用该指令,可以使程序流程改变到任何目标位置。
第四章 80x86 指令系统—控制转移指令 2.条件转移 根据判断条件是否成立决定是否转移。按照判断条件的不同分为以下类型:单个标志、无符号数判断、有符号数判断、CX寄存器。 条件转移都是段内直接短转移,即(IP)=(IP)+Data8类型的转移。 指令格式:Jcc short_label “cc”表示条件 ⑴ 判断单个标志 ZF: JZ(JE),JNZ(JNE) SF: JS,JNS OF: JO,JNO PF: JP,JNP CF: JC,JNC
第四章 80x86 指令系统—控制转移指令 ⑵ 判断无符号数的大小 助记符中的意义: A(above):大于,B(below):小于, E(equal):等于 JB(JNAE),JNB(JAE), JA(JNBE), JNA(JBE) 判断CF and ZF ⑶ 判断有符号数的大小 助记符中的意义: G(greater):大于,L(less):小于, JL(JNGE),JNL(JGE),JLE(JNG),JNLE(JG) 判断CF and ZF and SF 使用比较大小的指令时,必须区分是有符号数还是无符号数。
第四章 80x86 指令系统—控制转移指令 ⑷ 判断CX寄存器 JCXZ: CX=0
第四章 80x86 指令系统—控制转移指令 3.循环控制 循环指令的转移也都是段内直接短转移,即(IP)←(IP)+Data8类型的转移。
第四章 80x86 指令系统—控制转移指令 (CX)0循环 LOOP disp8 (CX) (CX)-1 当 (CX)0 指令名称 指令格式 指令功能 测试条件 (CX)0循环 LOOP disp8 (CX) (CX)-1 当 (CX)0 则 (IP) (IP)+disp8 (CX)0 为零或相等循环 LOOPZ disp8 LOOPE disp8 当 (CX)0 且 (ZF)=1 (CX)0 且 (ZF)=1 非零或不等循环 LOOPNZ disp8 LOOPNE disp8 当 (CX)0 且 (ZF)=0 (CX)0 且 (ZF)=0
第四章 80x86 指令系统—控制转移指令 说明: ① 循环指令不影响状态标志。 ② 如果目标位置的位移量超出Data8所能够表示的范围,则需要用JMP辅助来完成循环。
第四章 80x86 指令系统—控制转移指令 例4.16 在内存的数据段中存放了若干个8位带符号数,数据块的长度为COUNT(不超过255),首地址为TABLE,试统计其中正数、负数及零的个数,并分别将统计结果存入PLUS、MINUS和ZERO单元中。
第四章 80x86 指令系统—控制转移指令 分析: 为了统计正数、负数和零的个数,可先将PLUS、MINUS和ZERO三个单元清零,然后将数据表中的带符号数逐个取入AL寄存器并使其影响状态标志位,再利用前面介绍的JS、JZ等条件转移指令测试该数是一个负数、零还是正数,然后分别在相应的单元中进行计数。 程序如下:
第四章 80x86 指令系统—控制转移指令 CHECK: LODSB XOR AL,AL OR AL,AL MOV PLUS,AL JS X1 JZ X2 INC PLUS JMP NEXT X1: INC MINUS X2: INC ZERO NEXT: LOOP CHECK HLT XOR AL,AL MOV PLUS,AL MOV MINUS,AL MOV ZERO,AL LEA SI,TABLE MOV CX,COUNT CLD
第四章 80x86 指令系统—控制转移指令 4.子程序调用 CALL 子程序调用指令 用法:CALL dst 说明:由汇编程序自动匹配为某种寻址方式。 RET 子程序返回指令 用法:RET 段内返回:(IP)←((SP)+1:(SP)),(SP)←(SP)+2 段间返回:(IP)←((SP)+1:(SP)),(SP)←(SP)+2, (CS)←((SP)+1:(SP)),(SP)←(SP)+2 汇编程序自动匹配为段内或段间的返回
第四章 80x86 指令系统—处理器控制指令 处理器控制指令 1. 标志处理指令 CLC 对CF清零, CF ← 0 STC 对CF置位, CF ← 1 CMC 对CF取反,CF← CF CLD 对DF清零,DF ← 0 STD 对DF置位,DF ← 1 CLI 对IF清零,IF ← 0 STI 对IF置位,IF ← 1
第四章 80x86 指令系统—处理器控制指令 2. 处理器控制指令 NOP (No Operation) 空操作 一个字节的机器码,没有操作数,对状态标志位没有影响。不执行任何操作,但占用3个时钟周期,然后继续执行下一条指令。 HLT (Halt) 停机 处理器停止工作,进入暂停状态。外部中断或复位信号可使CPU退出暂停状态。对状态标志位没有影响。 WAIT (Wait) 等待 处理器处于等待状态,等到外部的TEST引脚上的低电平到来。
第四章 80x86 指令系统—处理器控制指令 ESC (Escape) 换码 该指令是一个交权的指令前缀,把指令给协处理处理。 一般和WAIT指令一起使用,通过TEST引脚和协处理器同步。 LOCK (Lock) 封锁 该指令是一个前缀,使得使用此前缀的指令执行时一直维持总线封锁状态。
学习要求 第四章 80x86 指令系统 指令系统是程序员编写程序的基础,因此很好地掌握本 章内容是后续进一步学习汇编语言程序设计的关键。通过本 章学习,应该达到如下要求: 1、熟练掌握8086/8088的寻址方式。 3、掌握8086/8088指令系统中的各种指令的名称、功能、 对操作数寻址方式的约定、 及指令执行对标志寄存器的 影响。
Thank you!