8051单片机汇编指令集
第3章80C51的指令系统

另一类直接寻 址是转移目标地 址的寻址。如: LJMP ADDR16
操作数 在50H单元
50H
3AH
E5H 50H
MOV A,50H
RAM
3AH
ACC
ROM
SFR
2021/6/23
15
❖ 定义:将操作数的地址直接存放在指令中,这种 寻址方式称为直接寻址。
❖ 特点:指令中含有操作数的地址。该地址指出了 参与操作的数据所在的字节单元地址或位地址。 计算机执行它们时便可根据直接地址找到所需要 的操作数。
第3章 80C51的指令系统
3.1 指令格式及常用符号
3.2 80C51的寻址方式
3.3 数据传送指令
(29条)
3.4 算数运算指令
(24条)
3.5 逻辑运算与循环类指令(24条)
3.6 控制转移类指令
) 3.7 位操作类指令
(17条 (17条)
2021/6/23
1
❖ 指令:CPU按照人们的意图来完成某种操作的命令。
24
❖ 定义:将程序计数器PC的当前值(取出本条指令后的PC 值)与指令第二个字节给出的偏移量(rel)相加,形成 新的转移目标地址。称为相对寻址方式。
❖ 特点:相对寻址方式是为实现程序的相对转移而设计的, 为相对转移指令所使用,其指令码中含有相对地址偏移量, 能生成浮动代码。
❖ 如: SJMP rel
寻址范围:只能对程序存储器ROM进行寻址,主要用于 查表性质的访问。
2021/6/23
22
注意:累加器A中存放的操作数地址相对基地址的 偏 移 量 的 范 围 为 00H ~ FFH ( 无 符 号 数 ) 。 MCS-51单片机共有以下三条变址寻址指令:
80C51单片机的程序设计(完整版)

第四章 80C51单片微机的程序设计 单片微机的程序设计
4.1概述 概述
4.1.1 汇编语言格式
1. 计算机语言 计算机语言——机器语言、汇编语言与高级语言 机器语言、 机器语言 程序就是为计算某一算式或完成某一工作的若干指令的有序 集合。计算机的全部工作概括起来, 集合。计算机的全部工作概括起来,就是执行这一指令序列的 过程。这一指令序列称为程序。为计算机准备这一指令前的过 过程。这一指令序列称为程序。 程称为程序设计。目前, 程称为程序设计。目前,可用于程序设计的语言基本上可分为 三种:机器语言、汇编语言和高级语言。 三种:机器语言、汇编语言和高级语言。 ⑴ 机器语言 在计算机中,所有的数符都是用二进制代码来表示的, 在计算机中,所有的数符都是用二进制代码来表示的,指令 也是用二进制代码来表示。这种用二进制代码表示的指令系统 也是用二进制代码来表示。 称为机器语言系统,简称为机器语言。 称为机器语言系统,简称为机器语言。直接用机器语言编写的 程序称为手编程序或机器语言程序。 程序称为手编程序或机器语言程序。
两种语句都由四个部分组成。其中每一部分称为域也称为字段, 两种语句都由四个部分组成。其中每一部分称为域也称为字段, 各字段之间用一个空格或字段定界符分隔, 各字段之间用一个空格或字段定界符分隔,常用的字段定界符有 冒号“ ”“逗号 逗号“ 和分号“ 冒号“:”“逗号“,”和分号“;”。其中方括号括起来的是 可选择部分。 可选择部分。
标号(也称为名字 标号 也称为名字) 域: 也称为名字 用来说明指令的地址。标号可以作为LJMP、AJMP、 用来说明指令的地址。标号可以作为 、 、 LCALL及ACALL等指令的操作数。 等指令的操作数。 及 等指令的操作数 • 在指令语句中,标号位于一个语句的开头位置,由字母和数 在指令语句中,标号位于一个语句的开头位置, 符组成, 字母打头,冒号“ 结束。 符组成 , 字母打头 , 冒号 “ : ” 结束 。 在 80C51单片微机的汇编 单片微机的汇编 语言中,标号中的字符个数一般不超过8个 若超过8个 语言中,标号中的字符个数一般不超过 个,若超过 个,则以前 面的8个为有效 后面字符不起作用。 个为有效, 面的 个为有效,后面字符不起作用。 • 不能使用本汇编语言中已经定义了的符号作标号, 不能使用本汇编语言中已经定义了的符号作标号,比如指令 助记符(如 及寄存器符号名称(如 助记符 如ADD) 、伪指令 (如END) 及寄存器符号名称 如PC) 。 如 • 一条语句可以有标号,也可以没有标号, 一条语句可以有标号,也可以没有标号,标号的有无取决于 程序中的其它语句是否需要访问该条语句。 程序中的其它语句是否需要访问该条语句。 伪指令语句与指令语句主要不同是在其名字后面没有冒号。 伪指令语句与指令语句主要不同是在其名字后面没有冒号。
C8051F单片机

5、系统复位
复位电路将控制器置于一个预定的缺省状态。 1)CIP-51 停止程序执行 2) 特殊功能寄存器(SFR)被初始化为所定义的复位值 3)外部端口引脚被置于一个已知状态 4)中断和定时器被禁止。 5)所有的SFR 都被初始化为预定值 6)I/O 端口锁存器的复位值为0xFF,全部为逻辑‘1’,内部 弱上拉有效,使外部I/O 引脚处于高电平状态。 7) MCU 使用内部振荡器运行在2MHz 作为默认的系统时钟。 8) 看门狗定时器被使能,使用其最长的超时时间。
13
1、概述
4、可编程数字I/O •C8051F310有29个I/O引脚(3个8位口和一个5位口) •C8051F31x端口的工作情况与标准8051相似,但有一些 改进。每个端口引脚都可以被配置为模拟输入或数字I/O 。 •被选择作为数字I/O的引脚还可以被配置为推挽或漏极 开路输出。 •在标准8051中固定的“弱上拉”可以被总体禁止,为低 功耗应用提供了进一步节电的能力。
18
3、优先权交叉开关配置
也称为“交叉开关”,按优先权顺序将端口0 – 3 的 引脚分配给器件上的数字外设(UART、SMBus、 PCA、定时器等)。 端口引脚的分配顺序是从P0.0 开始,可以一直分配 到P3.7。为数字外设分配端口引脚的优先权顺序为 UART0具有最高优先权,而CNVSTR具有最低优先 权。 优先权交叉开关的配置是通过3个特殊功能寄存器 XBR0、XBR1、XBR2来实现的,对应使能位被设置 为逻辑‘1’时,交叉开关将端口引脚分配给外设。
◆16K 字节可在系统编程的FLASH 存储器
◆1280字节的片内RAM ◆可寻址64K字节地址空间的外部数据存储器接口
◆硬件实现的SPI、SMBus/ I2C 和两个UART 串行接口
单片机汇编语言指令集

