- 1、本文档共58页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第3章指令系统-改资料
第3章 MCS-51的指令系统 本章介绍MCS-51汇编语言的指令系统。 3.1 指令系统概述 MCS-51的基本指令共111条,按指令在程序存储器所占的字节来分,其中: (1) 单字节指令49条; (2) 双字节指令45条; (3) 三字节指令17条。 按指令的执行时间来分,其中: (1) 1个机器周期(12个时钟振荡周 期)的指令64条; (2) 2个机器周期(24个时钟振荡周期)的指令45条; (3) 4个机器周期(48个时钟振荡周 期)的指令2条; 在12MHz晶振的条件下,每个机器周期为1?s。 3.2 指令格式 由两部分组成,即操作码和操作数。 操作码用来规定指令进行什么操作。 操作数则是指令操作的对象。 按指令字节的长度,有单字节指令、双字节指令、三字节不同长度的指令,指令长度不同,格式也就不同。 (1)单字节指令:指令只有一个字节,操作码和操作数同在一个字节中。 (2)双字节指令:一个字节为操作码,另 一个字节是操作数。 (3)三字节指令:操作码占一个字节,操作数占二个字节。其中操作数既可能是数据,也可能是地址。 3.3 指令系统的寻址方式 寻址方式就是在指令中说明操作数所在地址方法。共7种寻址方式。 1.寄存器寻址方式 操作数在寄存器中 MOV A,Rn ;(Rn)→A,n=0~7 表示把寄存器Rn的内容传送给累加器A。 寻址范围包括: (1)4组通用工作寄存区共32个工作寄存器。 (2)部分特殊功能寄存器,例如A、B 以及数据指针寄存器DPTR等。 2.直接寻址方式 操作数直接以单元地址的形式给出 MOV A,40H 寻址范围: (1) 内部RAM的128个单元 (2) 特殊功能寄存器。除了以单元地址的形式 外,还可以用寄存器符号的形式给出。例如: MOV A,80H 与 MOV A,P0 是等价的。 52系列单片机采用直接寻址方式访问特殊功能寄存器,以与片内RAM(80H~FFH)的访问方式相区别。 3. 寄存器间接寻址方式 寄存器中存放的是操作数的地址。 在寄存器的名称前面加前缀标志“@”。 只能采用R0或R1作为间址寄存器。 可以用其访问内部RAM或外部数据存储器的低256个字节。 例如: MOV A,@Ri ;i=0或1 其中Ri中的内容为40H,把内部RAM中40H单元的内容送到A。 寻址范围: (1)访问内部RAM低128个单元,其通用形式为@Ri (2)对片外数据存储器的64K字节的间接寻址,例如: MOVX A,@DPTR; (3)片外数据存储器的低256字节 例如:MOVX A,@Ri (4)堆栈区 堆栈操作指令PUSH(压栈)和POP(出栈)使用堆栈指针(SP)作间址寄存器。 4.立即寻址方式 操作数在指令中直接给出,需在操作数前面加前缀标志“#”。例如: MOV A,#40H 5.基址寄存器加变址寄存器间址寻址方式(变址寻址) 本寻址方式是以DPTR或PC作基址寄存器,以累加器A作为变址寄存器。 例如:指令 MOVC A,@A+DPTR 其中A的原有内容为05H,DPTR的内容为0400H,该指令执行的结果是把程序存储器0405H单元的内容传送给A。 说明: (1)本寻址方式是专门针对程序存储器的寻址方式,寻址范围可达到64KB。 (2)本寻址方式的指令只有3条: MOVC A,@A+DPTR MOVC A,@A+PC JMP @A+DPTR 6.位寻址方式 MCS-51有位处理功能,可以对数据位进行操作。 例如: MOV C,40H 是把位40H的值送到进位位C。 寻址范围包括: (1)内部RAM中的位寻址区。位有两种表示方法,例 如,40H;另一种是单元地址加上位,例如,(28H).0,指的是28H单元中的最低位。它们是等价的。 (2)特殊功能寄存器中的可寻址位 在指令中有如下4种的表示方法: 接使用位地址。例如PSW.5的位地址为0D5H。 位名称的表示方法。例如PSW.5是F0标志位,可使用F0表示该位。 单元地址加位数的表示方法。例如 :(0D0H).5。 特殊功能寄存器符号加位
文档评论(0)