MCS-51指令系统

合集下载

第03章 MCS-51指令系统

第03章  MCS-51指令系统
► 例:
三、指令系统支持的寻址方式(4-2)
► 寄存器间接寻址的三种用法: ► ⑴可以借助于 R0 或 R1 这 2 个工作寄存器用 MOV 指
令进行寄存器间接寻址来寻址片内RAM区的通用寄 存器; ► ⑵可以借助于R0或R1这2个工作寄存器用MOVX指 令进行寄存器间接寻址来寻址片外 64K数据存储器 R0R1片外 区的低256单元; ► ⑶还可以借助于16位的数据指针DPTR用MOVX指 令进行寄存器间接寻址来寻址整个片外64K数据存 DPTR片外 储器区中的任一单元。
► 4、寄存器间接寻址:
操作码中包含着R0或R1这2 个工作寄存器中某一个的序号,而该工作寄存器中 的内容为存放操作数的地址。
E7H MOV A,@R1 ► 若指令执行前 ► PSW.4=0(RS1)、PSW.3=0(RS0)、 ► (01H)=30H(R1)、(30H)=33H; ► 则执行指令后累加器A即(E0H)=33H。 ► 必须注意的是 52 子系列片内 RAM 中高 128 单元的 通用寄存器只能用此方式寻 变址寻址
位寻址
PC+偏移量 @+PC,@+DPTR
程序存储器 程序存储器
片内RAM中的位寻址 区,可以位寻址的特 殊功能寄存器位
四、指令系统支持的辅助结果(1)
► 指令操作的辅助结果存放在程序状态字PSW(D0H)
之中,其一个字节的 8 位内容除 D1 位未用外,其 余各位的定义分别为: ► 1、进位标志C(D7): ► 加、减法运算有进、借位时C=1,否则C=0; ► 位处理时,作位累加器用,即存放第一操作 数与结果; ► 2、辅助进位标志AC(D6): ► 加、减法运算时低半字节的 D3 位有进、借位 时AC=1,否则AC=0; ► 3、软件标志 F0(D5): 由软件置位或复位, 归用户定义使用;

MCS-51单片机指令系统教程(3)