汇编语言的所有指令数据传送指令集MOV功能: 把源操作数送给目的操作数语法: MOV 目的操作数,源操作数格式: MOV r1,r2MOV r,mMOV m,rMOV r,dataXCHG功能: 交换两个操作数的数据语法: XCHG格式: XCHG r1,r2 XCHG m,r XCHG r,mPUSH,POP功能: 把操作数压入或取出堆栈语法: PUSH 操作数POP 操作数格式: PUSH r PUSH M PUSH data POP r POP mPUSHF,POPF,PUSHA,POPA功能: 堆栈指令群格式: PUSHF POPF PUSHA POPALEA,LDS,LES功能: 取地址至寄存器语法: LEA r,m LDS r,m LES r,mXLAT(XLATB)功能: 查表指令语法: XLAT XLAT m算数运算指令ADD,ADC功能: 加法指令语法: ADD OP1,OP2 ADC OP1,OP2格式: ADD r1,r2 ADD r,m ADD m,r ADD r,data影响标志: C,P,A,Z,S,OSUB,SBB功能:减法指令语法: SUB OP1,OP2 SBB OP1,OP2格式: SUB r1,r2 SUB r,m SUB m,r SUB r,data SUB m,data影响标志: C,P,A,Z,S,OINC,DEC功能: 把OP的值加一或减一语法: INC OP DEC OP格式: INC r/m DEC r/m影响标志: P,A,Z,S,ONEG功能: 将OP的符号反相(取二进制补码)语法: NEG OP格式: NEG r/m影响标志: C,P,A,Z,S,OMUL,IMUL功能: 乘法指令语法: MUL OP IMUL OP格式: MUL r/m IMUL r/m影响标志: C,P,A,Z,S,O(仅IMUL会影响S标志)DIV,IDIV功能:除法指令语法: DIV OP IDIV OP格式: DIV r/m IDIV r/mCBW,CWD功能: 有符号数扩展指令语法: CBW CWDAAA,AAS,AAM,AAD功能: 非压BCD码运算调整指令语法: AAA AAS AAM AAD影响标志: A,C(AAA,AAS) S,Z,P(AAM,AAD)DAA,DAS功能: 压缩BCD码调整指令语法: DAA DAS影响标志: C,P,A,Z,S位运算指令集AND,OR,XOR,NOT,TEST功能: 执行BIT与BIT之间的逻辑运算语法: AND r/m,r/m/data OR r/m,r/m/data XOR r/m,r/m/data TEST r/m,r/m/data NOT r/m 影响标志: C,O,P,Z,S(其中C与O两个标志会被设为0) NOT指令不影响任何标志位SHR,SHL,SAR,SAL功能: 移位指令语法: SHR r/m,data/CL SHL r/m,data/CL SAR r/m,data/CL SAL r/m,data/CL影响标志: C,P,Z,S,OROR,ROL,RCR,RCL功能: 循环移位指令语法: ROR r/m,data/CL ROL r/m,data/CL RCR r/m,data/CL RCL r/m,data/CL 影响标志: C,P,Z,S,O程序流程控制指令集CLC,STC,CMC功能: 设定进位标志语法: CLC STC CMC标志位: CCLD,STD功能: 设定方向标志语法: CLD STD标志位: DCLI,STI功能: 设定中断标志语法: CLI STI标志位: ICMP功能: 比较OP1与OP2的值语法: CMP r/m,r/m/data标志位: C,P,A,Z,OJMP功能: 跳往指定地址执行语法: JMP 地址JXX功能: 当特定条件成立则跳往指定地址执行语法: JXX 地址注:A: ABOVE,当C=0,Z=0时成立B: BELOW,当C=1时成立C: CARRY,当弁时成立CXZ: CX寄存器的值为0(ZERO)时成立E: EQUAL,当Z=1时成立G: GREATER(大于),当Z=0且S=0时成立L: LESS(小于),当S不为零时成立N: NOT(相反条件),需和其它符号配合使用O: OVERFLOW,O=1时成立P: PARITY,P=1时成立PE: PARITY EVEN,P=1时成立PO: PARITY ODD,P=0时成立S: SIGN,S=1时成立Z: ZERO,Z=1时成立LOOP功能: 循环指令集语法: LOOP 地址LOOPE(Z)地址LOOPNE(Z) 地址标志位: 无CALL,RET功能: 子程序调用,返回指令语法: CALL 地址RET RET n标志位: 无INT,IRET功能: 中断调用及返回指令语法: INT n IRET标志位: 在执行INT时,CPU会自动将标志寄存器的值入栈,在执行IRET时则会将堆栈中的标志值弹回寄存器字符串操作指令集MOVSB,MOVSW,MOVSD功能: 字符串传送指令语法: MOVSB MOVSW MOVSD标志位: 无CMPSB,CMPSW,CMPSD功能: 字符串比较指令语法: CMPSB CMPSW CMPSD标志位: C,P,Z,S,OSCASB,SCASW功能: 字符串搜索指令语法: SCASB SCASW标志位: C,P,Z,S,OLODSB,LODSW,STOSB,STOSW功能: 字符串载入或存贮指令语法: LODSB LODSW STOSB STOSW标志位: 无REP,REPE,REPNE功能: 重复前缀指令集语法: REP 指令S REPE 指令S REPNE 指令S标志位: 依指令S而定对于IBM PC机它有它的指令系统,其中包括:数据传送指令、串处理指令、算术指令、控制移动指令、逻辑指令、处理机控制指令。
单片机setb指令

