- 1、本文档共83页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
单片机第三章课件
第三章 MCS-51单片机指令系统 §3-1 指令格式及其操作寻址方式 §3-2 指令系统 §3-1 指令格式及其操作寻址方式 一、基本概念 1、指令及其格式 什么是指令? 计算机认识什么样的指令? 指令能干什么? 机器指令:用2进制数0、1表示的命令代码。常以16进制表示。 机器语言:由机器指令描述的程序语言。 助记符指令:用字母和16进制数代替机器指令形成的符号指令。 助记符语言:由助记符指令形成的程序语言,又称汇编语言。 MCS-51单片机汇编语言指令格式: [标号:] 操作码 操作数(目的操作数,源操作数)[ ;注释] 其中: 标 号:称符号地址,代表该指令第1字节所在的地址。 操作码:规定了指令将要干什么,必不可少。 操作数:表示参与运算作的数或数的地址。 注 释:可有可无,必须以“;”开始。 2、指令中的符号标识 Ri、Rn、#data、#data16、addr11、addr16、 Direct、rel、bit @: 间接寻址符号 (X): X中的内容 ((X)): 由X的内容作为地址的单元中的内容 ←: 箭头左边的内容被右边的内容代替 / : 位操作数前缀,表示取反。 二、寻址方式 寻址方式:指令给出参与运算的数据的方式,即确定操作数地址的方法。 MCS-51指令寻址方式主要有6种:立即寻址、寄存器寻址、寄存器间接寻址、直接寻址、基址寄存器+变址寄存器间接寻址和相对寻址 1、立即寻址 操作数以常数的形式出现,直接跟在操作码后面, 以指令字节的形式存放在ROM中。 例如: MOV A, #40H MOV DPTR, #TABLE ;TABLE为标号地址 MOV P1, MOV R3, #18 3、寄存器间接寻址 指令中指出某一个寄存器的内容为操作数的地址,以符号“@”表示。其寻址范围: (1)以R0,R1为地址指针,寻址内部RAM 00~7FH 和外RAM的低256B; (2)以堆栈SP为地址指针,寻址栈区单元; (3)以DPTR(须用P2指定高8位地址) 为地址指针,寻址外部RAM的64KB空间和扩展 I/O口。 例:MOV A,@R0 ;(A)←((R0)) PUSH ACC ;((SP)) ←(A) MOVX A,@DPTR ;(A)←((DPTR) 4、直接寻址 在指令中直接给出了操作数所在的存储器地址,该地址指出了参与运算的数所在的字节单元地址或位地址(位寻址)。直接寻址的寻址范围: (1)内部数据存储器的低128字节,00H~7FH; (2)特殊功能寄存器,注意除A、B、DPTR外,其他 SFR只能采用直接寻址方式。 专用寄存器的表示形式: 位地址 如:SETB D5H 位名称 如:SETB F0 字节单元地址加位数 如:SETB D0.5 专用寄存器名称加位数 如:SETB PSW.5 (3)位寻址:所有可寻址位;(片内RAM 20H ~ 2FH,共128位,还有11个专用寄存器的各位83位,总计211位) 例如:MOV A, 70H ;(A)←(70H) MOV C, 70H ;(C)←(70H) 5、基址寄存器+变址寄存器间接寻址 (1)变址寻址 以基址寄存器(PC、 DPTR)和变址寄存器(A)的内容 作为无符号数相加,形成16位地址,访问程序存储器(表格)。 MOVC A,@A+PC ;(A)←((A)+(PC)) MOVC A,@A+DPTR ;(A)←((A)+(DPTR)) 例如:设(A)=30H,(PC)=1000H, 执行MOVC A,@A+PC的情况如下图所示。 取数地址为:1001+30=1031H。 显然: 当(A)=00H时,新(PC)=1001H; 当(A)=FFH时,新(PC)=1100H; (2)相对寻址 指令中给定地址的相对偏移量rel,以PC当前值为基地址,加上rel所得结果为转移目标地址。 rel:符号数,单字节补码,-128~+127。
文档评论(0)