单片机指令系统
第三章MCS51系列单片机指令系统及汇编语言程序设计

SJMP rel ;PC+ 2 + rel→PC 短转移指令为一页地址范围内的相对转移指令。因为rel为1字节补码 偏移量,且SJMP rel指令为2字节指令,所以转移范围为-126D~+ 129D 【4】间接转移指令
表3.4 程序存储器空间中的32个基本2K地址范围
0000H~07FFH 0800H~0FFFH 1000H~17FFH 1800H~1FFFH 2000H~27FFH 2800H~2FFFH 3000H~37FFH 3800H~3FFFH 4000H~47FFH 4800H~4FFFH 5000H~57FFH
3. 寄存器寻址
以通用寄存器的内容为操作数的寻址方式。通用寄存 器包括:A,B,DPTR,R0~R7。其中,R0~R7必须在 工作寄存器组之中。
例如:INC R0 ;(R0)+1→R0
需要注意的是,A和B既是通用寄存器,又是具有直 接地址的特殊功能寄存器。
4. 寄存器间接寻址
以寄存器中的内容为地址,该地址中的内容为操作数的寻址方式。能够 用于寄存器间接寻址的寄存器有:R0,R1,DPTR,SP。其中,R0,R1必 须在工作寄存器组之中,SP仅用于堆栈操作。
MCS-51单片机共有111条指令,按功能分类, MCS-51指令系统可分为5大类:
➢ 数据传送类指令(共29条) ➢ 算术操作类指令(共24条) ➢ 逻辑操作类指令(共24条) ➢ 控制转移类指令(共17条) ➢ 布尔变量操作类指令(共17条)
1.数据传送类指令(共29条)
以累加器A为目的操作数类指令(4条)
8051单片机3单片机指令系统

(1) 方括号[ ]表示该项是可选项, 可有可无。 (2) 标号是用户设定的符号, 它实际代表该指令所在的地址。 标号必须以字母开头, 其后跟1~8个字母或数字, 并以“:”结 尾。 (3) 操作码是用英文缩写的指令功能助记符。它确定了本条指 令完成什么样的操作功能。如: ADD表示加法操作。任何一 条指令都必须有该助记符项, 不得省略。 (4) 操作数指的是指令操作的数据. 可以是一个数,也可以是寄 存器和特殊功能寄存器,还可以是标号地址;个数可以为0, 3 也可以为1,2,3
23
3.4.1 数据传送类指令
3.4.1 数据传送类指令
数据传送类指令共29条, 它是指令系统中最活跃、 使 用最多的一类指令。一般的操作是把源操作数传送到目的操 作数, 即指令执行后目的操作数改为源操作数, 而源操作数保 持不变 数据传送类指令不影响进位标志CY、 半进位标志AC 和溢出标志OV, 但当传送或交换数据后影响累加器A的值时, 奇偶标志P的值则按A的值重新设定。 按数据传送类指令的操作方式,又可把传送类指令分 为3种类型: 数据传送、数据交换和堆栈操作, 并使用8种助记 符: MOV、MOVX、MOVC、XCH、XCHD、SWAP、 PUSH及POP 24
3.4.1 数据传送类指令
25
3.4.1 数据传送类指令
1. 内部数据存储器间数据传送指令
内部RAM区是数据传送最活跃的区域, 可用的指令数也最 多, 共有16条指令, 指令操作码助记符为MOV,通用格式为: MOV 目的操作数 , 源操作数 内部RAM之间源操作数传递关系如下图所示
26
3.4.1 数据传送类指令
4
3.1 指令格式
指令描述符号:
在分类介绍各类指令之前, 先对描述指令的一些 符号意义进行一些简单约定:
单片机指令系统及其执行过程的详解

