3 指令系统及汇编.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
3 指令系统及汇编

单片机原理 任课教师: 朱奇光 E-MAIL:zhu7880@ysu.edu.cn 第三章 MCS-51单片机指令系统 3.1 指令分类 3.2 指令格式 3.3 指令系统的寻址方式 3.4 指令系统分类介绍 3.5 伪指令 3.1 指令分类 1.按指令所占的字节数可分为: (1)单字节指令(49条) (2)双字节指令(46条) (3)三字节指令(16条) 2.按指令的执行时间可分为: (1) 单周期指令(65条) (2) 双周期指令(44条) (3) 四周期指令(2条):乘、除 3、按指令的功能可分为: (1) 数据传送类指令(29条) (2) 算术运算类指令(24条) (3) 逻辑运算类指令(24条) (4) 控制转移类指令(17条) (5) 位操作类指令(17条) 3.2 指令格式 MCS—51单片机汇编语言指令的标准格式包括四部分: [标号: ]操作码 [目的操作数][, 源操作数][; 注释] 例如: LOOP: ADD A, #10H ; (A)←(A)+10H (1) 方括号[ ]表示该项是可选项, 可有可无。 (2) 标号是用户设定的符号, 它实际代表该指令所在的地址。 标号必须以字母开头, 其后跟1~8个字母或数字, 并以“:”结尾。 (3) 操作码是用英文缩写的指令功能助记符。它确定了本条指令完成什么样的操作功能。如: ADD表示加法操作。任何一条指令都必须有该助记符项, 不得省略。 3.2 指令格式 (4) 目的操作数提供操作的对象, 并指出一个目标地址, 表示操作结果存放单元的地址, 它与操作码之间必须以一个或几个空格分隔。如上例中A表示操作对象是累加器A的内容, 并指出操作结果又回送A存放。 (5) 源操作数指出的是一个源地址(或立即数), 表示操作的对象或操作数来自何处。它与目的操作数之间要用“,”号隔开。 (6) 注释部分是在编写程序时, 为了增加程序的可读性, 由用户拟写对该条指令或该段程序功能的说明。它以分号“;”开头, 可以用中文、英文或某些符号来表示, 显然它不存入计算机, 只出现在源程序中。 3.2 指令格式 在MCS-51单片机指令系统中,有单字节指令、双字节指令、三字节指令这些不同长度的指令,指令长度不同,格式也不相同: (1) 单字节指令:指令只有一个字节,操作码和操作数同在一个字节。 (2)双字节指令:一个字节为操作码,另一个字节为操作数。 (6)三字节指令:操作码占一个字节,操作数占两个字节。其中操作数既可以时数据,也可以是地址。 3.2 指令格式 指令中常用符号 在分类介绍各类指令之前, 先对描述指令的一些符号意义进行一些简单约定: (1) Ri和Rn: R表示当前工作寄存器区中的工作寄存器, i表示0或1, 即R0和R1。 n表示0~7, 即R0~R7, 当前工作寄存器的选定是由PSW的RS1和RS0位决定的。 (2) #data: #表示立即数, data为8位常数。 #data是指包含在指令中的8位立即数。 3.2 指令格式 (3) #data16: 包含在指令中的16位立即数。 (4) rel: 相对地址, 以补码形式表示的地址偏移量, 范围为-128~+127, 主要用于无条件相对短转移指令SJMP和所有的条件转移指令中。 (5) addr16: 16位目的地址。目的地址可在全部程序存储器的64 KB空间范围内, 主要用于无条件长转移指令LJMP和子程序长调用指令LCALL中。 (6) addr11: 11位目的地址。 目的地址应与下条指令处于相同的2 KB程序存储器地址空间范围内, 主要用于绝对转移指令AJMP和子程序绝对调用指令ACALL指令中。 3.2 指令格式 (7) direct: 表示直接寻址的地址, 即8位内部数据存储器RAM的单元地址(0~127/255), 或特殊功能寄存器SFR的地址。对于SFR可直接用其名称来代替其直接地址。 (8) bit: 内部数据存储器RAM和特殊功能寄存器SFR中的可直接寻址位地址。 (9) @: 间接寻址寄存器或基地址寄存器的前缀, 如@Ri, @DPTR, 表示寄存器间接寻址。 3.2 指令格式 (10) (X): 表示X中的内容。 (11) ((X)): 表示由X寻址的单元中的内容, 即(X)作地址, 该地址的内容用((X))表示。 (12)符号/ : 表示对该位操作数取反, 但不影响该位的原值。 (13)符号→:表示指令操作流程, 将箭头一方的内容, 送入箭头另一方的单元中去。 3.

文档评论(0)

xxj1658888 + 关注
实名认证
文档贡献者

教师资格证持证人

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

领域认证该用户于2024年04月12日上传了教师资格证

1亿VIP精品文档

相关文档