单片机setb指令一、引言单片机是一种集成电路,它包含了处理器、存储器、输入输出接口等多种功能。
在单片机编程中,setb指令是一种常用的指令,它可以将某个IO口置高。
本文将对setb指令进行详细介绍。
二、setb指令的概述setb指令是8051系列单片机中的一个汇编指令,其功能为将某个IO 口置高。
其语法如下:setb bit其中,bit为需要置高的IO口的位地址。
三、setb指令的使用方法1. 确定需要置高的IO口在使用setb指令之前,首先需要确定需要置高的IO口。
在8051系列单片机中,每个IO口都有一个唯一的位地址。
例如P0口的位地址为80H,P1口的位地址为90H等。
2. 编写程序编写程序时,需要使用汇编语言,并在程序中调用setb指令。
以下是一个简单示例代码:MOV P0, #00H ; 将P0端口初始化为低电平SETB P0.0 ; 将P0.0端口置高END ; 程序结束以上代码中,首先将P0端口初始化为低电平,并使用SETB P0.0将P0.0端口置高。
四、setb指令与其他相关指令的比较在单片机编程中,除了setb指令外,还有其他一些相关的指令,例如clr、mov等。
下面将对这些指令进行简要比较。
1. setb与clr指令setb指令用于将某个IO口置高,而clr指令则用于将某个IO口置低。
两者功能相反,但使用方法类似。
2. setb与mov指令mov指令是单片机编程中最基本的汇编指令之一,其功能为将数据从一个寄存器或内存位置复制到另一个寄存器或内存位置。
而setb指令则只能用于IO口的置高操作。
五、setb指令的注意事项1. setb指令只能用于将某个IO口置高,不能用于将某个IO口置低。
2. 在使用setb指令之前,需要确定需要置高的IO口的位地址。
3. 在编写程序时,需要使用汇编语言,并在程序中调用setb指令。
六、结论本文对单片机中常用的setb指令进行了详细介绍。
通过学习本文内容,读者可以了解到setb指令的概述、使用方法以及与其他相关指令的比较等内容。
80c51汇编语言指令

80c51汇编语言指令80C51汇编语言是一种常用的低级程序设计语言,广泛应用于嵌入式系统中。
它是基于Intel 8051系列单片机的指令集架构,具有高效、灵活、可靠的特点。
本文将介绍80C51汇编语言的一些常用指令。
一、MOV指令MOV指令是80C51汇编语言中最基本、最常用的指令之一,用于将数据从一个寄存器或内存位置复制到另一个寄存器或内存位置。
例如,MOV A, #25H表示将立即数25H复制到A寄存器中。
二、ADD指令ADD指令用于执行两个操作数的相加运算,并将结果存储在目标操作数中。
例如,ADD A, R0表示将A寄存器和R0寄存器中的数据相加,并将结果存储在A寄存器中。
三、SUBB指令SUBB指令用于执行两个操作数的减法运算,并将结果存储在目标操作数中。
与ADD指令不同的是,SUBB指令会考虑进位位的值。
例如,SUBB A, R1表示将A寄存器中的数据减去R1寄存器中的数据,并将结果存储在A寄存器中。
四、MUL指令MUL指令用于执行两个操作数的乘法运算,并将结果存储在累加器A和可选的乘法寄存器B中。
例如,MUL AB表示将累加器A和B 中的数据相乘,并将结果存储在A和B中。
五、DIV指令DIV指令用于执行两个操作数的除法运算,并将结果存储在累加器A和可选的余数寄存器B中。
例如,DIV AB表示将累加器A和B 中的数据相除,并将商存储在A中,余数存储在B中。
六、JC、JNC指令JC指令用于在条件跳转时执行跳转操作,如果进位标志位(C)为1,则执行跳转。
JNC指令则相反,只有当进位标志位为0时才执行跳转。
七、JZ、JNZ指令JZ指令用于在条件跳转时执行跳转操作,如果零标志位(Z)为1,则执行跳转。
JNZ指令则相反,只有当零标志位为0时才执行跳转。
八、CJNE指令CJNE指令用于在条件跳转时执行跳转操作,它比较两个操作数的值,并根据比较结果来确定是否执行跳转。
如果两个操作数相等,则不执行跳转;如果不相等,则执行跳转。
8051单片机指令

8051单片机指令8051单片机是一种经典的微控制器,使用广泛,特别适用于嵌入式系统开发。
在实际的编程过程中,了解并掌握8051单片机的指令集是非常重要的。
本文将介绍一些常用的8051单片机指令,帮助读者更好地理解和应用这些指令。
一、MOV指令MOV指令是8051单片机中最常用的指令之一,用于将数据从一个寄存器移动到另一个寄存器。
例如,MOV A, B表示将B寄存器的值移动到A寄存器中。
这个指令非常简单直观,容易理解和使用。
二、ADD指令ADD指令用于将两个数相加,并将结果存储到累加器。
例如,ADD A, B表示将A和B寄存器中的值相加,并将结果存储到A寄存器中。
这个指令非常有用,可以实现简单的数学运算。
三、SUB指令SUB指令用于计算两个数的差值,并将结果存储到累加器。
例如,SUB A, B表示将B寄存器的值从A寄存器的值中减去,并将结果存储到A寄存器中。
这个指令也非常常用,可以实现简单的减法运算。
四、MUL指令MUL指令用于计算两个数的乘积,并将结果存储到累加器和扩展寄存器中。
例如,MUL AB表示将A和B寄存器中的值相乘,并将低8位结果存储到累加器A中,将高8位结果存储到扩展寄存器B中。
这个指令非常有用,可以实现简单的乘法运算。
五、DIV指令DIV指令用于计算两个数的商和余数,并将结果存储到累加器和余数寄存器中。
例如,DIV AB表示将A和B寄存器中的值相除,并将商存储到累加器A中,余数存储到余数寄存器B中。
这个指令非常有用,可以实现简单的除法运算。
六、JMP指令JMP指令用于无条件跳转到指定的地址。
例如,JMP 2000H表示程序跳转到2000H地址处执行。
这个指令非常常用,可以实现程序的控制流跳转。
七、JC指令JC指令用于在进位标志位(Carry Flag)为1时跳转到指定的地址。
例如,JC 3000H表示当进位标志位为1时,程序跳转到3000H地址处执行。
这个指令非常有用,可以实现条件判断和分支跳转。
单片机基础考试试卷

