2014年第6章-单片机指令系统[3]孙旭飞.ppt

  1. 1、本文档共40页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
福州大学物理与信息工程学院 第六章 指令系统 二、 算术运算指令 算术运算指令进行加、减、乘、除四则运算,以及增量、减量、二-十进制调整操作 共24条 算术运算指令影响PSW标志位 1、加法指令 1)不带进位的加法指令ADD 源操作数均为累加器A中的内容,将目的操作数与A中的内容相加,结果也放在A中。 ADD A, Rn ;(A) ←(A)+(Rn) ADD A, @Ri ;(A) ←(A)+((Ri)) ADD A, direct ;(A) ←(A)+(direct) ADD A, #data ;(A) ←(A)+#data 对标志位的影响: D7产生进位,则(CY)=1,否则(CY)=0 D3产生进位,则(AC)=1,否则(AC)=0 作为有符号数,溢出(超出-128~+127) 则 OV =1,运算结果出错, 否则 OV =0,运算结果正确。 结果A中“1”的个数为奇数,则(P)=1, 否则(P)=0 例: 设(A)= 84H,(30H)=8DH ADD A,30H 则(A)=11H ;(CY)= 1; (AC)= 1; (OV)= 1; (P)= 0 分析: 当作为无符号数时:84H=132,8DH=141 84H+8DH = 273 256 则(CY)=1 当作为有符号数时:84H = -124, 8DH = -115 (-124) + (-115) = -239 超出-128~+127,故溢出(OV)=1。 事实上,两个负数相加,其结果(A)=11H=17为正数,不合理,必然溢出。 例: MOV A, #0B3H MOV 20H, #10H MOV R0, #20H ADD A, R0 ADD A, @R0 ADD A, #10H 2)带进位加法指令ADDC 用于多字节加法运算,使在进行高字节加法时考虑到低字节向高字节的进位。 ADDC A, Rn ;(A)← (A)+(Rn)+(Cy) ADDC A, @Ri ;(A)← (A)+((Ri )) +(Cy) ADDC A, direct ;(A)← (A)+(direct) +(Cy) ADDC A, #data ;(A)← (A)+#data +(Cy) 对标志位的影响与ADD相同 例: (A)=42H,(R3)=68H,(CY)=1 ADDC A,R3 结果: (A)=0ABH (CY)=0 (AC)=0 (OV)=1 (P)=1 3)加1指令 INC A ;(A)←(A)+1 INC Rn ;(Rn)←(Rn)+1 INC direct ;(direct)←(direct)+1 INC @Ri ;((Ri))←((Ri))+1 INC DPTR ;(DPTR)←(DPTR)+1 该指令是唯一的16位运算指令 注:除INC A和INC ACC影响P标志位外,其他均不影响PSW标志位。 比较 INC A ADD A, #01H 前者不影响标志位CY、OV、AC 后者影响标志位CY、OV、AC 前者为1个字节 后者为2个字节 常用于访问连续地址和循环程序中循环数的控制 例:把20H~2FH单元内容移入40H~4FH单元中 MOV R0,#20H MOV R1,#40H MOV A,@R0 MOV @R1,A INC R0 INC R1 · · · · · · MOV A,@R0 MOV @R1,A INC R0 INC R1 4)十进制调整指令 以上是十六进制表示的二进制的加法运算,其结果都是十六进制。十进制(BCD码)加法的结果应该是十进制,但系统没有专门的十进制指令,因此只能借助二进制加法指令(把十进制当作十六进制相加),但结果可能出现A~F,BCD码中无A~F,所以需要进行十进制调整,将十进制加法结果调整为十进制。 DA A 例: 求67D和56D的和,先看作67H+56H

文档评论(0)

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

1亿VIP精品文档

相关文档