MCS-51单片机指令系统教程(3)
MOV IE,#00H ;初始化中断允许寄存器 MOV TH1,#0FEH ;为定时器1赋初值 尽管使用SFR的寄存器名称来取代直接地址,可以带 来程序的可读性,但是在汇编时,仍要将寄存器名字转换 为直接地址。
2,当直接地址时在工作寄存器区中时,可以使用两种寻址 方式来访问。 如:
MOV A,00H ;将RAM中00H单元数据送累加器A
04
03
02
01
00
返回前一次
2.2.3立即寻址
指令本身直接含有所需要的8位或16位的操作数。
将此数称为“立即数”(使用#标明)。如:
MOV A,#30H
;将(8位)立即数送累加器A
MOV DPTR,#2000H ;16位立即数送DPTR积存器
【注意】:MOV A,#30H MOV A,30H 两者的区别。 立即数寻址的指令长度为2或3个字节。
三字节指令在存储器中存放的方式示意图
指令的字节数与指令的运行时间
指令的字节多是否意味着指令周期就长?
指令
字节数 周期数
MOV A,R0
1
1
MOV A,#0FFH 2
1
MOV 20H,#30H 3
2
MUL AB
1
4
INC DPTR
1
1
指令说明 R0内容送累加器A
立即数FFH送A 立即数30H送内存20h单元
累加器A 02H
ALU
DPTR 0300H
0300H + 02H
0302H
ROM
0302H X
返回
MOVC A,@A+DPTR
2.2.6 相对寻址
转移指令中使用的一种寻址方式。MCS-51单片机的指令 系统中,有两类转移指令:相对转移( 2个或3个字节)

MCS-51指令系统

MCS-51指令系统

❖ 目的操作数寻址方式(3种):
直接寻址、寄存器寻址、寄存器间接寻址
除了目的操作数为ACC的指令影响奇偶标志P外,一般不影响
标志位。2022/2/15
16
3.3.1 十六位数的传递指令(1条)
MOV DPTR,#data16
8051是一种8位机,这是唯一的一条16位立即数传递指 令。功能:将一个16位的立即数送入DPTR中去。其中 高8位送入DPH,低8位送入DPL。
2022/2/15
2
常用符号 Rn:工作寄存器中的寄存器R0、R1…R7之一,
Ri:工作寄存器中的寄存器R0或R1
#data:8位立即数
#data16:16位立即数 direct:片内RAM或SFR的地址(8位)
@间接寻址寄存器
Bit:片内RAM或SFR的位地址 addr11:11位目的地址
addr16:16位目的地址
者内容相加,结果作为操作数的地址。
常用于查表操作。 ❖ MCS-51
操作数在程 序存储器中
MOVC A, @A+DPTR ;(A+DPTR) →A
MOVC A, @A+PC ; PC+1 →PC,(A+PC)→A
2022/2/15
10
如:MOVC A,@A+DPTR 设DPTR=2000H,A=E0H
常用于跳转指令。 如: JC 23H 若C=0,不跳转; C=1,跳转.
2022/2/15
12
如:JC 23
程序存储区
1000H 40 1001H 23 1002H 30
当前PC …

1024H 47 1025H 45
指令代码
23H

MCS-51单片机的指令系统

MCS-51单片机的指令系统

整理ppt
12
4.2 寻址方式
51汇编语言有42种操作码助记符,用来描述33种操作功 能。一种操作码可以使用一种以上的数据类型,又由于 助记符规定了其访问的存储器空间,所以一种功能可能 有几个助记符(如MOV、MOVX、MOVC)。功能助记 符与寻址方式组合,得到111条指令。
整理ppt
13
4.2 寻址方式
1)无操作数单字节指令
这类指令只有操作码字段,操作数隐含在操作码中。
例如:INC DPTR
指令码为 :
数据指针隐含其中
整理ppt
6
指令的组成及字节数
2)含有操作数寄存器号的单字节指令 单字节的指令码由操作码字段和指示操作数所 在寄 存器号的字段组成。 例如;MOV A,Rn 指令码为:
其中,rrr为寄存器Rn的编号
整理ppt
2
4.1 指令和指令程序
“指令”: CPU能直接识别和执行的命令。 指令系统:CPU所能执行的全部指令的集合。
与CPU的能力、使用的方便灵活性密切相关。 指令的记忆问题?指令本身是二进制代码。
例如以下的51单片机指令:
把10放到累 740AH 加器A中 为பைடு நூலகம்便于记忆 指令助
A加20,结 果仍在A中
整理ppt
8
指令的组成及字节数
3.三字节指令(17条)
这条指令的指令码的第1字节为操作码;第2和第3字节为 操作数或操作数地址,有如下3类。 1)16位数据 例如:MOV DPTR,#26ABH 指令码为:
整理ppt
9
指令的组成及字节数
2)8位地址和8位数据 例如:MOV 74H,#0FFH 指令码为:
在MCS-51指令中,若操作数是以R0~R7来表示操作数时, 就属于寄存器寻址方式。

MCS51单片机指令系统

MCS51单片机指令系统