单片机基础考试试卷一、选择题(每题2分,共20分)1. 单片机是一种集成在单一芯片上的微型计算机,其核心是______。
A. 微处理器B. 微控制器C. 微运算器D. 微存储器2. 下列哪个不是单片机的典型应用领域?A. 家用电器控制B. 工业自动化C. 网络通信D. 大型计算机系统3. 8051单片机中,下列哪个寄存器是用于存储地址的?A. ACCB. BC. SPD. PC4. 单片机的I/O口通常具有的模式不包括以下哪项?A. 准双向口B. 推挽输出C. 开漏输出D. 存储模式5. 下列哪个指令不是8051单片机的汇编语言指令?A. MOVC. SUBD. JUMP6. 单片机的中断系统通常包括哪两个主要部分?A. 中断向量表和中断服务程序B. 中断请求和中断响应C. 中断优先级和中断服务程序D. 中断向量和中断优先级7. 8051单片机的定时器/计数器在以下哪个模式下可以同时作为定时器和计数器使用?A. 模式0B. 模式1C. 模式2D. 模式38. 下列哪个不是单片机的存储器类型?A. ROMB. RAMC. EPROMD. Cache9. 单片机的看门狗定时器的主要作用是什么?A. 定时唤醒B. 系统监控C. 定时计数D. 定时中断10. 单片机的串行通信中,波特率的设置取决于以下哪个寄存器?A. SCONC. PCOND. TMOD二、简答题(每题5分,共20分)1. 简述单片机的中断优先级是如何确定的。
2. 解释单片机中的堆栈(Stack)的作用及其工作原理。
3. 描述单片机的看门狗定时器如何防止系统死锁。
4. 简述单片机的串行通信与并行通信的区别。
三、计算题(每题10分,共20分)1. 给定一个8051单片机的定时器,其时钟频率为12MHz,定时器的时钟频率为机器周期的1/12。
计算定时器的1ms定时周期需要设置的初始值是多少?(忽略机器周期的12分频)2. 假设单片机的I/O口P1.0连接了一个LED灯,编写一段汇编语言代码,实现LED灯闪烁10次的功能。
第3章 80C51单片机的寻址方式和指令系统

