微机原理-第03章-2 8086指令系统.ppt

  1. 1、本文档共107页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
3-3 8086的指令系统 数据传送指令 算术运算指令 逻辑运算、移位、循环指令 控制转移指令 处理器控制指令 串操作指令 (1) MOV传送指令 MOV dst,src ; dst ? src (2) 交换指令 格式: XCHG dst1,dst2 把 dst 与 src 的内容互换,即执行后的src等于执行前dst的内容,而执行后dst等于执行前src的内容。 (3)换码指令(查表指令) 格式: XLAT ;AL?(DS:(BX+AL)) 在数据段中,以BX与AL的和作为有效地址确定存储单元,再把该单元的字节数据送入AL中。 例: 十进制数字0~9转换成七段显示码的译码表,现在要取 3 的对应的七段译码。 (3)堆栈操作指令 PUSH src ;把src推入堆栈 POP dst ;从堆栈弹出到dst 例:设SS=0100 H, SP=0008H,AX=12C3H, BX = 5070 H PUSH AX ;(1) SP ? SP-2;SP=0006 ;(2) (0100 : 0006H) ? AX POP AX ;(1)将栈顶两单元内容送AX ;(2)SP ? SP+2 2、目标地址传送指令 (1)取有效地址 LEA reg16 , mem 功能 : 取存储器源操作数mem的有效地址(而不是单元内容)送16位寄存器 (2)双字指针传送 LDS reg16,men32 存储器中32位数据的前2个字节送16位寄存器,后2个字节送DS LES reg16,mem32 存储器中32位数据的前2个字节送16位寄存器,后2个字节送ES 传送指令的总线操作 传送指令的总线操作分析 3 指令系统——算术运算指令 3 指令系统——算术运算指令 数据运算的几点说明 参加运算的数据的类型在编程过程中是已经明确的。在开始编程之间,必须先设计好数据结构; 参加运算的数据类型相同,运算结果应该与参加运算的数据类型相同; 无符号数运算得到无符号数; 带符号数运算得到带符号数; BCD码运算结果还应该是BCD码; 计算注意小数点位置; 1)加法 ADD dst,src ;dst ? dst + src ADC dst,src ;dst ? dst + src + CF INC dst ;dst ? dst + 1 DAA ;把AL中的和值调整为压缩BCD AAA ;把AL中的和值调整为非压缩BCD MOV AL , BL ;取第一个加数 ADD AL , DL ;与第二个数进行二进制加 DAA ;加法的十进制调整 MOV BL , AL ;回送结果 例:有两个3字节BCD数存放在数据段的2000H和3000H开始的单元中,低位在前,高位在后。将两个数相加,结果放2000H开始的单元中 1)减法 SUB dst,src ;dst ? dst - src SBB dst,src ;dst ? dst - src - CF DEC dst ;dst ? dst - 1 DAS ;把AL中的差值调整为压缩BCD AAS ;把AL中的差值调整为非压缩BCD NEG dst ;dst ? 0 - dst 比较指令 格式: CMP src1,src2 ; src1 – src2 注意:CMP指令执行相减,但不回送结果,两个操作数的值都保持不变,结果只影响标志位CF、OF、SF、ZF、AF、PF。 2)带符号数大小比较:用 OF ⊕ SF判断 带符号数的最高位为符号位,减法运算借位标志CF反映的是符号位的借位状态,不能真正反映数值的大小,所以不能用CF来判断,需要用差值真值的符号来判断 差值真值为正(含等于0)时?被减数≥减数,差值真值为负?被减数减数 在不发生溢出情况 OF=0下 ,形式差值等于差值真值,则SF=1?被减数减数,SF=0 ?被减数≥减数 在发生溢出 OF=1情况下 ,形式差值的符号与差值真值符号相反,则SF=0?被减数减数,SF=1 ?被减数≥减数 综上所述:差值真值的符号 = OF⊕SF OF⊕SF=1?被减数减数, OF⊕SF=0?被减数≥减数 1)无符号乘法 MUL src8 ;A

文档评论(0)

好文精选 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档