单片机指令系统及其执行过程的详解单片机是现代电子设备中不可或缺的组成部分,其指令系统和执行过程对于单片机的工作和性能起着至关重要的作用。
本文将详细介绍单片机指令系统的组成和执行过程,并探讨其在实际应用中的意义。
一、单片机指令系统的组成单片机的指令系统由指令集、寄存器和地址计算单元组成。
1. 指令集指令集是单片机能够执行的所有指令的集合。
它包含了各种不同类型的指令,如算术指令、逻辑指令、数据传输指令等。
不同的单片机具有不同的指令集,但通常都包括基本的算术和逻辑运算指令,以及控制流指令(如条件分支和循环)。
2. 寄存器寄存器是单片机内部用于存储数据和执行运算的存储器组件。
常见的寄存器包括通用寄存器、标志寄存器、程序计数器等。
通用寄存器用于存储临时数据,标志寄存器用于存储运算结果的状态信息,程序计数器用于存储当前正在执行的指令地址。
3. 地址计算单元地址计算单元用于计算指令中的操作数的地址。
它根据指令中的寻址方式和地址模式,将指令中的操作数地址计算出来,并将其传递给存储器或寄存器。
二、单片机指令执行过程单片机的指令执行过程包括指令取指、指令译码和指令执行三个阶段。
1. 指令取指在指令取指阶段,程序计数器(PC)从存储器中读取下一条指令的地址,并将其存储在指令寄存器(IR)中。
同时,PC的值自动递增,准备读取下一条指令。
2. 指令译码在指令译码阶段,单片机将指令寄存器中的指令译码为对应的操作。
根据指令的类型和操作码,单片机确定需要执行的具体操作,如运算、数据传输或控制流操作。
3. 指令执行在指令执行阶段,单片机根据译码结果执行具体的操作。
这包括算术和逻辑运算、数据传输等。
执行结果可以存储在寄存器中,也可以写入存储器。
同时,单片机还会根据程序的控制流进行条件分支或循环。
三、单片机指令系统的应用意义单片机指令系统的优化对于提高单片机的执行效率和性能至关重要。
通过合理设计指令集,可以充分发挥单片机的计算和控制能力,提高其运算速度和响应能力。
第9章 单片机的指令系统说明

计算机总是把操作数当作有符号数(补码形式)看待 并影响PSW的相关标志位。影响情况如下: 进位/借位标志CY: 两数和的D7位有进位时,(CY)=1,否则,(CY)=0。 半进位/借位标志AC: 两数和的D3位有进位时,(AC)=1,否则,(AC)=0。 溢出标志OV: 两数和的D7,D6位只有一位有进位时,(OV)=1;否则, (OV)=0,即OV=C6⊕C7。 奇偶标志P: 当累加器A中“1”的个数为奇数时,(P)=1;为偶数 时(P)=0。
例2 把片外RAM的36H单元中的数据送到片外RAM的 1200H单元。 〈分析〉(36H)→(1200H) 程序如下: MOV R1,#36H MOVX A ,@R1 MOV DPTR,#1200H MOVX @DPTR, A <想一想>下面的程序可以实现吗? MOV DPTR, #1200H MOV R1,#36H MOV @DPTR,@R1 注意:片外RAM之间不能直接传送数据,必须经过累加器 A
例5 试分析8051单片机执行下述指令后,累加器A和PSW各标 志位的变化。 MOV A,#0A5H ADD A,#0CFH 解: (A)=10100101B + Data=11001111B CY 01110100B C7 C6 AC (CY)=C7=1;(AC)=1;溢出标志(OV)=C7⊕C6=1⊕0=1,有 溢出;(P)=0。执行结果:(A)=74H。 若为无符号数运算, (CY)=1,表示结果超出(0~255) 范围。若为带符号数运算,因(-49)+(-91)=-140,超出了 (-128~+127)的范围,所以OV=1溢出。
半字节交换 XCHD A,@Ri SWAP A
;(A3~0)((Ri)3~0) ;(A3~0)(A7~4)
第3章MCS1的指令系统

