- 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.1 MCS-51单片机指令系统概述; ■ 指令的三种属性
功能属性:每条指令都对应一个特定的操作功能;
时间属性:一条指令执行所用的时间;
空间属性:一条指令在程序存储器中存储所占用的字节数。;★ MCS-51单片机指令系统及其指令格式
功能: 数据传送、算术操作、逻辑操作、程序转移、位操作等五大类;
空间属性: 单字节指令(49条)、双字节指令(46条)和最长的三字节指令(只有16条)。
时间属性: 单机器周期指令(64条)、双机器周期指令(45条)和只有乘、除法两条4个机器周期的指令。; 结构:操作码+操作数。
操作码:表示计算机执行该指令将进行何种操作。
操作数:表示参加操作的数的本身或操作数所在的地址。
(无操作数、单操作数、双操作数); 指令格式:
[标号:] 操作码助记符 [目的操作数][,源操作数] [;注释]; ■ 描述指令的一些符号的约定意义的说明:
▲ Ri和Rn:表示当前工作寄存器区中的工作寄存器,i取0或1,表示R0或R1。n取0~7,表示R0~R7。
▲ #data:表示包含在指令中的8位立即数。
▲ #data16:表示包含在指令中的16位立即数。
▲ rel:以补码形式表示的8位相对偏移量,范围为-128~127,主要用在相对寻址的指令中。; ▲ addr16和addr11:分别表示16位直接地址和11位直接地址。
▲ direct:表示直接寻址的地址。
▲ bit:表示可位寻址的直接位地址。
▲ (X):表示X单元中的内容。
▲ ((X)):表示以X单元的内容为地址的存储器单元内容,即(X)作地址,该地址单元的内容用((X))表示。
▲ / 和→符号:“/”表示对该位操作数取反,但不影响该位的原值。“→”表示操作流程,将箭尾一方的内容送入箭头所指另一方的单元中去。 ;3.2 寻 址 方 式;★ 立即寻址
★ 寄存器寻址
★ 寄存器间接寻址
★ 直接寻址
★ 变址寻址
★ 相对寻址
★ 位寻址;★ 立即寻址
操作数直接出现在指令中,紧跟在操作码的后面,作为指令的一部分与操作码一起存放在程序存储器中,可以立即得到并执行,不需要经过别的途径去寻找。
* 在一个数的前面冠以#符号作前缀。 ;★ 寄存器寻址
在指令选定的某寄存器中存放或读取操作数,以完成指令规定的操作。
* ACC,DPTR,AB,Rn,Cy ;★ 寄存器间接寻址
由指令指出某一寄存器的内容作为操作数地址的寻址方法。
* 寄存器中的内容不是操作数本身,而是操作数的地址,到该地址单元中才能得到操作数。
* @Ri,@DPTR
* 可寻址内部RAM(@Ri)和外部数据存储器(@Ri,@DPTR) ;图3.1 寄存器间接寻址示意图 ;★ 直接寻址
指令中直接给出操作数所在的存储器地址供存取数。
* 直接寻址可用于访问片内数据存储器(低128字节)、SFR。;★ 变址寻址;图3.2 变址寻址示意图 ;★ 相对寻址
以当前程序计数器PC值加上指令中给出的偏移量rel,而构成实际操作数地址。
* 用于访问程序存储器,常出现在相对转移指令中。
* 当前PC值指相对转移指令的存储地址加上该指令的字节数。
* 偏移量rel是有符号的单字节数,以补码表示,范围是-128~+127。转移的地址(目的地址)为:
目的地址=当前PC值+rel = 指令存储地址+指令字节数+rel;★ 位寻址
在位操作指令中直接给出位操作数的地址。
* 片内RAM中的128位和特殊功能寄存器SFR中的93位。;3.3 数据传送类指令;★ 访问片内数据存储器的一般数据传送指令
功能:实现数在片内RAM单元之间、寄存器之间、寄存器与RAM单元之间的传送。
格式:
MOV 目的操作数,源操作数;目的操作数单元←源
操作数(或单元) ;图3.3 访问片内RAM的一般传送指令操作关系图 ;表3.1 访问片内RAM的一般传送指令表;;★ 片内特殊传送指令
▲ 堆栈操作指令;(SP)←(SP)-1 修改指针,指向新栈顶
?
?
?
; ▲ 数据
文档评论(0)