(2)算术运算类指令(24条);
(3)逻辑运算及移位类指令(24条); (4)控制转移类指令(17条); (5)位操作类指令(17条)。
6
本节内容
3.1.1 汇编语言指令格式 3.1.2 机器码的三种格式 3.1.3 指令中常用符号说明
7
3.1.1 汇编语言指令格式
3.4.1 加法指令 3.4.2 减法指令 3.4.3 乘、除法指令
3.5 逻辑运算及移位类指令(24条)
3.5.1 逻辑与运算指令 3.5.2 逻辑或运算指令
3
第2章:80C51系列单片机基本结构及原理
3.5.3 逻辑异或运算指令 3.5.4 累加器清零、取反指令 3.5.5 循环移位指令
目录
3.6 控制转移类指令(17条)
解:指令执行过程如图3-3,结果:(A)= 60H 。 指令在ROM中的机器码为E8H,指令对应的机器码是:E8H=1110 1000B,二进 制的后三位000就是隐含的R0寄存器的编码,如果是R7其编码为111。 由于寄存器在CPU内部,所以采用寄存器寻址可以获得较高的运算速度。
31
32
能实现这种寻址方式的寄存器有: (1)工作寄存器 R0~R7 (4组工作寄存器均可) (2)累加器A (注:使用A为寄存器寻址,使用ACC为直接寻址) (3)寄存器B (注:以AB寄存器对的形式出现时为寄存器寻址,单独出现
一条完整的汇编语言指令通常由标号、操作码、操作数 (一般包括目的操作数和源操作数)及指令的注释构成。 指令格式: [标号:] <操作码> [操作数] [,操作数][;注释]
说明:
①在一条指令中,方括号中的内容可有可无,尖括号中的内容 必须有。
8051单片机工作原理_--_单片机入门经典教程

第一课:初识单片机记得在我们网站的论坛里,曾经有一位网友问了一个问题,什么是单片机?单片机是怎样的一个东东?单片机可以实现些什么功能?它主要应用在哪些领域?在我们单片机自学网的网上课堂的第一节课,我们就上面的这些问题与大家先做一个初步的探讨。
在进入课程的讲解之前,大家先一起来看看单片机吧。
下图是一片40脚的89C51及一片20脚的89C2051的单片机。
单片机的外形从上图中我们已初步认识了,那么什么叫单片机呢?所谓单片机,通俗的来讲,就是把中央处理器CPU(Central Processing Unit),存储器(memory),定时器,I/O(Input/Output)接口电路等一些计算机的主要功能部件集成在一块集成电路芯片上的微型计算机。
单片机又称为“微控制器MCU”。
中文“单片机”的称呼是由英文名称“Single Chip Microcomputer”直接翻译而来的。
单片机的主要分类:1、按应用领域可分为:家电类,工控类,通信类,个人信息终端类等等;2、按通用性可分为:通用型和专用型。
通用型单片机的主要特点是:内部资源比较丰富,性能全面,而且通用性强,可履盖多种应用要求。
所谓资源丰富就是指功能强。
性能全面通用性强就是指可以应用在非常广泛的领域。
通用型单片机的用途很广泛,使用不同的接口电路及编制不同的应用程序就可完成不同的功能。
小到家用电器仪器仪表,大到机器设备和整套生产线都可用单片机来实现自动化控制。
专用型单片机的主要特点是:针对某一种产品或某一种控制应用而专门设计的,设计时已使结构最简,软硬件应用最优,可靠性及应用成本最佳。
专用型单片机用途比较专一,出厂时程序已经一次性固化好,不能再修该的单片机。
例如电子表里的单片机就是其中的一种。
其生产成本很低。
在我们的这个网上课堂中,介绍的是MCS-51系列单片机,MCS-51单片机也是一种通用单片机,其结构及原理对所有的单片机都适用。
3、按总线结构可分为总线型和非总线型。
单片机简答题与答案

1、MCS-51单片机的时钟周期与振荡周期之间有什么关系?一个机器周期的时序如何划分?答:时钟周期是单片机最基本的时间单位。
机器周期则是完成某一个规定操作所需的时间。
一个机器周期为6个时钟周期,共12个振荡周期性,依次表示为S1P1、S1P2、……S6P1、S6P2。
2、MCS-51单片机有几种复位方法?应注意的事项?答:上电复位和开关复位。
上电复位要求接通电源,自动实现复位操作。
开关复位要求在电源接通的条件下,在单片机运行期间,如果发生死机,用按钮开关操作使单片机复位。
3、MCS-51单片机内部包含哪些主要逻辑功能部件?答:(1)一个8位微处理器CPU。
(2)数据存储器RAM和特殊功能寄存器SFR。
(3)内部程序存储器ROM。
(4)两个定时/计数器,用以对外部事件进行计数,也可用作定时器。
(5)四个8位可编程的I/O(输入/输出)并行端口,每个端口既可做输入,也可做输出。
(6)一个串行端口,用于数据的串行通信。
4、什么是堆栈?堆栈有何作用?在程序设计时,有时为什么要对堆栈指针SP重新赋值?如果CPU在操作中要使用两组工作寄存器,你认为SP的初值应为多大?答:堆栈是一种按照“先进后出”或者“后进先出”规律存取数据的RAM区域由于程序中没有表识,所以要对SP重新赋值对指针SP重新赋值是因为堆栈空间有限,要给他赋首地址。
要使用两组工作寄存器,SP的值应该设置为10H。
5、MCS-51单片机的P0~P3四个I/O端口在结构上有何异同?使用时应注意的事项?答:80C51单片机的4个I/O端口在结构上时基本相同的,但又各具特点。
在无片外扩展存储器的系统中,这4个端口的每1位都可以作为I/O端口使用。
在作为一般的通用I/O输入时,都必须先向锁存器写入“1”,使输出驱动场效应管FET截止,以免误读数据。
在系统扩展片外存储器时,P2口作为高8位地址,P0口分时作为低8位地址和双向数据总线。
它们的主要不同点如下:(1)P0口的每一位可驱动8个LSTTL负载。
单片机汇编语言指令集

单片机汇编语言指令集汇编语言是一种低级程序设计语言,广泛应用于单片机的编程和控制。
单片机汇编语言指令集是程序员在开发单片机应用时必须了解和掌握的一项基础知识。
本文将介绍常用的单片机汇编语言指令集及其功能。
1. 指令集概述单片机汇编语言指令集是单片机内部指令的集合,用于完成各种操作和控制功能。
指令集由操作码和操作数组成,操作码表示指令的类型,操作数表示指令要操作的数据或地址。
2. 数据传送指令数据传送指令用于将数据从一个位置传送到另一个位置,包括寄存器之间的传送、寄存器和内存之间的传送等。
常用的数据传送指令有MOV、LDR、STR等。
3. 算术运算指令算术运算指令用于进行各种算术运算,包括加法、减法、乘法、除法等。
常用的算术运算指令有ADD、SUB、MUL、DIV等。
4. 逻辑运算指令逻辑运算指令用于进行各种逻辑运算,包括与、或、非、异或等。
常用的逻辑运算指令有AND、OR、NOT、XOR等。
5. 条件转移指令条件转移指令用于根据条件进行跳转或循环控制,常用的条件转移指令有BEQ、BNE、BGT、BLE等。
通过条件转移指令,程序可以根据不同的条件选择执行不同的代码路径。
6. 程序控制指令程序控制指令用于实现程序的跳转、函数的调用和返回等功能。
常用的程序控制指令有JMP、CALL、RET等。
通过程序控制指令,程序可以按照预定的流程执行,实现复杂的控制逻辑。
7. 输入输出指令输入输出指令用于与外部设备进行数据交互,包括输入数据和输出数据。
常用的输入输出指令有IN、OUT等。
通过输入输出指令,单片机可以与外围设备进行数据的传输和交互。
8. 中断指令中断指令用于处理外部中断或内部中断事件,包括中断的触发、中断的响应和中断的处理等。
常用的中断指令有INT、IRET等。
通过中断指令,单片机可以及时响应和处理各种中断事件。
9. 扩展指令扩展指令是一些额外的指令,用于扩展单片机的功能和性能。
扩展指令的具体内容和功能因不同的单片机而异,常见的扩展指令有乘法指令、移位指令、位操作指令等。
单片机汇编语言(指令集锦)

单片机汇编语言一、格式[标号]:操作码[操作数];[注释]1.标号指令的符号地址,与操作码用‘:’分隔,其间可加若干空格。
有标号,程序的其他语句才可访问该语句。
可有可无。
规定:由8个以内的字母、数字构成,第一个必为字母,同一程序不可有相同标号,不能有助记符、伪指令、寄存器名、特殊符号等。
正确标号:AB1、NEXT、LOOP1。
错误标号:2A、S+M、EQU、ADD。
2.操作码说明语句功能,必不可少。
与操作数之间用空格相隔。
3.操作数说明操作对象。
可以是具体的数、标号(符号地址)、寄存器、直接地址等。
操作数为十六进制,且字母在最高位,则前面应补0.据指令之异,个数可为1、2、3或无。
各操作间用‘,’相隔。
4.注释程序说明。
以‘;’开头,可多行,每行都以‘;’开头。
二、寻址方式寻找操作数的地址。
1.寄存器寻址以通用寄存器的内容作为操作数,在指令的助记符中直接以寄存器名字来表示操作数位置。
51中若操作数以R0~R7表示操作数时,就属于此方式。
如:‘MOV A,R0’,功能:把寄存器R0的内容传送到累加器A中。
2.直接寻址在指令中直接给出操作数地址。
如:MOV ‘A,3AH’,功能:把内部RAM的3AH单元内容传送到累加器A中。
3.立即寻址指令的操作数是一个数。
该操作数被称为立即数。
立即数前加‘#’,如:’MOV A,#3AH’,功能:把立即数3AH送到累加器A中。
4.寄存器间接寻址寄存器中存放的是操作数的地址,即操作数是通过寄存器间接得到的,相应的寄存器前加@。
如:‘MOV A,@R0’,功能:取出寄存器R0中的值,将此值作为地址,取该地址单元中的内容传送到A。
5.变址寻址以某个寄存器的内容为基本地址,在此基本地址基础上加上地址偏移量作为真正的操作地址,并将此地址单元的内容作为指令的操作数。
51中,一般用数据指针DPTR或程序计数器PC的内容为基本地址,累加器A的内容为地址偏移量,并以DPTR+A或PC+A的值作为实际的操作数地址。
(完整版)C51单片机汇编语言指令集,推荐文档

的逻辑判断,结果存回累加器
ANL 1 1 将累加器的值与间接地址的内容做AND
A,@Ri
的逻辑判断,结果存回累加器
ANL 2 1 将累加器的值与常数做AND的逻辑判断,
A,#data
结果存回累加器
ANL 2 1 将直接地址的内容与累加器的值做AND
direct,A
的逻辑判断,结果存回该直接地址
ANL
1 1 将累加器的值减去寄存器的值减借 位C,结果存回累加器
2 1 将累加器的值减直接地址的值减借 位C,结果存回累加器
1 1 将累加器的值减间接地址的值减借
A,@Ri 12.SUBB A,0data
位C,结果存回累加器 2 1 将累加器的值减常数值减借位C,结
果存回累加器
13.INC A 1 1 将累加器的值加1 14.INC Rn 1 1 将寄存器的值加l
51汇编语言指令集
符号定义表
符号
含义
Rn
R0~R7寄存器n=0~7
Direct 直接地址,内部数据区的地址 RAM(00H~7FH)
SFR(80H~FFH) B,ACC,PSW,IP,P3,IE,P2,SCON, P1,TCON,P0
@Ri
间接地址Ri=R0或R1
8051/31RAM地址
(00H~7FH) 8052/32RAM地址(00H~FFH)
44.CPL A 1 1 将累加器的值反相
45.RL A 1 1 将累加器的值左移一位
46.RLC A 1 1 将累加器含进位C左移一位
47.RR A 1 1 将累加器的值右移一位
48.RRC A 1 1 将累加器含进位C右移一位
49.SWAP 1 1 将累加器的高4位与低4位的内容交换。
mcs51单片机指令集

一个单片机所需执行指令的集合即为单片机的指令系统。
单片机使用的机器语言、汇编语言及高级语言,但不管使用是何种语言,最终还是要“翻译”成为机器码,单片机才能执行之。
现在有很多半导体厂商都推出了自己的单片机,单片机种类繁多,品种数不胜数,值得注意的是不同的单片机它们的指令系统不一定相同,或不完全相同。
但不管是使用机器语言、汇编语言还是高级语言都是使用指令编写程序的。
所谓机器语言即指令的二进制编码,而汇编语言则是指令的表示符号。
在指令的表达式上也不会直接使用二进制机器码,最常用的是十六进制的形式。
但单片机并不能直接执行汇编语言和高级语言,都必须通过汇编器“翻译”成为二进制机器码方能执行,但如果直接使用二进制来编写程序,那将十分不便,也很难记忆和识别,不易编写、难于辨读,极易出错,同时出错了也相当难查找。
所以现在基本上都不会直接使用机器语言来编写单片机的程序。
最好的办法就是使用易于阅读和辨认的指令符号来代替机器码,我们常称这些符号为助记符,用助记符的形式表示的单片机指令就是汇编语言,为便于记忆和阅读,助记符号通常都使用易于理解的英文单词和拼音字母来表示。
每种单片机都有自己独特的指令系统,那么指令系统是开发和生产厂商定义的,如要使用其单片机,用户就必须理解和遵循这些指令标准,要掌握某种(类)单片机,指令系统的学习是必须的。
MCS-51共有111条指令,可分为5类:[1].数据传送类指令(共29条)[2].算数运算类指令(共24条)[3].逻辑运算及移位类指令(共24条)[4].控制转移类指令(共17条)[5].布尔变量操作类指令(共17条)一些特殊符号的意义在介绍指令系统前,我们先了解一些特殊符号的意义,这对今后程序的编写都是相当有用的。
Rn——当前选中的寄存器区的8个工作寄存器R0—R7(n=0-7)。
Ri——当前选中的寄存器区中可作为地址寄存器的两个寄存器R0和R1(i=0,1)direct—内部数据存储单元的8位地址。
51单片机汇编指令集(附记忆方法)

51单片机汇编指令集一、数据传送类指令(7种助记符)MOV(英文为Move):对内部数据寄存器RAM和特殊功能寄存器SFR的数据进行传送;MOVC(Move Code)读取程序存储器数据表格的数据传送;MOVX (Move External RAM) 对外部RAM的数据传送;XCH (Exchange) 字节交换;XCHD (Exchange low-order Digit) 低半字节交换;PUSH (Push onto Stack) 入栈;POP (Pop from Stack) 出栈;二、算术运算类指令(8种助记符)ADD(Addition) 加法;ADDC(Add with Carry) 带进位加法;SUBB(Subtract with Borrow) 带借位减法;DA(Decimal Adjust) 十进制调整;INC(Increment) 加1;DEC(Decrement) 减1;MUL(Multiplication、Multiply) 乘法;DIV(Division、Divide) 除法;三、逻辑运算类指令(10种助记符)ANL(AND Logic) 逻辑与;ORL(OR Logic) 逻辑或;XRL(Exclusive-OR Logic) 逻辑异或;CLR(Clear) 清零;CPL(Complement) 取反;RL(Rotate left) 循环左移;RLC(Rotate Left throught the Carry flag) 带进位循环左移;RR(Rotate Right) 循环右移;RRC (Rotate Right throught the Carry flag) 带进位循环右移;SWAP (Swap) 低4位与高4位交换;四、控制转移类指令(17种助记符)ACALL(Absolute subroutine Call)子程序绝对调用;LCALL(Long subroutine Call)子程序长调用;RET(Return from subroutine)子程序返回;RETI(Return from Interruption)中断返回;SJMP(Short Jump)短转移;AJMP(Absolute Jump)绝对转移;LJMP(Long Jump)长转移;CJNE (Compare Jump if Not Equal)比较不相等则转移;DJNZ (Decrement Jump if Not Zero)减1后不为0则转移;JZ (Jump if Zero)结果为0则转移;JNZ (Jump if Not Zero) 结果不为0则转移;JC (Jump if the Carry flag is set)有进位则转移;JNC (Jump if Not Carry)无进位则转移;JB (Jump if the Bit is set)位为1则转移;JNB (Jump if the Bit is Not set) 位为0则转移;JBC(Jump if the Bit is set and Clear the bit) 位为1则转移,并清除该位;NOP (No Operation) 空操作;五、位操作指令(1种助记符)CLR 位清零;SETB(Set Bit) 位置1。
单片机的mul指令

单片机中的"mul" 指令通常用于执行乘法操作。
不同型号的单片机可能会有不同的指令集架构和语法,因此"mul" 指令的具体用法会有所不同。
以下是一些常见单片机架构中"mul" 指令的通用概述:操作数:"mul" 指令通常需要两个操作数,分别是要相乘的两个值。
这些值可以是寄存器中的数据、内存中的数据或立即数(常数)。
操作结果:"mul" 指令执行乘法操作,并将结果存储在一个寄存器中,通常是一个专门用于存储乘法结果的寄存器。
溢出处理:在执行乘法时,需要考虑溢出问题。
如果乘法的结果太大,无法用一个寄存器来存储,那么可能需要使用多寄存器或特殊的溢出标志来处理溢出情况。
指令格式:"mul" 指令的具体语法和指令格式会根据单片机的架构而变化。
例如,在某些单片机中,指令可能是"mul R1, R2",其中R1 和R2 是要相乘的寄存器。
以下是一些示例:8051 单片机(汇编语言):MUL AB ; 将A 寄存器和B 寄存器中的值相乘,结果存储在A 和B 中ARM Cortex-M(汇编语言):MUL R0, R1, R2 ; 将R1 和R2 中的值相乘,结果存储在R0 中PIC 单片机(汇编语言):MULWF 0x0A ; 将W 寄存器中的值与地址为0x0A 的RAM 中的值相乘,结果存储在W 寄存器中请注意,不同型号的单片机有不同的指令集和操作数寄存器。
因此,你需要查阅特定单片机的文档或参考手册,以了解其"mul" 指令的具体用法和语法。
单片机指令表汇总

51单片机指令表汇总51单片机是一种广泛应用的微控制器,其指令集是进行编程的基础。
下面将51单片机的指令表进行汇总,以帮助初学者更好地理解其指令集。
一、数据传输指令1、MOV指令:将源操作数的内容传送到目标操作数。
2、XCH指令:将两个操作数的内容互换。
3、MOVC指令:从外部存储器将数据传送到目标操作数。
4、MOVX指令:将外部存储器中的数据传送到目标操作数。
5、PUSH指令:将数据压入堆栈。
6、POP指令:从堆栈中弹出数据。
二、算术运算指令1、ADD指令:将两个操作数相加,并将结果存放在目标操作数中。
2、SUB指令:从目标操作数中减去源操作数,并将结果存放在目标操作数中。
3、MUL指令:将两个操作数相乘,并将结果存放在目标操作数中。
4、DIV指令:将目标操作数除以源操作数,并将结果存放在目标操作数中。
5、ANL指令:对目标操作数和源操作数进行按位与运算,并将结果存放在目标操作数中。
6、ORL指令:对目标操作数和源操作数进行按位或运算,并将结果存放在目标操作数中。
7、XRL指令:对目标操作数和源操作数进行按位异或运算,并将结果存放在目标操作数中。
8、CPL指令:对目标操作数进行按位取反运算,并将结果存放在目标操作数中。
9、INC指令:将目标操作数加1。
10、DEC指令:将目标操作数减1。
11、ASR指令:将目标操作数右移n位,最高位用符号位补齐。
12、LSR指令:将目标操作数右移n位,最低位用0补齐。
13、ROL指令:将目标操作数循环左移n位,最高位移入最低位。
14、ROR指令:将目标操作数循环右移n位,最低位移入最高位。
单片机汇编指令表一、概述在单片机的世界里,汇编语言扮演着举足轻重的角色。
它是一种低级语言,能够直接与硬件进行交互,提供高效的代码执行效率。
下面,我们将详细列出一些常见的单片机汇编指令,以及它们的功能。
二、指令表1、MOV指令:用于将数据从一个寄存器移动到另一个寄存器。
例如,MOV R1, R2将把 R2的内容移动到 R1中。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
将直接地址的内容加1 将间接地址的内容加1 数据指针寄存器值加1
当DPTR的低字节(DPL)从FFH溢出至00H时,会使高字节(DPH)加1,不影响任何标志位 将累加器的值减1 将寄存器的值减1 将直接地址的内容减1 将间接地址的内容减1 将累加器的值与B寄存器的值相乘,乘积的低位字节存回累加器,高位字节 存回B寄存器
指令 算数运算指令 1.ADD A,Rn 2.ADD A,direct 3.ADD A,@Ri 4.ADD A,#data 5.ADDC A,Rn 6.ADDC A,direct 7.ADDC A,@Ri 8.ADDC A,#data 9.SUBB A,Rn 10.SUBB A,direct 11.SUBB A,@Ri 12.SUBB A,0data 13.INC A 14.INC Rn
2 2 3 2 1 2 1 2 2 2 3 2 2 2 1 2 2 2 2 2 3 2 3 2
107.CJNE @Rn,#data,rel 3 2 108.CJNE @Ri,#data,rel 3 2 109.DJNZ Rn,rel 110.DJNZ direct,rel 111.NOP 2 2 3 2 1 1
A) 7-4←(A)7-4+6 将累加器的值与寄存器的值做AND的逻辑判断,结果存回累加器 将累加器的值与直接地址的内容做AND的逻辑判断,结果存回累加器 将累加器的值与间接地址的内容做AND的逻辑判断,结果存回累加器 将累加器的值与常数做AND的逻辑判断,结果存回累加器 将直接地址的内容与累加器的值做AND的逻辑判断,结果存回该直接地址 将直接地址的内容与常数值做AND的逻辑判断,结果存回该直接地址 将累加器的值与寄存器的值做OR的逻辑判断,结果存回累加器 将累加器的值与直接地址的内容做OR的逻辑判断,结果存回累加器 将累加器的值与间接地址的内容做OR的逻辑判断,结果存回累加器 将累加器的值与常数做OR的逻辑判断,结果存回累加器 将直接地址的内容与累加器的值做OR的逻辑判断,结果存回该直接地址 将直接地址的内容与常数值做OR的逻辑判断,结果存回该直接地址 将累加器的值与寄存器的值做XOR的逻辑判断,结果存回累加器
8位常数
16位常数
16位的目标地址
11位的目标地址
相关地址
内部数据RAM(20H~2FH),特殊功能寄存器的直接地址的位
动作说明
将累加器与寄存器的内容相加,结果存回累加器 将累加器与直接地址的内容相加,结果存回累加器 将累加器与间接地址的内容相加,结果存回累加器 将累加器与常数相加,结果存回累加器 将累加器与寄存器的内容及进位C相加,结果存回累加器 将累加器与直接地址的内容及进位C相加,结果存回累加器 将累加器与间接地址的内容及进位C相加,结果存回累加器 将累加器与常数及进位C相加,结果存回累加器 将累加器的值减去寄存器的值减借位C,结果存回累加器 将累加器的值减直接地址的值减借位C,结果存回累加器 将累加器的值减间接地址的值减借位C,结果存回累加器 将累加器的值减常数值减借位C,结果存回累加器 将累加器的值加1 将寄存器的值加l
2 1 1 1 2 1 2 1 3 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 2 1 1 1 2 1 1 1 2 2 2 1 2 1 2 2 3 2 2 2 3 2 1 1 2 2 2 1 3 2
66.MOVC A,@A+DPTR
1 2
累加器的值再加数据指针寄存器的值为其所指定地址,将该地址的内容读入累加器 67.MOVC A,@A+PC 68.MOVX A,@Ri 69.MOVX A,@DPTR 70.MOVX @Ri,A 71.MOVX @DPTR,A 72.PUSH direct 73.POP direct 74.XCH A,Rn 75.XCH A,direct 76.XCH A,@Ri 77.XCHD A,@Ri 布尔代数运算 78.CLR C 79.CLR bit 80.SETB C 81.SETB bit 82.CPL C 83.CPL bit 84.ANL C,bit 85.ANL C,/bit 86.ORL C,bit 87.ORL C,/bit 88.MOV C,bit 89.MOV bit,C 90.JC rel 91.JNC rel 92.JB bit,rel 93.JNB bit,rel 94.JBC bit,rel 程序跳跃 1 1 2 1 1 1 2 1 1 1 2 1 2 2 2 2 2 2 2 2 2 1 2 2 2 2 2 2 3 2 3 2 3 2 1 2 1 2 1 2 1 2 1 2 2 2 2 2 1 1 2 1 1 1 1 1
51汇编语言指令集
符号定义表 符号 Rn Direct @Ri #data #data16 Addr16 Addr11 Rel bit 指令介绍 字 周 节 期 1 1 2 1 1 1 2 1 1 1 2 1 1 1 2 1 1 1 2 1 1 1 2 1 1 1 1 1 含义 R0~R7寄存器n=0~7 直接地址,内部数据区的地址RAM(00H~7FH) SFR(80H~FFH) B,ACC,PSW,IP,P3,IE,P2,SCON,P1,TCON,P0 间接地址Ri=R0或R1 8位常数 16位常数 16位的目标地址 11位的目标地址 相关地址 内部数据RAM(20H~2FH),特殊功能寄存器的直接地址的位 8051/31RAM地址(00H~7FH) 8052/32RAM地址(00H~FFH)
38.XRL A,direct 39.XRL A,@Ri 40.XRL A,#data 41.XRL direct,A 42.XRL direct,#data 43.CLR A 44.CPL A 45.RL A 46.RLC A 47.RR A 48.RRC A 49.SWAP A 数据转移指令 50.MOV A,Rn 51.MOV A,direct 52.MOV A,@Ri 53.MOV A,#data 54.MOV Rn,A 55.MOV Rn,direct 56.MOV Rn,gdata 57.MOV direct,A 58.MOV direct,Rn 59.MOV direct1, direct2 60.MOV direct,@Ri 61.MOV direct,#data 62.MOV @Ri,A 63.MOV @Ri,direct 64.MOV @Ri,#data 65.MOV DPTR,#data16
(A) ←((A)+(DPTR))
存器的值为其所指定地址,将该地址的内容读入累加器 (PC)←(PC)+1;(A)←((A)+(PC))累加器的值加程序计数器的值作为其所指 定地址,将该地址的内容读入累加器 将间接地址所指定外部存储器的内容读入累加器(8位地址) 将数据指针所指定外部存储器的内容读入累加器(16位地址) 将累加器的内容写入间接地址所指定的外部存储器(8位地址) 将累加器的内容写入数据指针所指定的外部存储器(16位地址) 将直接地址的内容压入堆栈区 从堆栈弹出该直接地址的内容 将累加器的内容与寄存器的内容互换 将累加器的值与直接地址的内容互换 将累加器的值与间接地址的内容互换 将累加器的低4位与间接地址的低4位互换 清除进位C为0 清除直接地址的某位为0 设定进位C为1 设定直接地址的某位为1 将进位C的值反相 将直接地址的ቤተ መጻሕፍቲ ባይዱ位值反相 将进位C与直接地址的某位做AND的逻辑判断,结果存回进位C 将进位C与直接地址的某位的反相值做AND的逻辑判断,结果存回进位C 将进位C与直接地址的某位做OR的逻辑判断,结果存回进位C 将进位C与直接地址的某位的反相值做OR的逻辑判断,结果存回进位C 将直接地址的某位值存入进位C 将进位C的值存入直接地址的某位 若进位C=1则跳至rel的相关地址 若进位C=0则跳至rel的相关地址 若直接地址的某位为1,则跳至rel的相关地址 若直接地址的某位为0,则跳至rel的相关地址 若直接地址的某位为1,则跳至rel的相关地址,并将该位值清除为0
95.ACALL addr11 96.LCALL addr16 97.RET 98.RETI 99.AJMP addr11 100.LJMP addr16 101.SJMP rel 102.JMP @A+DPTR 103.JZ rel 104.JNZ rel 105.CJNE A,direct,rel 106.CJNE A,#data,rel
说明:将累加器A和寄存器B内的无符号整数相乘,产生16位的积,低位字节存入A,高位字节存入B寄存器。如 果积大于FFH,则溢出标志位(OV)被设定为1,而进位标志位为0 23.DIV AB 1 4
说明:无符号的除法运算,将累加器A除以B寄存器的值,商存入A,余数存入B。执行本指令后,进位位(C)及 溢出位(OV)被清除为0 24.DA A 1 1 若(A) 3-0>9或(AC)=1,则(A) 3-0←(A)3-0+6 若(A) 7-4>9或 (C)=1,则(A) 7-4←(A)7-4+6 逻辑运算指令 25.ANL A,Rn 26.ANL A,direct 27.ANL A,@Ri 28.ANL A,#data 29.ANL direct,A 30.ANL direct,#data 31.ORL A,Rn 32.ORL A,direct 33.ORL A,@Ri 34.ORL A,#data 35.ORL direct,A 36.ORL direct,#data 37.XRL A,Rn 1 1 2 1 1 1 2 1 2 1 3 2 1 1 2 1 1 1 2 1 2 1 3 2 1 1
将累加器的值与直接地址的内容做XOR的逻辑判断,结果存回累加器 将累加器的值与间接地扯的内容做XOR的逻辑判断,结果存回累加器 将累加器的值与常数作XOR的逻辑判断,结果存回累加器 将直接地址的内容与累加器的值做XOR的逻辑判断,结果存回该直接地址 将直接地址的内容与常数的值做XOR的逻辑判断,结果存回该直接地址 清除累加器的值为0 将累加器的值反相 将累加器的值左移一位 将累加器含进位C左移一位 将累加器的值右移一位 将累加器含进位C右移一位 将累加器的高4位与低4位的内容交换。(A)3-0←(A)7-4 将寄存器的内容载入累加器 将直接地址的内容载入累加器 将间接地址的内容载入累加器 将常数载入累加器 将累加器的内容载入寄存器 将直接地址的内容载入寄存器 将常数载入寄存器 将累加器的内容存入直接地址 将寄存器的内容存入直接地址 将直接地址2的内容存入直接地址1 将间接地址的内容存入直接地址 将常数存入直接地址 将累加器的内容存入某间接地址 将直接地址的内容存入某间接地址 将常数存入某间接地址 将16位的常数存入数据指针寄存器