第一条指令为远查表指令,可以在64K的程序存储器空间寻 址。基地址寄存器为DPTR,其意思为,DPTR里面存放的是 程序存储器中数据表格的首地址,A为数据地址的偏移量。
这条指令执行以后,以 (A)+(DPTR)的数值为地址数 据就送进A里面来了,也就是从表格首地址开始以后的第(A) 个数据被送进A了。(举例子说明)
编写好的程序都放在程序存储器中,由于一个存储地址所 指示的存储单元只能存放一字节的数据。所以,在存放指令时, 必须将指令拆分成一个一个字节进行连续存放。
比如: 实现“累加器加10H”这条指令,其机器语言为 0111010000010000, 占用了两个字节,就必须拆成两个字节 进行连续存储。
但是,用二进制来表示比较麻烦,因此,也常用十六进制来 表示如:74H 10H来表示以上这条机器语言。可见,用十六进 制表示指令比较简单,但是,指令系统有上百条指令,不易记 住。所以,一般采用容易记住的一些缩写符号来表示机器语言,
2. 在指令中直接给出操作数的地址, 这种寻址方式就属
于直接寻址方式。在这种方式中, 指令的操作数部分直接 是操作数的地址。
比如:MOV A,30H;将30H里面的数送到A里面 MOV 21H,30H;将30H里面的数存放到21H里面 在MCS -51 单片机指令系统中, 直接寻址方式中可
以访问 3 种存储器空间: (1) 内部数据存储器的低 128 个字节单元(00H~
7. 位寻址 指按照位进行的寻址操作,(前面讲的都是按字节进
行的寻址操作)。该种寻址方式中, 操作数是内部RAM单元 中20H到2FH的128个位地址以及SFR中的11个可进行 位寻址的寄存器中的位地址寻址。
比如:MOV C,20H;就是将RAM中位寻址区中20H位地 址中的内容送给C。区别与MOV A,20H;这个是将内部 RAM中20H单元的内容送给A。

大学课件MCS51单片机指令系统与汇编语言程序设计

大学课件MCS51单片机指令系统与汇编语言程序设计

ANL C, P ; (C)← (C)∧(P)
其中:P是PSW的第0位,C是PSW的第7位。
(4)字节符号地址(字节名称)加位序号的形式。对于部分特 殊功能寄存器(如状态标志寄存器PSW),还可以用其字节名 称加位序号形式来访问某一位。AC 如:
定义:操作数存放在MCS-51内部的某个工作寄存器Rn (R0~R7)或部分专用寄存器中,这种寻址方式称为 寄存器寻址。
特点:由指令指出某一个寄存器的内容作为操作数。 存放操作数的寄存器在指令代码中不占据单独的一个 字节,而是嵌入(隐含)到操作码字节中。
寻址范围:四组通用寄存器Rn(R0~R7)、部分专用 寄存器( A, B, DPTR, Cy )。
伪指令只出现在汇编前的源程序中,仅提供汇编用的某些控制 信息,不产生可执行的目标代码,是CPU不能执行的指令。
(1)定位伪指令ORG
格式:ORG n
其中:n通常为绝对地址,可以是十六进制数、标号或表达式。
功能:规定编译后的机器代码存放的起始位置。在一个汇编 语言源程序中允许存在多条定位伪指令,但每一个n值都应和前
2.2.2 直接寻址
定义:将操作数的地址直接存放在指令中,这种寻址方式称为 直接寻址。 特点:指令中含有操作数的地址。该地址指出了参与操作的数 据所在的字节单元地址或位地址。计算机执行它们时便可根据 直接地址找到所需要的操作数。
寻址范围:ROM、片内RAM区、SFR和位地址空间。P42
2.2.3 寄存器寻址
定义:指令中给出的操作数是一个可单独寻址的位地址,这种寻址 方式称为位寻址方式。
特点:位寻址是直接寻址方式的一种,其特点是对8位二进制数中 的某一位的地址进行操作。
寻址范围:片内RAM低128B中位寻址区、部分SFR(其中有83位 可以位寻址)。

第3章MCS-51指令系统

第3章MCS-51指令系统

第3章 MCS-51指令系统 4. 伪指令 在汇编语言源程序中,除了包含可以转化为特定计算机系 统的机器语言指令所对应的汇编语言指令外,还可能包含一些 伪指令,如“ORG 2000H”、“END”等。“伪”者,假也,尽 尽 管它不是计算机系统对应的指令,汇编时也不产生机器码,但 管它不是计算机系统对应的指令,汇编时也不产生机器码, 汇编语言程序中的伪指令并非可有可无。伪指令的作用是指导 汇编语言程序中的伪指令并非可有可无。 源程序的汇编过程, 源程序的汇编过程,例如“ORG 2000H”伪指令,指示汇编程序 将该伪指令后的汇编语言指令对应的机器码从2000H单元开始存 放。
第3章 MCS-51指令系统
· 52/54子系列内部RAM后128字节(即地址编码为80~FFH) 各单元之间不能直接传送。原因是高128字节内部RAM只能使 用寄存器间接寻址方式,而一条指令中,最多只允许一个操作 数使用寄存器间接寻址方式。 数据传送指令一般不会影响程序状态字寄存器PSW中的标 志位,但当数据传送到累加器A时,PSW中的奇偶标志位P会改 变,原因是奇偶标志位P总是体现累加器A中“1”的个数的奇偶 性。
第3章 MCS-51指令系统 1. 内部 内部RAM与特殊功能寄存器之间的数据传送 与特殊功能寄存器之间的数据传送 表3-1 内部RAM与特殊功能寄存器之间的数据传送指令
指令名称 指令格式 MOV A,Rn 以累加器A作为 目的操作数 MOV A,direct MOV A,@Ri MOV A,#data 机器码 11101rrr 11100101 direct 1110011i 01110100 data 功能 A←Rn A←(direct) A←(Ri) A←data 指令周期 1 1 1 1
MOV 90H,0F0H ; 将特殊功能寄存器0F0H单元(即寄存器B) 内容传送到特殊功能寄存器90H ; 单元(即P1口锁存器)中

MCS-51指令系统入门

MCS-51指令系统入门
/ # @ $ ← ∧ ∨ ⊕ @DPTR
含义 X的内容 以X的内容为地址的内容 加在位地址之前,表示对该位取反 立即数前缀 间址寄存器前缀 程序计数器PC的当前值 箭头右面的数据传送到箭头左面 逻辑与运算 逻辑或运算 逻辑异或运算 16位片外数据指针,范围为0000H~FFFFH
—6—
four
指令分类
指令格式 two
—4—
MCS-51系列单片机指令中常用助记符及含义
符号 A
累加器ACC
含义
B
寄存器B
Ri
寄存器间接寻址的寄存器(i=0或1)
Rn
当前工作寄存器R0~R7的一个
bit
具有位寻址功能的位地址
rel
用补码形式表示的偏移量,范围为 -128~ƐH~FFH
—3—
在MCS-51系统中采用变长指令,对于不同类型的指令,或
者相同指令的操作数类型不同,其长度是可变的,因此,MCS-51 指令为变长指令。大部分指令的长度为1~3个字节。
提示
对于双操作数指令来说,一般操作数1是目的操作数,操作数2是源操作数。 采用RISC的单片机,每条指令的长度相同,如ARM芯片全部指令都是32位的。
—9—
1)立即寻址
立即寻址是指在指令中直接给出参加运算的操作数的寻址方式。这种形式的操作数称为立即数。为了与 直接寻址指令中的直接地址相区别,立即数前面要加“#”标志。
【例3-1】 立即寻址方式如表所示:
编号
汇编语言指令
a
MOV A,#40H
b
MOV DPTR,#4000H
机器语言 7440H 904000H
机器语言 E560H E588H E588H
机器语言
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
20
图3-1 寄存器寻址示意图
第3章 MCS-51指令系统
说明: (1)寄存器寻址方式可以用在目的操作数中,也可以用
在源操作数中。
( 2 )寄存器寻址的主要对象是通用寄存器,共有 4 组通
用寄存器,但寄存器寻址只能使用当前寄存器组。因此指令
中的寄存器名称只能是R0~R7。 ( 3)寄存器寻址还包括部分专用寄存器 SFR,如累加器 A、寄存器B(但仅限于乘法指令)、地址寄存器DPTR。
29
第3章 MCS-51指令系统
存储单元 内容 地址编码 … PC PC+1 74 23 … 1 FFF 2 00 0 2 00 1 2 00 2
累加器A 23
图3-4 立即寻址示意图
30
第3章 MCS-51指令系统
说明:立即数长度必须小于或等于目的操作数的长度。 在上例中,如果累加器A字长为8位,则不能将16位二进制数
7
第3章 MCS-51指令系统
2)指令:指令分为两类——执行指令和伪指令。
• 执行指令是计算机指令系统给出的各种指令。已在前 一章介绍过,即由“操作码”和“操作数”组成。 • 伪指令是由汇编程序规定,仅在机器汇编时供汇编程 序识别和执行,用来对汇编过程进行控制和操作,并不 产生供机器直接执行的机器码,也不会直接影响存储器 中代码和数据的分布。
4
第3章 MCS-51指令系统
5
第3章 MCS-51指令系统

