第3章MCS-51单片机指令系统讲解.ppt

  1. 1、本文档共54页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
用于对BCD码十进制数加法运算结果的内容修正。 指令格式: DA A 两个BCD码按二进制相加之后,必须经本指令的调整 才能得到正确的压缩BCD码的和数。 二进制数的加法运算原则并不能适用于十进制数的加法运算,有时会产生错误结果。例如: (a)3+6=9 0011+0101=1001 运算结果正确 (b)7+8=15 0111+1000=1111 运算结果不正确 (c)9+8=17 1001+1000=00001 C=1 结果不正确 二进制数加法指令不能完全适用于BCD码十进制数的加法运算,对结果作有条件的修正 ——十进制调整 出错原因和调整方法: BCD码只用了了其中的10个,6个没用到的编码。 (1010,1011,1100,1101,1110,1111)为无效码 凡结果进入或者跳过无效码编码区时,其结果就是错误的。 调整的方法是把结果加6调整,即所谓十进制调整修正。 修正方法应是: (a)累加器低4位大于9或辅助进位位Ac=1,则进行低4位加6修正。 (b)累加器高4位大于9或进位位Cy=1,则进行高4位加6修正。 (c)加器高4位为9,低4位大于9,则高4位和低4位分别加6修正。 具体是通过执行指令:DA A 来自动实现的 。 例 (A)=56H,(R5)=67H,把它们看作为两个压缩的BCD数,进行BCD数的加法。执行指令: ADD A,R5 DA A 由于高、低4位分别大于9,所以要分别加6进行十进制调整对结果进行修正。 结果为: (A)=23H,Cy=1 可见,56+67=123,结果是正确的。 5.带借位的减法指令 4条指令: SUBB A,Rn ; (A)-(Rn)- Cy→A,n=0~7 SUBB A,direct ; (A)-(direct)- Cy→A SUBB A,@Ri;(A)-((Ri))- Cy→A, i=0,1 SUBB A,#data ;(A)-#data - Cy→A 从累加器A中的内容减去指定的变量和进位标志Cy的值,结果存在累加器A中。 如果位7需借位则置“1” Cy,否则清“0”Cy; 如果位3需借位则置“1”Ac,否则清“0”Ac; 如果位6需借位而位7不需要借位,或者位7需借位,位6不需借位,则置“1”溢出标志位OV,否则清“0”OV。 例 (A)=C9H ,(R2)=54H,Cy=1,执行指令: SUBB A,R2 结果:(A)=74H,Cy=0,Ac=0,OV=1(位6向位7借位) 6.减1指令 4条指令: DEC A ;(A)-1→A DEC Rn ;(Rn)-1→Rn,n=0~7 DEC direct ;(direct)-1→direct DEC @Ri ;((Ri))-1→(Ri),i=0,1 减1指令不影响标志位。 7.乘法指令 MUL AB ;A×B→BA 如果积大于255,则置“1”溢出标志位OV 8.除法指令 DIV AB ;A/B→A(商),余数→B 如果B的内容为“0”(即除数为“0”),则存放结果的A、B中的内容不定,并置“1”溢出标志位OV。 3.4.3 逻辑运算指令 1. 简单逻辑操作指令 (1) CLR A 功能是累加器A清“0”。不影响Cy、Ac、OV等标志。 (2) CPL A 功能是将累加器A的内容按位逻辑取反,不影响标志。 2.左环移指令 RL A 功能是累加器A的8位向左循环移位,位7循环移入位0,不影响标志。 3.带进位左环移指令 RLC A 功能是将累加器A的内容和进位标志位Cy一起向左环移一位,Acc.7移入进位位Cy,Cy移入Acc.0,不影响其它标志。 4.右环移指令 RR A 功能是累加器A的内容向右环移一位,Acc.0移入Acc.7,不影响其它标志。 5.带进位环移指令 RRC A 这条指令的功能是累加器A的内容和进位标志Cy一起向右环移一位,Acc.0进入Cy,Cy移入Acc.7。 6.累加器半字节交换指令 SWAP A 将累加器A的高半字节(Acc.7~Acc.4)和低半字节(Acc.3~Acc.0)互换。 例 (A)=0C5H,执行指令: SWAP A 结果:(A)=5CH 7.逻辑与指令 ANL A,Rn ; (A)∧(Rn)→A,n=0~7

您可能关注的文档

文档评论(0)

shuwkb + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档