7.位寻址
3.4
MCS-51指令系统分类介绍
MCS-51 的指令系统,共有 111 条指令,按功能分类, 可分为下面5大类: (1)数据传送类(28条) (2)算术操作类(24条 (3)逻辑运算类(25条)
(4)控制转移类(17条)
(5)位操作类(17条)
26
3.4
MCS-51指令系统分类介绍
程序存储器 DPTR
2000H A
2010H 64H 64H(10H) 10H
2000H
变址寻址示意图
18
5.基址寄存器加变址寄存器间址寻址方式(变址寻址) 说明: (1)本寻址方式是专门针对程序存储器的寻址方式,寻址范围 可达到64KB。 (2)本寻址方式的指令只有3条: MOVC A,@A+DPTR
8
3.3
1.寄存器寻址方式
指令系统的寻址方式
以通用寄存器的内容为操作数的寻址方式。 通用寄存器指A、B 、DPTR以及R0~R7 。 寄存器寻址就是从寄存器中读取操作数或存放操作数进寄存
器。
MOV A,Rn ;(Rn)→A,n=0~7 表示把寄存器Rn的内容传送给累加器A 寻址范围: (1)4组通用工作寄存区共32个工作寄存器。 (2)部分特殊功能寄存器,例如A、B 以及数据指针寄存器 DPTR等。
在相对寻址的转移指令中,给出了地址偏移量,以“rel” 表示,即把 PC 的当前值加上偏移量就构成了程序转移的目的
地址:
目的地址=转移指令所在的地址 + 转移指令的字节数 + rel 偏移量rel是一带符号的8位二进制数补码数。 范围是:–128 - +127 向地址增加方向最大可转移(127+转移指令字节)个单元
MCS-51单片机指令系统

6、堆栈操作指令
进栈 【PUSH direct;(SP)+1→SP,(dirsct)→(SP)】 出栈 【POP direct;(SP)→(dirsct),(SP)-1→SP】
MCS-51指令系统中有两条读程序存储器中表格数据的指令。 因为对程序存储器只能读不能写,所以查表指令数据传送都是单向的, 即从程序存储器到累加器中。
SETB C;1→C置一
3、位逻辑运算指令
ANL C,bit;C)∧(bit)→C
ORL C,/bit;(C)∨(~bit)→C
“ / “表示取反
JB bit,re1;若(bit)=1,则(PC)+rel→PC;否则,(PC)+3→PC
4、位条件转移指令
JNB bit,re1;若(bit)=0,则(PC)+rel→PC;否则,(PC)+3→PC
1、逻辑与指令【ANL A,#data;(A)∧data→A 】
2、逻辑或指令【ORL A,#data;(A)∨data→A】
3、逻辑异或指令【XRL A,#data;(A)⊕data→A】
4、累加器A清零指令【CLA A;0→A 】
5、累加器A取反指令【CPL A; ̅A→A】
RL A;左循环移位指令
2、以Rn为目的操作数的指令 【MOV Rn, #data;data→Rn】 (源操作数:累加器A、片内RAM单元、SFR内容,立即数) 传送到当前工作寄存器组R0~R7的某个寄存器
3、以直接地址为目的操作数的指令 【MOV direct, #data;data→direct】 (源操作数:累加器、片内RAM单元、工作寄存器,立即数) 传送到由direct所指的片内存储单元
返回指令
单片机原理与应用第3章8051单片机指令系统

80H SJMP 38H
38H 1832H+2
(1832H)
186CH
1834H 186CH
7.位寻址
对片内RAM中20H~2FH中的128个位地址及SFR中的 可位寻址的位地址寻址。
例如: MOV C,20H;20H位即24H.0的内容送CY标志 位,C称为位累加器。 MOV A,20H ;字节寻址,将内部 RAM中20H单 以上两条指令均为直接寻址,究竟是位寻址还是字节寻 址,根据两操作数类型一致的原则,由另一个操作数决定。 例如, MOV ACC.7, C
• • • • •
指令分类 数据传送指令(29条) 算术运算指令(24条) 逻辑运算和移位指令(24条) 位操作指令 (17条) 控制转移指令(17条) 共111条
3.2 寻址方式
指令中操作数提供的方式称为寻址方式。
指令符号约定
符号 Rn Ri #data addr16 addr11 direct rel 含 义
3.直接寻址: 操作数的地址直接出现在指令中。
寻址对象:①内部数据存贮器:使用它的地址 ②特殊功能 寄存器:既可使用它的地址,也可以 直接使用寄存器名。 例:MOV A,40H ; A=56H 机器码 E540H
41H 40H
78H 56H
MOV 40H,41H ; 机器码为854140H 内部RAM (41H)→(40H) 41H (40H)=(41H)=78H 40H MOV P0,#45H ;45H→P0, P0为直接寻址的 SFR,其地址为 80H, 机器码为758045H
操作数存放在寄存器中。 寻址对象:A,B,DPTR,R0~R7 。 B 仅在乘除法指令中为寄存器寻址,在其他指令中为直 接寻址。 A 可以寄存器寻址又可以直接寻址,直接寻址时写作ACC。
单片机第4章8051单片机指令系统

