某微型计算机指令格式如图,第5章86系列微型计算机的指令系统——郑学坚、周斌《微型计算机原理及应用》讲述.ppt...

本文详细解析了86系列微型计算机的控制类指令,包括STD/CLD操作、中断允许标志IF控制、处理器控制指令如NOP、HLT和WAIT等,以及内存操作指令和寻址方式。通过实例和指令格式探讨,深入理解了指令系统的运作机制。
摘要由CSDN通过智能技术生成

第5章86系列微型计算机的指令系统——郑学坚、周斌《微型计算机原理及应用》讲述

5 控制类指令 指令组成: STD方向标志位置1指令:DF 1 CLD方向标志位置0指令:DF 0 指令说明:执行串操作指令过程中,决定字符地址的修改方向。STD置1:字符地址减量修改,CLD置0:字符地址增量修改。 方向标志DF操作指令 4.处理器控制指令 5 控制类指令 中断允许标志IF操作指令 指令组成: STI中断标志位置1指令:IF 1 CLI中断标志位置0指令:IF 0 指令说明: STI置1,开放中断;CLI清0,屏蔽外部中断。 4.处理器控制指令 5 控制类指令 2)其它处理机控制指令 (1)NOP无操作指令 (2)HLT停机指令 (3)WAIT等待指令 (4)LOCK总线封锁指令 (5)ESC交权指令 操作:不执行任何操作 操作:使CPU处于暂停状态 操作:不断测试引脚 操作:使引脚输出低电平信号 操作:为协助处理器提供操作码,数据总线把存储单元内容送出,并开始一条协处理器指令的执行 4.处理器控制指令 5 控制类指令 暂停指令 指令格式: HLT 指令说明: 该指令经常和中断过程联系在一起,常用于外部硬件中断。 4.处理器控制指令 交权指令 指令格式: ESC 指令说明: 在带协处理器的系统中,程序中的交权指令表示8086调用协处理器工作。 5 控制类指令 等待指令 指令格式: WAIT 指令说明: 该指令一般是和ESC指令配合使用。8086用ESC指令使协处理器工作以后,自己还可以执行一些其他操作,此时处于并行工作状态。要取回协处理器的处理结果。可安排一条等待指令WAIT指令过程中,不断测试CPU的TEST引腿上的信号。 4.处理器控制指令 5 控制类指令 总线封锁指令 指令格式: LOCK 指令说明: 该指令可以放在任何一条指令的前面,LOCK实际上是一个指令前缀。LOCK前缀用在8086最大模式中,在硬件上将CPU的LOCK引腿与总线控制器8289的LOCK输入端相连,用了指令前缀LOCK以后,CPU在执行前缀后面的一条指令时,会从LOCK引腿往外送1个低电平信号,CPU访问存储器或外设时,总线控制器会对总线实行封锁,使其他处理器得不到总线控制权,不能访问存储器或外设。 4.处理器控制指令 习题 5.1 分别指出下列指令中的源操作数和目的操作数的寻址方式: (1) MOV SI,200 (2) MOV CX,DATA[SI] (3) ADD AX,[BX][DI] (4) AND AX,BX (5) MOV [SI],AX (6) PUSHF 5.2 试述指令MOV AX,2010H和MOV AX,DS:[2010H]的区别。 习题 5.3 写出以下指令中内存操作数的所在地址。 (1) MOV AL,[BX+5] (2) MOV [BP+5],AX (3) INC BYTE PTR[SI+3] (4) MOV DL,ES∶[BX+DI] (5) MOV BX,[BX+SI+2] 5.4判断下列指令书写是否正确: (1) MOV AL,BX(6) MOV BL,F5H (2) MOV AL,CL(7) MOV DX,2000H (3) INC [BX](8) POP CS (4) MOV 5,AL(9) PUSH CS (5) MOV [BX],[SI] 习题 5.5 设堆栈指针SP的初值为2000H,AX=3000H,BX=5000H,试问: (1) 执行指令PUSH AX后SP=? (2) 再执行PUSH BX及POP AX后SP=?AX=?BX=? 5.6 要想完成把[2000H]送[1000H]中,用指令: MOV [1000H],[2000H]是否正确?如果不正确,应用什么方法? 5.7 假如想从100中减去AL中的内容,用SUB 100,AL是否正确?如果不正确,应用什么方法? 5.8 用两种方法写出从88H端口读入信息的指令。再用两种方法写出从42H口输出100H的指令。 习题 5.9 假如AL=20H,BL=10H,当执行CMP AL,BL后,问: (1) 若AL,BL中内容是两个无符号数,比较结果如何?影响哪几个标志位? (2) 若AL,BL中内容是两个有符号数,结果又如何?影响哪几个标志位? * * 交换过程可以在CPU的内部寄存器之间进行,也可以在内部寄存器和存储单元之间进行,但不能在两个存储单元之间执行数据交换过程。 * 执行XLAT指令可将任意一个十进制数翻译成7段显示码,其操作步骤如下: (1) 将译码表定位到某个逻辑段的一片连续地址中,并将其表首址的偏移地址置入BX寄存器中。 (2) 将待

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值