- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第3章 MCS-51的指令系统 学习要点: 熟练掌握汇编语言的各类指令 第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个时钟振荡周期)。 12MHz晶振:机器周期为1?s。 3.2 指令格式 指令的表示方法称为指令格式,包括指令的长度、指令内部信息的安排等。由两部分组成,即操作码和操作数。 操作码用来规定指令进行什么操作 操作数则是指令操作的对象 对于指令中的操作数,因为指令常伴有从右向左传送数据的内容,因此把左边的操作数称为目的操作数,右边的操作数称为源操作数。 有单字节指令、双字节指令、三字节不同长度的指令,格式不同: (1)单字节指令(49条):指令只有一个字节,操作码和操作数同在一个字节中。如MOV A,Rn指令机器码11001rrr,其中rrr可表示000—111分别代表R0—R7 (2)双字节指令(45条):一个字节为操作码,另一个字节是操作数。如MOV A,#data (3)三字节指令(17条):操作码占一个字节,操作数占二个字节。其中操作数既可能是数据,也可能是地址.如ANL direct,#data。第一个字节操作码,第二个字节8位地址direct,第三个字节8位立即数,#data 3.3 指令系统的寻址方式 寻址方式就是在指令中说明操作数所在地址的方法。 共7种寻址方式。在指令中通常根据源操作数来决定寻址方式 1.寄存器寻址方式 操作数在寄存器中,即在指令中把指定寄存器的内容作为操作数。在寄存器寻址方式中,用符号名称表示寄存器。 例如: INC R0;把R0的内容加1再送回到R0中。寻址示意图 寻址范围包括: (1)4组通用工作寄存区共32个工作寄存器。指令中只能用当前指定寄存器组 (2)部分特殊功能寄存器,例如累加器A、B寄存器以及数据指针DPTR等。 2.直接寻址方式 操作数直接以单元地址的形式给出: MOV A,3AH 寻址范围: (1) 内部RAM的128个单元,直接寻址方式只能给出8位地址,限于片内RAM (2) 特殊功能寄存器。除了以单元地址的形式外,还可用寄存器符号的形式给出。直接寻址是访问特殊功能寄存器的唯一方法。例如: MOV A,80H 与 MOV A,P0是等价的。 3. 寄存器间接寻址方式 指令中在寄存器中存放的是操作数的地址,从该地址取出来的才是操作数 在寄存器的名称前面加前缀标志“@” 访问内部RAM或外部数据存储器的低256个字节时,只能采用R0或R1作为间址寄存器。例如: MOV A,@Ri ;i=0或1 其中Ri中的内容为40H,把内部RAM40H单元内容送A。 寻址范围: (1)访问内部RAM低128个单元,其通用形式为@Ri (2)对片外数据存储器的64K字节的间接寻址,例如: MOVX A,@DPTR (3)片外数据存储器的低256字节 例如:MOVX A,@Ri (4)堆栈区 堆栈操作指令PUSH(压栈)和POP(出栈)使用堆栈指针(SP)作间址寄存器 4.立即寻址方式 操作数在指令中直接给出,需在操作数前面加前缀 “#”。例如: MOV DPTR,#1234H 5.基址寄存器加变址寄存器间址寻址方式 本寻址方式是以DPTR或PC作基址寄存器,以累加器A作为变址寄存器,两者相加形成的16位程序存储器地址为操作数地址。 例如:指令 MOVC A,@A+DPTR 其中A的原有内容为54H,DPTR的内容为1256H,该指令执行的结果是把程序存储器12AAH单元的内容传送给A。若12AAH单元内容为0,则A的内容也变成0 变址寻址示意图 说明: (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中的位寻址区。位有两种表示方
文档评论(0)