单片机第4章8051单片机指令系统在单片机的世界里,指令系统就如同指挥官手中的指令手册,指引着单片机完成各种复杂的任务。
8051 单片机的指令系统更是其中的重要组成部分,它为我们提供了丰富多样的指令,让我们能够灵活地控制单片机的运行。
8051 单片机的指令系统可以分为五大类,分别是数据传送指令、算术运算指令、逻辑运算指令、控制转移指令和位操作指令。
数据传送指令是指令系统中的基础,就像是在战场上调配物资一样。
它能够实现寄存器之间、寄存器与存储器之间、立即数与寄存器或存储器之间的数据传递。
比如 MOV 指令,它可以将一个数据从源地址传送到目的地址。
假设我们要将立即数 50H 传送到累加器 A 中,就可以使用指令“MOV A, 50H”。
这样,累加器 A 就存储了 50H 这个数值。
算术运算指令则像是在进行战斗中的兵力计算。
它包括加法、减法、乘法和除法等运算。
ADD 指令用于加法运算,SUBB 指令用于带借位的减法运算。
例如,我们要将累加器 A 中的值与寄存器 B 中的值相加,并将结果存放在累加器 A 中,就可以使用指令“ADD A, B”。
如果要进行带借位的减法运算,比如从累加器 A 中减去寄存器 B 中的值以及借位标志位 CY 的值,可以使用指令“SUBB A, B”。
逻辑运算指令就像是在制定战略时的思考逻辑。
AND 指令用于逻辑与操作,ORL 指令用于逻辑或操作,XRL 指令用于逻辑异或操作。
以 AND 指令为例,如果我们要将累加器 A 中的值与立即数 80H 进行逻辑与操作,并将结果存放在累加器 A 中,就可以使用指令“AND A, 80H”。
控制转移指令则是指挥战斗中的战略部署调整。
它可以改变程序的执行顺序,使单片机能够根据不同的条件执行不同的程序段。
比如 JZ 指令,如果累加器 A 的值为 0,则程序跳转到指定的地址;JC 指令,如果进位标志位 CY 为 1,则程序跳转到指定的地址。
位操作指令则专注于对单个位的操作,就像是在精细地调整战斗中的某个关键环节。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
• 3.1 MCS-51指令系统的分 类、格式及一般说明
• 3.2 寻址方式
单片机指令系统
学习目的及要求
• 熟悉指令、指令系统、机器语言、及汇 编语言的概念;
• 熟悉8051汇编语言指令的格式; • 掌握8051的七种寻址方式,并能实际
应用;
单片机指令系统
MCS-51单片机指令系统有如 (1)指令执行下时特间快点。:
返回本章首页
3.1.1 指令分类
• 按指令功能,MCS-51指令系统分为数 据传递与交换、算术运算、逻辑运算、 程序转移、布尔处理操作、CPU控制等 6类。
• 布尔处理操作类指令又称位操作指令。
单片机指令系统
返回本节
3.1.2 指令格式
• 在MCS-51指令中,一般指令主要由操作码、操作数 组成。
• 相对寻址用于修改PC值,主要用于实 现程序的分支转移。
例 如 , SJMP 08H
;
PC←PC+2+08H
指令操作示意图如图3-5所H SJMP 08H 08H
200AH
2000H+2
PC
(2000H) 200AH
图3-5 相对寻址示意图
单片机指令系统
返回本节
(2)指令短,约有一半的指令为单字节 指令。
(3)用一条指令即可实现2个一字节的 相乘或相除。
(4)具有丰富的位操作指令。 (5)可直接用传送指令实现端口的输入
输出操作。
单片机指令系统
3.1 MCS-51指令系统的分类、格式及一般说明
• 3.1.1 指令分类 • 3.1.2 指令格式
单片机指令系统
例如:MOV A,# 60H;A←60H
MOV DPTR,# 3400H;DPTR←3400H
MOV
30H,# 40H ;30H单元←40H
• 上述三条指令执行完后,累加器A中数据为立即数据 60H,DPTR寄存器中数据为3400H,30H单元中数 据为立即数40H。
单片机指令系统
返回本节
3.2.2 直接寻址
指令格式为:操作码 [目的操作数][,源操作数] • 指令应具有以下功能: (1)操作码指明执行什么性质和类型的操作。例如,
数的传送、加法、减法等。
(2)操作数指明操作的数本身或者是操作数所在的地 址。
(3)指定操作结果存放的地址。
单片机指令系统
返回本节
8051指令系统中,有单字节、双字节或三字节指令 1.单字节指令:单字节指令中的8位二进制代码既包含操
• 3.2.1 立即寻址 • 3.2.2 直接寻址 • 3.2.3 寄存器寻址 • 3.2.4 寄存器间接寻址 • 3.2.5 变址寻址 • 3.2.6 相对寻址 • 3.2.7 位寻址 • 3.2.8 寻址空间及符号注释
单片机指令系统
返回本章首页
3.2.1 立即数寻址
• 指令中直接给出操作数的寻址方式。立即操作数用前 面加有#号的8位或16位数来表示。
返回本节
3.2.3 寄存器寻址
• 以通用寄存器的内容为操作数的寻址方 式。通用寄存器指A、B 、DPTR以及 R0~R7 。 例如:MOV A,R0;A ←(R0) CLR A ;A←0 INC DPTR;DPTR←DPTR+1 ADD A,R5;A←(A)+(R5)
单片机指令系统
返回本节
3.2.4 寄存器间接寻址
作码的信息,又包含操作数的信息。共49条。
2 .双字节指令:用一个字节表示操作码,另一个字节表 示操作数或操作数所在的地址。共有45条。
3.三字节指令:一个字节操作码,两个字节操作数。共 有17条。
8051单片机共有111条指令。
单片机指令系统
3.2 寻址方式
• 寻址方式:就是寻找指令中操作数或操作数所在地址的方法。 8051共有七中寻址方式。
又如:MOVX @DPTR,A; 外部RAM (DPTR)←A
其 指 令 操 作 过 程 示 意 图 如 图 3- 2 所示。
单片机指令系统
R0
30H
A
34H
片内RAM
30H
34H
图3-1 MOV @R0,A间接寻址示意
图
单片机指令系统
片外RAM
DPTR 2000H
A 30H
2000H
30H
图3-2 MOVX @DPTR,A 间接寻址示意图
• 以寄存器中内容为地址,以该地址中内 容为操作数的寻址方式。间接寻址的存 储 器 空 间 包 括 内 部 数 据 RAM 和 外 部 数 据RAM。
• 能用于寄存器间接寻址的寄存器有R0, R1,DPTR,SP。其中R0、R1必须是 工作寄存器组中的寄存器。SP仅用于堆 栈操作。
单片机指令系统
例 如 : MOV @R0 , A ; 内 部 RAM(R0)←A 其指令操作过程示意图如图3-1所 示。
• 指令中直接给出操作数地址的寻址方式, 能进行直接寻址的存储空间有SFR寄存 器和片内RAM的128个单元。
例如:MOV
A,P1; A←(P1)
把SFR中P1口的内容送A。
MOV A,30H ;A←(30H)
注意解释字段中加括号和不加括号的区 别!
• 30H为直接给出的内部RAM的地址。
单片机指令系统
A←(A+DPTR) 又 如:MOVC A,@ A+PC ;
A←(A+PC) 这种寻址方式多用于查表操作。
单片机指令系统
程序存储器 2010H 64H
A 10H
64H(10H)
DPTR 2000H 2000H
图3-4 变址寻址示意图
单片机指令系统
返回本节
3.2.6 相对寻址
• 以当前程序计数器PC的内容为基础, 加上指令给出的一字节补码数(偏移量) 形成新的PC值的寻址方式。
单片机指令系统
返回本节
3.2.5 变址寻址
是基址寄存器(A)+变址寄存器(PC或DPTR) 的间接寻址。变址寻址只能对程序存储器中数据进行 操作。由于程序存储器是只读的,因此变址寻址只有 读操作而无写操作,在指令符号上采用MOVC的形 式(如图3-4所示)。 例如:MOVC A,@ A+DPTR;
3.2.7 位寻址
• 位寻址只能对有位地址的单元作位寻址
操作。
• 位寻址其实是一种直接寻址方式,不过 其地址是位地址。
例如:SETB 10H 1。
;将10H位置
若22H单元中存放着数据40H,22H
单元的 D0位的位地址为10H,执行上 述指令后
(22H)=4单1片H机指。令系统
返回本节
3.2.8 寻址空间及符 号注释 1.寻址空间:每种寻址方式可涉及的存储器空间