6
第3章 MCS-51指令系统
二、汇编语言的格式
标号: 指令 ;注释
1)标号:是用户设定的一个符号,表示存放指令或数 据的存储单元地址。 • 标号是由字母开始的1~8个字母或数字串组成。 • 标号后面必须紧跟冒号“ :”,作为标号的结束。 • 一个标号只能表示一个地址,不允许多个地址使用同一 个标号。
MOVC A, @A+PC
JMP @A+DPTR
33
第3章 MCS-51指令系统
3.2.6 位寻址
位寻址方式是单片机系统特有的一种寻址方式。位寻址指 令中可以直接使用位地址。例如: MOV C, 23H 23H ; 指令中的“C”是进位标志Cy的简称,
是位寻址空间内的位地址
MOV C, ACC.7 ;SFR中的位既可以使用位地址也可以使 用符号+位序号
操作数DPTR同样隐藏在了操作码中
16
第3章 MCS-51指令系统
2)8位地址和8位数据 例如:MOV 74H,#0FFH 指令码为:
3)16位地址 例如:LCALL 2020H 指令码为:
在程序设计中,应尽可能选用字节少的指令。这样,指令所占存 储单元少,执行速度也快。 17
第3章 MCS-51指令系统
第3章 MCS-51指令系统
DPTR —— 16位外部数据指针寄存器。 bit —— 内部RAM中的可直接寻址位。 A —— 累加器。 ACC —— 直接寻址方式的累加器。 B —— 寄存器B。 C —— 进、借位标志位,是布尔处理机的累加器,也称 之为位累加器。 @ —— 间接寄存器前缀标志。 / —— 加在位地址前面,表示对该位状态求反。 (x) —— x中的内容。 ((x)) —— x中的地址中的内容。 $—— 当前指令存放的地址 。
第3章 MCS-51指令系统
本章重点
• 寻址方式 • 数据传送类指令 • 算术运算类指令 • 逻辑运算类指令 • 位操作指令
• 控制转移类指令
课时安排:10个课时
1
第3章 MCS-51指令系统
第3章 MCS-51指令系统
3.1 指令系统简介 3.2 寻址方式 3.3 数据传送指令 3.4 算术运算指令 3.5 逻辑运算指令
18
第3章 MCS-51指令系统
3.2 寻址方式
3.2.1 寄存器寻址 3.2.2 直接寻址 3.2.3 寄存器间接寻址 3.2.4 立即寻址 3.2.5 变址寻址 3.2.6 位寻址 3.2.7 相对寻址 3.2.8 各种寻址方式小结 思考题
19
第3章 MCS-51指令系统
3.2.1 寄存器寻址
34
第3章 MCS-51指令系统
位寻址的寻址范围: ( 1 )内部 RAM 中的位寻址区( 20H ~ 2FH )。位寻址 区中的位有两种表示方法,一种是位地址;一种是单元地址 加位。 (2)专用寄存器SFR的可寻址位。
9
第3章 MCS-51指令系统
3 )注释:只是对程序的说明,注释信息和程 序一起存储、打印,但汇编时不被翻译,不会出现 在机器代码的目标程序中,也不影响程序的执行。
注释必须以分号“ ;”开始,注释信息占用
多行时,每行都必须以“ ;”开始。
10
第3章 MCS-51指令系统
三、指令中操作数的描述符号
23
第3章 MCS-51指令系统
24
第3章 MCS-51指令系统
25
第3章 MCS-51指令系统
重要
ACC与A的区别: ACC表示的是累加器的直接地址E0H (直接寻址) A表示的累加器这样一个寄存器的内容 (寄存器寻址)
26
第3章 MCS-51指令系统
3.2.3 寄存器间接寻址
寄存器间接寻址方式中,寄存器中存放的是操作数的地 址,即操作数是通过寄存器间接得到的。例如: MOV A, @R0
传送到累加器A中,即如下指令在汇编时将出错:
MOV A, #1234H ;由于累加器A长度只有8位, 无法装入16位二进制数1234H
但立即数长度可以小于目的操作数长度,例如: MOV DPTR, #02H MOV DPTR, #2H
31
第3章 MCS-51指令系统
3.2.5 变址寻址
变址寻址方式是为了访问ROM中的数据表格。以DPTR 或PC作基址寄存器,以累加器A作变址寄存器,然后以两者 内容相加形成的16位地址作为操作数地址,达到访问数据表 格的目的。例如:MOVC A, @A+DPTR
21
第3章 MCS-51指令系统
3.2.2 直接寻址
指令中操作数直接以单元地址的形式给出,就称之为直接 寻址。例如:MOV A, 23H
存储单元 内容 地址编码
55 … PC PC+1 PC+1 E5 23 00 …
0 02 3 1 FFF 2 00 0 2 00 1 2 00 2 55 累加器A
程序存储器 2040 93 ACC (47)E0 DPH DPL 20 00
. . .
20E0
. . .
47
ALU
图3-5 变址寻址示意图
32
第3章 MCS-51指令系统
说明: (1)变址寻址方式只能对 ROM进行寻址,或者说它是 专门针对ROM的寻址方式,寻址范围可达64KB。
(2)变址寻址指令只有3条: MOVC A, @A+DPTR
图3-2 直接寻址示意图 22
第3章 MCS-51指令系统
说明:直接寻址方式只能使用 8 位二进制数表示的地址, 因此这种寻址方式的寻址范围只限于内部RAM区。即:
( 1 )低 128 字节。在指令中直接以单元地址的形式给出。
(2)专用寄存器区。可以以单元地址的形式给出,也可 以以寄存器符号形式给出(对 SFR 来说,地址一定、符号一 定,寄存器符号等同于寄存器直接地址,这时程序编译是就 确定下来的)。
程序存储器
片内RAM区
片内RAM区
2030
E6
(R0) 00
50
50
4A
ACC
4A
27
图3-3 寄存器间接寻址示意图
第3章 MCS-51指令系统
寄存器间接寻址方式的寻址范围是: ( 1 )内部 RAM 的低 128 字节。此时只能使用 R0 或 R1 作 间址寄存器,其通用形式为@Ri。 (2)外部RAM的64KB范围。此时一般使用DPTR作间址 寄存器,其形式为@DPTR。 如: MOVX A, @DPTR (3)外部RAM的低256字节。此时使用R0或R1作间址寄 存器。 如: MOVX A, @R0。(有什么问题?) ( 4 )堆栈操作指令( PUSH 和 POP )也应算作是寄存器 间接寻址,即以SP作间址寄存器的间接寻址方式。
Rn —— 当前寄存器组的8个通用寄存器R0 ~ R7。 Ri —— 可用作间接寻址的寄存器,只能是R0、R1。 Direct —— 8位直接地址,在指令中表示直接寻址方式,寻 址包括片内低128B RAM单元地址、以及高128B RAM区中的26个SFR地址。 #data —— 8位立即数。 #data 16 —— 16位立即数。 addr 16—— 16位目的地址,只限于在LCALL和LJMP指令中 使用。 addr 11 —— 11位目的地址,只限于在ACALL和AJMP指令中 使用。 11 rel —— 8位带符号补码数,作为转移指令中的偏移量。
这条8位数传送指令的含义是把指令码第2字节立即数 23H取出来存放到累加器(A)中。该指令的操作码 占1B;23H为源操作数,也是1B;累加器(A)是目 的操作数寄存器,隐含在操作码字段中。
15
第3章 MCS-51指令系统
3.三字节指令(17条)
这条指令的指令码的第1字节为操作码;第2和第3字 节为操作数或操作数地址,有如下3类。 1)16位数据 例如:MOV DPTR,#26ABH 指令码为:
13
第3章 MCS-51指令系统
2)含有操作数寄存器号的单字节指令 单字节的指令码由操作码字段和指示操作 数所 在寄存器号的字段组成。 例如;MOV A,Rn 指令码为:
其中,rrr为寄存器Rn的编号
14
第3章 MCS-51指令系统
2.双字节指令(45条)
双字节指令的操作码字节在前;在后面的操作数字节 可以是立即数,也可以是操作数所在的片内RAM地址。 例如:MOV A,#23H 指令码为:
相关文档
最新文档