C51单片机指令集大全

合集下载

C51指令集

C51指令集

51指令集指令格式 功能简述 字节数 周期一、数据传送类指令MOV A, Rn 寄存器送累加器 1 1MOV Rn,A 累加器送寄存器 1 1MOV A ,@Ri 内部RAM单元送累加器 1 1MOV @Ri ,A 累加器送内部RAM单元 1 1MOV A ,#data 立即数送累加器 2 1MOV A ,direct 直接寻址单元送累加器 2 1MOV direct ,A 累加器送直接寻址单元 2 1MOV Rn,#data 立即数送寄存器 2 1MOV direct ,#data 立即数送直接寻址单元 3 2MOV @Ri ,#data 立即数送内部RAM单元 2 1MOV direct ,Rn 寄存器送直接寻址单元 2 2MOV Rn ,direct 直接寻址单元送寄存器 2 2MOV direct ,@Ri 内部RAM单元送直接寻址单元 2 2 MOV @Ri ,direct 直接寻址单元送内部RAM单元 2 2 MOV direct2,direct1 直接寻址单元送直接寻址单元 3 2 MOV DPTR ,#data16 16位立即数送数据指针 3 2MOVX A ,@Ri 外部RAM单元送累加器(8位地址) 1 2 MOVX @Ri ,A 累加器送外部RAM单元(8位地址) 1 2 MOVX A ,@DPTR 外部RAM单元送累加器(16位地址) 1 2 MOVX @DPTR ,A 累加器送外部RAM单元(16位地址) 1 2 MOVC A ,@A+DPTR 查表数据送累加器(DPTR为基址) 1 2 MOVC A ,@A+PC 查表数据送累加器(PC为基址) 1 2XCH A ,Rn 累加器与寄存器交换 1 1XCH A ,@Ri 累加器与内部RAM单元交换 1 1XCHD A ,direct 累加器与直接寻址单元交换 2 1XCHD A ,@Ri 累加器与内部RAM单元低4位交换 1 1 SWAP A 累加器高4位与低4位交换 1 1POP direct 栈顶弹出指令直接寻址单元 2 2PUSH direct 直接寻址单元压入栈顶 2 2二、算术运算类指令ADD A, Rn 累加器加寄存器 1 1ADD A, @Ri 累加器加内部RAM单元 1 1ADD A, direct 累加器加直接寻址单元 2 1ADD A, #data 累加器加立即数 2 1ADDC A, Rn 累加器加寄存器和进位标志 1 1ADDC A, @Ri 累加器加内部RAM单元和进位标志 1 1 ADDC A, #data 累加器加立即数和进位标志 2 1ADDC A, direct 累加器加直接寻址单元和进位标志 2 1 INC A 累加器加1 1 1INC Rn 寄存器加1 1 1INC direct 直接寻址单元加1 2 1INC @Ri 内部RAM单元加1 1 1INC DPTR 数据指针加1 1 2DA A 十进制调整 1 1SUBB A, Rn 累加器减寄存器和进位标志 1 1SUBB A, @Ri 累加器减内部RAM单元和进位标志 1 1 SUBB A, #data 累加器减立即数和进位标志 2 1SUBB A, direct 累加器减直接寻址单元和进位标志 2 1 DEC A 累加器减1 1 1DEC Rn 寄存器减1 1 1DEC @Ri 内部RAM单元减1 1 1DEC direct 直接寻址单元减1 2 1MUL AB 累加器乘寄存器B 1 4DIV AB 累加器除以寄存器B 1 4三、逻辑运算类指令ANL A, Rn 累加器与寄存器 1 1ANL A, @Ri 累加器与内部RAM单元 1 1ANL A, #data 累加器与立即数 2 1ANL A, direct 累加器与直接寻址单元 2 1ANL direct, A 直接寻址单元与累加器 2 1ANL direct, #data 直接寻址单元与立即数 3 1ORL A, Rn 累加器或寄存器 1 1ORL A,@Ri 累加器或内部RAM单元 1 1ORL A,#data 累加器或立即数 2 1ORL A,direct 累加器或直接寻址单元 2 1ORL direct, A 直接寻址单元或累加器 2 1ORL direct, #data 直接寻址单元或立即数 3 1XRL A, Rn 累加器异或寄存器 1 1XRL A,@Ri 累加器异或内部RAM单元 1 1XRL A,#data 累加器异或立即数 2 1XRL A,direct 累加器异或直接寻址单元 2 1XRL direct, A 直接寻址单元异或累加器 2 1XRL direct, #data 直接寻址单元异或立即数 3 2RL A 累加器左循环移位 1 1RLC A 累加器连进位标志左循环移位 1 1RR A 累加器右循环移位 1 1RRC A 累加器连进位标志右循环移位 1 1CPL A 累加器取反 1 1CLR A 累加器清零 1 1四、控制转移类指令类ACCALL addr11 2KB范围内绝对调用 2 2AJMP addr11 2KB范围内绝对转移 2 2LCALL addr16 2KB范围内长调用 3 2LJMP addr16 2KB范围内长转移 3 2SJMP rel 相对短转移 2 2JMP @A+DPTR 相对长转移 1 2RET 子程序返回 1 2RET1 中断返回 1 2JZ rel 累加器为零转移 2 2JNZ rel 累加器非零转移 2 2CJNE A ,#data ,rel 累加器与立即数不等转移 3 2CJNE A ,direct ,rel 累加器与直接寻址单元不等转移 3 2 CJNE Rn,#data ,rel 寄存器与立即数不等转移 3 2CJNE @Ri ,#data,rel RAM单元与立即数不等转移 3 2 DJNZ Rn ,rel 寄存器减1不为零转移 2 2DJNZ direct ,rel 直接寻址单元减1不为零转移 3 2NOP 空操作 1 1五、布尔操作类指令MOV C, bit 直接寻址位送C 2 1MOV bit, C C送直接寻址位 2 1CLR C C清零 1 1CLR bit 直接寻址位清零 2 1CPL C C取反 1 1CPL bit 直接寻址位取反 2 1SETB C C置位 1 1SETB bit 直接寻址位置位 2 1ANL C, bit C逻辑与直接寻址位 2 2ANL C, /bit C逻辑与直接寻址位的反 2 2 ORL C, bit C逻辑或直接寻址位 2 2ORL C, /bit C逻辑或直接寻址位的反 2 2 JC rel C为1转移 2 2JNC rel C为零转移 2 2JB bit,rel 直接寻址位为1转移 3 2JNB bit,rel 直接寻址为0转移。

【原创】C51指令

【原创】C51指令

算术运算:共7种运算+ 加- 减* 乘/ 除(取整数)++ 递加(加1)-- 递减(减1)% 除(取佘数)关系运算符:共6种(成立1、不成立0)判断数> 大于> = 大于或等于< 小于< = 小于或等于== 等于!= 不等于逻辑运算:共3种(成立1、不成立0)判断语句&& 与||或!非位逻辑运算符:共6种运算& 与|或^ 异或~ 非>> 右移<< 左移条件控制指令:共5种循环:for while do- while条件:单:if-else 多:switch-case(default 都不对时用)跳离本次循环:continue 跳离循环:break 子程序返回值:return 指针运算符:共2种& 获取地址* 获取内容优先次序:由上至下、由左至右注:程序中括号里的优先级最高,相同的优先级由左至右运算。

char:存放字符数据格式,代表存放8位数。

int:存放整数的数据格式,代表存放16位数。

float:存放浮点数的数据格式,代表存放32位数。

double:存放双位精度浮点数的数据格式,代表存放32位数。

signed:带符号。

unsigned:不带符号。

short:短,未加入short的变量为short。

long:长,其数据长度为原数据格式的2倍。

IE:中断触发控制寄存器(0:禁止 1:允许)默认优先级:低高总串行定/计1 外1 定/计0 外0 IP:中断优先级控制寄存器(0:低 1:高)默认优先级:低高串行定/计1 外1 定/计0 外0 TCON:定时/计数器控制寄存器TF1 TF0:定时/计数器溢出标志位,溢出时为1,执行中断时为0。

√TR1 TR0:软件设定,等于1时启动定时/计数器,等于0时停止。

IE1 IE0:外部中断触发时变为1,执行中断时变为0。

√IT1 IT0:外部中断触发方式,为0低电平中断,为1下降沿中断。

C51单片机指令集大全

C51单片机指令集大全

精心整理格式功能简述字节数周期一、数据传送类指令MOVA,Rn寄存器送累加器11MOVRn,A累加器送寄存器11MOVA,@Ri内部RAM单元送累加器11MOVXA,@DPTR外部RAM单元送累加器(16位地址)12MOVX@DPTR,A累加器送外部RAM单元(16位地址)12MOVCA,@A+DPTR查表数据送累加器(DPTR为基址)12MOVCA,@A+PC查表数据送累加器(PC为基址)12XCHA,Rn累加器与寄存器交换11XCHA,@Ri累加器与内部RAM单元交换11XCHDA,direct累加器与直接寻址单元交换21 XCHDA,@Ri累加器与内部RAM单元低4位交换11 SWAPA累加器高4位与低4位交换11POPdirect栈顶弹出指令直接寻址单元22 PUSHdirect直接寻址单元压入栈顶22二、算术运算类指令SUBBA,@Ri累加器减内部RAM单元和进位标志11 SUBBA,#data累加器减立即数和进位标志21 SUBBA,direct累加器减直接寻址单元和进位标志21 DECA累加器减111DECRn寄存器减111DEC@Ri内部RAM单元减111DECdirect直接寻址单元减121MULAB累加器乘寄存器B14DIVAB累加器除以寄存器B14三、逻辑运算类指令ANLA,Rn累加器与寄存器11ANLA,@Ri累加器与内部RAM单元11XRLdirect,#data直接寻址单元异或立即数32 RLA累加器左循环移位11RLCA累加器连进位标志左循环移位11RRA累加器右循环移位11RRCA累加器连进位标志右循环移位11CPLA累加器取反11CLRA累加器清零11四、控制转移类指令类ACCALLaddr112KB范围内绝对调用22 AJMPaddr112KB范围内绝对转移22 LCALLaddr162KB范围内长调用32 LJMPaddr162KB范围内长转移32MOVbit,CC送直接寻址位21 CLRCC清零11CLRbit直接寻址位清零21CPLCC取反11CPLbit直接寻址位取反21 SETBCC置位11SETBbit直接寻址位置位21ANLC,bitC逻辑与直接寻址位22ANLC,/bitC逻辑与直接寻址位的反22ORLC,bitC逻辑或直接寻址位22ORLC,/bitC逻辑或直接寻址位的反22JCrelC为1转移22MOVA,#0FFHMOVP1,#0FFH;开始时全灭;-------------------------------逐个点亮MOVR2,#8LOOP1:CLRCRLCAMOVP1,ACALLDL500MSDJNZR2,LOOP1CALLDL500MS;0.5sDJNZR2,LOOP3;------------------------------- DJNZR3,LOOP0MOVP1,#01001001B;5、显示为01001001 CALLDL500MSCALLDL500MS;共1sSJMP0000H;重新开始N遍;-------------------------------延时子程序。

c51单片机c语言常用指令 -回复

c51单片机c语言常用指令 -回复

c51单片机c语言常用指令-回复C51单片机C语言常用指令导语:C51单片机是一种非常常用的微控制器,它广泛应用于许多嵌入式系统和电子设备中。

在单片机的开发过程中,C语言是一种非常常用的编程语言。

本文将介绍C51单片机常用的指令,帮助读者了解这些指令的功能和使用方法。

第一部分:常用的I/O口控制指令I/O口控制指令是C51单片机中非常重要的一部分,因为它们用于控制单片机与外部设备之间的数据交互。

以下是一些常用的I/O口控制指令:- P0:将P0口设置为输入或输出,可以用于与外部设备进行数据通信。

- P1:将P1口设置为输入或输出,可以用于与外部设备进行数据通信。

- P2:将P2口设置为输入或输出,可以用于与外部设备进行数据通信。

- P3:将P3口设置为输入或输出,可以用于与外部设备进行数据通信。

第二部分:常用的中断控制指令中断是C51单片机中实现实时响应的重要机制之一。

以下是一些常用的中断控制指令:- EA:使能所有中断。

- EX0:外部中断0的控制指令,用于外部设备产生中断信号。

- EX1:外部中断1的控制指令,用于外部设备产生中断信号。

- IT0:外部中断0的触发方式,可以设置为电平触发或边沿触发。

- IT1:外部中断1的触发方式,可以设置为电平触发或边沿触发。

第三部分:常用的定时器控制指令定时器是C51单片机中实现时间计数和定时任务的重要模块。

以下是一些常用的定时器控制指令:- TMOD:设置定时器模式,可以选择定时器0/1的工作模式。

- TL0、TL1:定时器0/1的低8位计数器,用于保存定时值的低8位。

- TH0、TH1:定时器0/1的高8位计数器,用于保存定时值的高8位。

- TR0、TR1:定时器0/1的运行控制位,用于启动和停止计时器。

- TF0、TF1:定时器0/1的溢出标志位,用于判断定时器是否溢出。

第四部分:常用的串口通信指令串口通信是C51单片机中常用的通信方式之一,用于与其他设备进行数据交互。

C51单片机汇编语言指令集

C51单片机汇编语言指令集

C51单片机汇编语言指令集
51汇编语言指令集符号定义表
指令介绍
CY(PSW.7)——进位标志位。

AC(PSW.6)——辅助进位(或称半进位)标志。

F0(PSW.5)——由用户定义的标志位。

RS1(PSW.4)、RS0(PSW.3)——工作寄存器组选择位。

OV(PSW.2)——溢出标志位。

由硬件置位或清零。

PSW.1——未定义位。

P(PSW.0)——奇偶标志位。

位寻址区
20H~2FH单元是位寻址区。

这16个单元(共计16×8=128位)的每一位都赋予了一个位地址,位地址范围为00H~7FH。

位寻址区的每一位都可当作软件触发器,由程序直接进行位处理。

通常可以
把各种程序状态标志、位控制变量存于位寻址区内。

C51(8051)指令集

C51(8051)指令集
51汇编语言指令集
符号定义表
序 号 1 2 3 4 5 6 7 8 9 符号 Rn Direct @Ri #data #data16 Addr16 Addr11 Rel bit 含义 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 8051/31RAM地址(00H~7FH) 8052/32RAM地址(00H~FFH) 8位常数 16位常数 16位的目标地址 11位的目标地址 相关地址 内部数据RAM(20H~2FH)、特殊功能寄存器的直接地址的位
指令介绍
算术运算指令
1 ADD A,Rn 1 1 2 ADD A,direct 2 1 3 ADD A,@Ri 1 1 4 ADD A,#data 2 1 5 ADDC A,Rn 1 1 6 ADDC A,direct 2 1 7 ADDC A,@Ri 1 1 8 ADDC A,#data 2 1 9 SUBB A,Rn 1 1 10 SUBB A,direct 2 1 11 SUBB A,@Ri 1 1 12 SUBB A,0data 2 1 13 INC A 1 1 14 INC Rn 1 1 15 INC direct 2 1 16 INC @Ri 1 1 17 INC DPTR 1 1 说明:将16位的DPTR加1,当DPTR的低字节(DPL)从FFH溢出至00H时,会使高字节(DPH)加1,不影响任何标志位 18 DEC A 1 1 19 DEC Rn 1 1 20 DEC direct 2 1 21 DEC @Ri 1 1 22 MUL AB 1 4 说明:将累加器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 序 指令 号 字节 周期

51单片机指令表汇总

51单片机指令表汇总

51单片机指令表汇总51 单片机是一种广泛应用于电子工程和嵌入式系统开发的微控制器。

要熟练掌握 51 单片机的编程,了解其指令表是至关重要的。

下面就为大家汇总一下 51 单片机的常见指令。

数据传送类指令MOV 指令:这是最基本的数据传送指令,用于在寄存器之间、寄存器与存储器之间传送数据。

例如,“MOV A, 50H”就是将立即数 50H传送到累加器 A 中。

MOVX 指令:用于在片外数据存储器和累加器 A 之间进行数据传送。

比如“MOVX A, @DPTR”,将片外数据存储器中由数据指针 DPTR 所指定单元的内容传送到累加器 A 中。

MOVC 指令:用于访问程序存储器中的数据表格。

“MOVC A, @A+DPTR”是常见的用法。

算术运算类指令ADD 指令:实现加法运算。

像“ADD A, R0”就是将累加器 A 的内容和寄存器 R0 的内容相加,结果存放在累加器 A 中。

ADDC 指令:带进位加法指令。

考虑了上一次运算产生的进位标志。

SUBB 指令:用于减法运算,并且会考虑借位标志。

逻辑运算类指令ANL 指令:进行逻辑与操作。

例如“ANL A, R0”,将累加器 A 和寄存器 R0 的内容进行逻辑与运算,结果存放在累加器 A 中。

ORL 指令:执行逻辑或操作。

XRL 指令:实现逻辑异或运算。

控制转移类指令JC 指令:若进位标志为 1 则跳转。

JZ 指令:若累加器 A 的内容为 0 则跳转。

LJMP 指令:长跳转指令,可以跳转到 64KB 程序存储器空间的任意位置。

位操作类指令SETB 指令:将指定的位设置为 1。

例如“SETB P10”,将 P1 端口的第 0 位置 1。

CLR 指令:把指定的位清零。

这些只是 51 单片机指令的一部分,实际应用中还有更多的指令和组合使用方式。

在编程时,合理选择和运用这些指令能够实现各种复杂的功能。

比如,通过数据传送指令来初始化变量和读取外部数据;利用算术运算指令进行数值计算;借助逻辑运算指令处理逻辑关系;使用控制转移指令实现程序的分支和循环;运用位操作指令控制单个引脚的状态。

C51指令代码

C51指令代码

一、ACALL addr11指令名称:绝对挪用指令指令代码:A10 A9 A8 10001 A7 A6 A5 A4 A3 A2 A1 A0指令功能:构造目的地址,进行子程序挪用。

其方式是以指令提供的11位地址(al0~a0),取代PC的低11位,PC的高5位不变。

操作内容:PC←(PC)+2SP←(SP)+1(SP)←(PC)7~0SP←(SP)+1(SP)←(PC)15~8PC10~0←addrl0~0字节数: 2机械周期:2利用说明:由于指令只给出子程序入口地址的低11位,因此挪用范围是2KB。

二、ADD A,Rn指令名称:寄放器加法指令指令代码:28H~2FH指令功能:累加器内容与寄放器内容相加操作内容:A←(A)+(Rn), n=0~7字节数: 1机械周期;1阻碍标志位:C,AC,OV3、ADD A,direct指令名称:直接寻址加法指令指令代码:25H指令功能:累加器内容与内部RAM单元或专用寄放器内容相加操作内容:A←(A)+(direct)字节数: 2机械周期:1阻碍标志位:C,AC,OV4、ADD A,@Ri ’指令名称:间接寻址加法指令指令代码:26H~27H指令功能:累加器内容与内部RAM低128单元内容相加操作内容:A←(A)+((Ri)), i=0,1字节数: 1机械周期:1阻碍标志位:C,AC,OV五、ADD A,#data指令名称:当即数加法指令指令代码:24H指令功能:累加器内容与当即数相加操作内容:A←(A)+data字节数: 2机械周期:1阻碍标志位:C,AC,OV六、ADDC A,Rn指令名称:寄放器带进位加法指令指令代码:38H~3FH指令功能:累加器内容、寄放器内容和进位位相加操作内容:A←(A)+(Rn)+(C), n=0~7字节数: 1机械周期:1阻碍标志位:C,AC,OV7、ADDC A,direct指令名称:直接寻址带进位加法指令指令代码:35H指令功能:累加器内容、内部RAM低128单元或专用寄放器内容与进位位加操作内容:A←(A)+(direct)+(C)字节数: 2机械周期:1阻碍标志位:C,AC,OV八、ADDC A,@Ri指令名称:间接寻址带进位加法指令指令代码:36H~37H指令功能:累加器内容、内部RAM低128单元内容及进位位相加操作内容:A←(A)+((Ri))+(C), i=0,1字节数: 1机械周期:1阻碍标志位:C,AC,OV九、ADDC A,#data指令名称:当即数带进位加法指令指令代码:34H指令功能:累加器内容、当即数及进位位相加操作内容:A←(A)+data+(C)字节数: 2机械周期:1阻碍标志位:C,AC,OV10、AJMP addr11指令名称:绝对转移指令指令代码:A10 A9 A8 1 0 0 0 1 A7 A6 A5 A4 A3 A2 A1 A0指令功能:构造目的地址,实现程序转移。

C51指令集(比较完善),整洁

C51指令集(比较完善),整洁

38 39 40 41 42 43 44 45 46 47 48 49
XRL A,direct XRL A,@Ri XRL A,#data XRL direct,A XRL direct,#data CLR A CPL A RL A RLC A RR A RRC A SWAP A
2 1 2 2 3 1 1 1 1 1 1 1
指令介绍
算数运算指令
1 ADD A,Rn 1 1 将累加器与寄存器的内容相加,结果存回累加器 2 ADD A,direct 2 1 将累加器与直接地址的内容相加,结果存回累加器 3 ADD A,@Ri 1 1 将累加器与间接地址的内容相加,结果存回累加器 4 ADD A,#data 2 1 将累加器与常数相加,结果存回累加器 5 ADDC A,Rn 1 1 将累加器与寄存器的内容及进位C相加,结果存回累加器 6 ADDC A,direct 2 1 将累加器与直接地址的内容及进位C相加,结果存回累加器 7 ADDC A,@Ri 1 1 将累加器与间接地址的内容及进位C相加,结果存回累加器 8 ADDC A,#data 2 1 将累加器与常数及进位C相加,结果存回累加器 9 SUBB A,Rn 1 1 将累加器的值减去寄存器的值减借位C,结果存回累加器 10 SUBB A,direct 2 1 将累加器的值减直接地址的值减借位C,结果存回累加器 11 SUBB A,@Ri 1 1 将累加器的值减间接地址的值减借位C,结果存回累加器 12 SUBB A,0data 2 1 将累加器的值减常数值减借位C,结果存回累加器 13 INC A 1 1 将累加器的值加1 14 1INC Rn 1 1 将寄存器的值加l 15 INC direct 2 1 将直接地址的内容加1 16 INC @Ri 1 1 将间接地址的内容加1 17 INC DPTR 1 1 数据指针寄存器值加1 说明:将16位的DPTR加1,当DPTR的低字节(DPL)从FFH溢出至00H时,会使高字节(DPH)加1,不影响任何标志位 18 DEC A 1 1 将累加器的值减1 19 DEC Rn 1 1 将寄存器的值减1 20 DEC direct 2 1 将直接地址的内容减1 21 DEC @Ri 1 1 将间接地址的内容减1 22 MUL AB 1 4 将累加器的值与B寄存器的值相乘,乘积的低位字节存回累加器,高位字节存回B寄存器 说明:将累加器A和寄存器B内的无符号整数相乘,产生16位的积,低位字节存入A,高位字节存入B寄存器。如果积大于FFH,则溢出标志位(OV)被设定为1, 而进位标志位为0 23 DIV AB 1 4 将累加器的值除以B寄存器的值,结果的商存回累加器,余数存回B寄存器 说明:无符号的除法运算,将累加器A除以B寄存器的值,商存入A,余数存入B。执行本指令后,进位位(C)及溢出位(OV)被清除为0 24 DA A 1 1 将累加器A作十进制调整,若(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 序 指令 号 字节 周期 动作说明

51单片机汇编指令总结

51单片机汇编指令总结

51单片机汇编指令总结数据传输指令一.片内ram数据传输指令1.以累加器a为目的操作数的指令:mova,rnmova,directmova,@rimova,#data2.以寄存器rn为目的操作数的指令:movrn,amovrn,directmovrn,data3.以轻易地址为目的操作数的指令:movdirect,amovdirect,rnmovdirect1,derect2movdirect,@rimovdirect,#data4.间接地址为目的操作数的指令:mov@ri,amov@ri,directmov@ri,#data5.十六位数据传送指令:movdptr,#data16二.累加器a与片外ram数据传输指令:movxa,@rimovxa,@dptrmovx@ri,amovx@dptr,a三.换算串行:movca,@a+dptr(先pc←(pc)+1,后a←((a)+(dptr)))+movca,@a+pc(先pc←(pc)+1,后a←((a)+(pc)))四.互换指令:1.字节交换指令:xcha,rnxcha,directxcha,@ri2.半字节交换指令:xchda,@ri3.累加器半字节交换指令:swapa五.栈操作指令:1.push(入栈指令)pushdirect2.pop(出栈指令)popdirect算术运算指令:一.乘法加法指令:1.加法指令:adda,rnadda,directadda,@riadda,#data2.拎位次乘法指令:addca,rna←(a)+(rn)+cyaddca,directa←(a)+(direct)+cyaddca,@ria←(a)+((ri))+cyaddca,#dataa←(a)+(data)+cy3.带借位减法指令:subba,rna←(a)-cy-(rn)subba,directa←(a)-cy-(direct)subba,@ria←(a)-cy-((ri))subba,#dataa←(a)-cy-#data二.乘法乘法指令:1.乘法指令:mulabba←(a)×(b)高字节放到b中,低字节放到a中2.乘法指令:divaba←(a)÷(b)的商,(b)←(a)÷(b)的余数三.加1减1指令:1.提1指令:incaa←(a)+1incrnrn←(rn)+1incdirectdirect←(direct)+1inc@ri(ri)←((ri))+1incdptrdptr←(dptr)+12.减至1指令:decadecrndecdirectdec@ri四.十进制调制指令:daa调整累加器a的内容为bcd码逻辑操作方式指令:一.逻辑与、或、异或指令:1.逻辑与指令:anla,rnanla,directanla,@rianla,#data2.逻辑或这而令:orla,rnorla,directorla,@riorla,#dataorldirect,aorldirect,#data3.逻辑异或指令:xrla,rnxrla,directxrla,@rixrla,#dataxrldirect,axrldirect,#data二.清零、row指令:1.累加器a清零指令:crla2.累加器arow指令:cpla三.循环位移指令:1.累加器a循环左移指令:rla2.累加器a循环右移指令:rra3.累加器a连同进位位循环左移指令:rlca4.累加器a连同进位位循环右移指令:rrca控制转移指令:一.无条件迁移指令:1.绝对转移指令:ajmpaddr11(先pc+2,然后将addr11的高十位托付给pc,pc的高六位维持不变)2.长转移指令:ljmpaddr16(用addr16的值替代pc的值)3.相对迁移(长迁移)指令:sjmprel(带符号的偏移字节数)(pc+2,再加rel赋值给pc)4.间接转移指令:jmp@a+dptr(a)+(dptr)→(pc)二.条件转移指令:1.累加器判零迁移指令:jzrel先pc+2;后判断,a为0时转移,pc+rel赋值给pc;否则顺序继续执行jnzrel先pc+2,后判断,a不为0时转移,pc+rel赋值给pc;否则顺序执行2.比较转移指令:cjne目的操作数,源操作数,relcjnea,direct,rel先pc+3传回pc,再比较目的操作数和原操作数cjnea,#data,rel目>源时,程序转移,pc+rel传回pc且cy=0cjnern,#data,rel目=源时,程序顺序执行cjne@ri,#data,rel目djnzrn,rel先pc\\+2,rn-1,当rn为0时程序顺序继续执行,否则pc+rel传到pcdjnzdirect,rel先pc+3,direct-1,direct为0时程序顺序继续执行,否则pc+rel传到pc二.子程序调用、返回指令:1.绝对调用指令acall:acalladdr11先pc+2,sp+1将pc的低八位存入sp;sp+1,将pc的高八位取走sp。

c51汇编语言指令集

c51汇编语言指令集

资料转移指令MOV 移动MOVC 程式记忆体移动MOVX 外部RAM和扩展I/O口与累加器A的数据传送指令PUSH 放入堆叠POP 由堆叠取回XCH 8位元交换XCHD 低4位元交换SWAP 高低4位元交换算术指令ADD 两数相加ADDC 两数相加再加CSUBB 两数相减再减CINC 加一指令DEC 减一指令MUL (MUL AB乘法指令仅此一条)相乘指令,所得的16位二进制数低8位存累加器A高8位存BDIV (DIV AB 除法指令仅此一条)相除指令,所得商存A,余数存BDA (DA A 只此一条指令)调整为十进数逻辑指令ANL做AND(逻辑与)运算ORL做OR(逻辑或)运算XRL 做(逻辑异或)运算CLR 清除为0CPL 取反指令RL 不带进位左环移RLC 带进位左环移RR 不带进位右环移RRC 带进位右环移控制转移类指令JC C=1时跳JNC C=0时跳JB 位元=1时跳JNB 位元=0时跳JBC 位元=1时跳且清除此位元LCALL 长调用子程序ACALL 绝对调用子程序RET 由副程式返回RETI 由中断副程式返回AJMP 绝对转移SJMP 相对转移JMP @A+DPTR 散转,相对DPTR的间接转移JZ A=0时跳JNZA 0时跳CJNE 二数比较,不相等时跳DJNZ 减一,不等於0时跳NOP 空操作位变量指令SETB 设定为1ORG 程序开始,规定程序的起始地址END 程序结束EQU 等值指令(先赋值后使用)例:SUM EQU 30HDB 定义字节指令DW 定义字内容DS 定义保留一定的存贮单元数目BIT 位地址符号指令例:SAM BIT P1.0 RET 子程序返回指令RETI 中断子程序返回指令$ 本条指令地址算术运算指令指令说明周期ADD A,Rn A←A+Rn 12ADD A,direct A←A+direct 12ADD A,@Ri A←A+Ri 12ADD A,#data A←A+data 12ADDC A,Rn A←A+Rn+C 12ADDC A,direct A←A+direct+C 12 ADDC A,@Ri A←A+Ri+C 12ADDC A,#data A←A+data+C 12SU BB A,Rn A←A-Rn-C 12SUBB A,direct A←A-direct-C 12 SUBB A,@Ri A←A-Ri-C 12SUBB A,#data A←A-data-C 12INC A A←A+1 12INC Rn Rn←Rn+1 12INC direct direct←direct+1 12INC @Ri @Ri←@Ri+1 12INC DPTR DPTR←DPTR+1 12DEC A A←A-1 12DEC Rn Rn←Rn-1 12DEC direct direct←direct-1 12DEC @Ri @Ri←@Ri-1 12MUL AB 两个无符号的8位数据相乘,其中高阶8位放入B缓存器,低阶8位则放入累积器ACC 24DIV AB 两个无符号的8位数据相除,把ACC 值除以B缓存器值,商数放回ACC,余数放在B 48DA A 累加器作十进制调整 48逻辑运算指令指令说明周期ANL A,Rn A←A and Rn 12ANL A,direct A←A and direct 12ANL A,@Ri A←A and Ri 12ANL A,#data A←A and data 12ANL direct,A direct←direct and A 12 ANL direct,#data direct←direct and data 24ORL A,Rn A←A or Rn 12ORL A,direct A←A or direct 12ORL A,Rn A←A or Rn 12ORL A,@Ri A←A or Ri 12ORL A,#data A←A or data 12ORL direct,A direct←direct or A 12 ORL direct,#data direct←direct or data 24XRL A,Rn A←A xor Rn 12XRL A,direct A←A xor direct 12XRL A,@Ri A←A xor Ri 12XRL A,#data A←A xor data 12XRL direct,A direct←direct xor A 12 XRL direct,#data dir ect←direct xor data 12CLR A 清除累加器 12CPL A 累加器反相 12RL A 累加器向左旋转 12RLC A 累加器和C左旋 12RR A 累加器向右旋转 12RRC A 累加器和C右旋 12SWAP A 累加器的高低四位互换 12数据转移指令指令说明周期MOV A,Rn A←Rn 12MOV A,direct A←direct 12MOV A,@Ri A←Ri 12MOV A,#data A←data 12MOV Rn,A Rn←A 12MOV Rn,direct Rn←direct 24MOV Rn,#data Rn←data 12MOV direct,A direct←A 12MOV direct,Rn direct←Rn 24MOV direct,direct direct←direct 24 MOV direct,@Ri direct←Ri 24MOV direct,#data direct←data 24MOV @Ri,A Ri←A 12MOV @Ri,direct Ri←direct 24MOV @Ri,#data Ri←data 12MOV DPTR,#data 16 Ri←16bit data 24 MOVC A,@A+DPTR A←程序内存的数据 24 MOVC A,@A+PC A←程序内存的数据 24 MOVX A,@Ri A←外部RAM的数据(8bit地址) 24MOVX A,@DPTR A←外部RAM的数据(16bit地址) 24MOVX @Ri,A 外部的RAM(8bit)←A 24 MOVX @DPTR,A 外部的RAM(16bit)←A 24 PUSH direc 推迭区←direct 24POP direc direct←堆栈区 24XCH A,Rn A和Rn互换 12XCH A,direct A和direct互换 12XCH A,@Ri A和Ri互换 12XCHD A,@Ri A和Ri的低四位互换 12位运算指令指令说明周期CLR C 清除进位旗标 12CLR bit 清除直接位 12SETB C 设定进位旗标 12SETB bit 设定直接位 12CPL C 进位旗标反相 12CPL bit 直接位反相 12ANL C,bit C←C and bit 24ANL C,/bit C←C and bit(反相) 24 ORL C,bit C←C or bit 24ORL C,/bit C←C or bit(反相) 24 MOV C,bit C←bit 12MOV bit,C bit←C 24JC rel 若C=1跳至rel 24JNC rel 若C=0跳至rel 24JB bit,rel 若bit=1跳至rel 24JNB bit,rel 若bit=0跳至rel 24JBC bit,rel 若bit=1跳至rel,且清除此位24程序跳跃指令指令说明周期ACALL addr11 绝对式子程序呼叫 24 LCALL addr16 远程子程序呼叫 24RET 从子程序返回 24RETI 从中断子程序返回 24AJMP addr11 绝对式跳跃 24LJMP addr16 远程跳跃 24SJMP rel 短程跳跃 24JMP @A+DPTR 间接跳跃 24JZ rel 若A=0跳至rel 24JNZ rel 若A不等于0跳至rel 24CJNE A,direct,rel 若A不等于direct跳至rel 24CJNE A,#data,rel 若A不等于data跳至rel 24CJNE Rn,#data,rel 若Rn不等于data跳至rel 24CJNE @Ri,#data,rel 若Ri不等于data跳至rel 24DJNZ Rn,rel Rn减1不等于0跳至rel 24 DJNZ direct,rel direct减1不等于0跳至rel 24NOP 没动作 12缩写符号说明缩写符号说明备注Rn 缓存器R0-R7direct 8bit内部数据存储器,包括1.内部数据存储器(00-7F)的地址2.特殊功能缓存器(80-FF)的地址,如P0,PSW,TMOD..等@Ri 由缓存器R0或R1所寻址的内部RAM数据#data 8bit常数#data 16 16bit常数addr 16 16bit的目的地址,可使跳跃指令跳跃64kaddr 11 11bit的目的地址,可使跳跃指令跳跃2krel 具正负号的8位地址偏移量,用于相对地址的跳跃bit 1个bit:只所有可以位寻址的位。

c51指令集

c51指令集

c51指令集CIP-51指令集:助记符字节数周期数功能说明1:算术操作类指令:ADD A,Rn 1 1寄存器加到累加器ADD A,direct 2 2直接寻址字节加到累加器ADD A,@Ri 1 2间址RAM加到累加器ADD A,#data 2 2立即数加到累加器ADDC A,Rn 1 1寄存器加到累加器(带进位) ADDC A,direct 2 2直接寻址字节加到累加器(带进位) ADDC A,@Ri 1 2 间址RAM加到累加器(带进位) ADDC A,#data 2 2 立即数加到累加器(带进位) SUBB A,Rn 1 1累加器减去寄存器(带借位)SUBB A,direct 2 2累加器减去间接寻址RAM(带借位) SUBB A,@Ri 1 2 累加器减去间址RAM(带借位) SUBB A,#data 2 2 累加器减去立即数(带借位)INC A 1 1累加器加1INC Rn 1 1寄存器加1INC direct 2 2直接寻址字节加1INC @Ri 1 2间址RAM加1DEC A 1 1累加器减1DEC Rn 1 1寄存器减1DEC direct 2 2直接寻址字节减1DEC @Ri 1 2间址RAM减1INC DPTR 1 1数据地址加1MUL AB 1 4累加器和寄存器B加乘DIV AB 1 8累加器除以寄存器BDA A 1 1累加器十进制调整2:逻辑操作类指令:ANL A,Rn 1 1寄存器“与”到累加器ANL A,direct 2 2直接寻址字节“与”到累加器ANL A,@Ri 1 2间址RAM“与”到累加器ANL A,#data 2 2立即数“与”到累加器ANL direct,A 2 2累加器“与”到直接寻址字节ANL direct,#data 3 3 立即数“与”到直接寻址字节ORL A,Rn 1 1寄存器“或”到累加器ORL A,direct 2 2直接寻址字节“ORL A,@Ri 1 2间址RAM“或”到累加器ORL A,#data 2 2立即数“或”到累加器ORL direct,A 2 2累加器“或”到直接寻址字节ORL direct,#data 3 3 立即数“或”到直接寻址字节XRL A,Rn 1 1寄存器“异或”到累加器XRL A,direct 2 2直接寻址数“异或”到累加器XRL A,@Ri 1 2间址RAM“异或”到累加器XRL A,#data 2 2立即数“异或”到累加器XRL direct,A 2 2累加器“异或”到直接寻址字节XRL direct,#data 3 3 立即数“到直接寻址字节CLR A 1 1累加器清零CPL A 1 1累加器求反RL A 1 1循环循环左移RLC A 1 1经过进位位的累加器循环左移RR A 1 1累加器循环右移RRC A 1 1经过进位位的累加器循环右移SWAP A 1 1累加器内高低半字节交换3:数据传输类指令:MOV A,Rn 1 1寄存器传送到累加器A MOV A,direct 2 2直接寻址字节传送到累加器MOV A,@Ri 1 2间址RAM传送到累加器MOV A,#data 2 2立即数传送到累加器MOV Rn,A 1 1累加器传送到寄存器MOV Rn,direct 2 2直接寻址字节传送到寄存器MOV Rn,#data 2 2立即数传送到寄存器MOV direct,A 2 2累加器传送到直接寻址字节MOV direct,Rn 2 2寄存器传送到直接寻址字节MOV direct,direct 3 3直接寻址字节传送到直接寻址字节MOV direct,@Ri 2 2间址RAM传送到直接寻址字节MOV direct,#data 3 3立即数传送到直接寻址字节MOV @Ri,A 1 2累加器传送到间址RAMMOV @Ri,direct 2 2直接寻址数传送到间址RAMMOV @Ri,#data 2 2立即数传送到间址RAMMOV DPTR,#data16 3 316位常数装入数据指针MOVC A,@A+DPTR 1 3相对于DPTR的代码字节传送到累加器MOVC A,@A+PC 1 3 相对于PC的代码字节传送到累加器MOVX A,@Ri 1 3外部RAM(8位地址)数传送到A MOVX @Ri,A 1 3累加器传到外部RAM(8位地址)MOVX A,@DPTR 1 3外部RAM(16位地址)传送到A MOVX @DPTR,A 1 3 累加器传到外部RAM(16位地址)PUSH direct 2 2 直接寻址字节压入栈顶POP direct 2 2栈顶数据弹出到直接寻址字节XCH A,Rn 1 1寄存器和累加器交换XCH A,direct 2 2直接寻址字节与累加器交换XCH A,@Ri 1 2间址RAM与累加器交换XCHD A,@Ri 1 2间址RAM和累加器交换低半字节4:位操作类指令CLR C 1 1清进位位CLR bit 2 2清直接寻址位SETB C 1 1进位位置1SETB bit 2 2直接寻址位置位CPL C 1 1进位位取反CPL bit 2 2直接寻址位取反ANL C,bit 2 2直接寻址位“与”到进位位ANL C,/bit 2 2直接寻址位的反码“与”到进位位ORL C,bit 2 2直接寻址位“或”到进位位ORL C,/bit 2 2直接寻址位的反码“或”到进位位MOV C,bit 2 2直接寻址位传送到进位位MOV bit,C 2 2进位位传送到直接寻址位JC rel 2 2/3若进位位为1则跳转JNC rel 2 2/3若进位位为零则跳转JB bit,rel 3 3/4若直接寻址位为1则跳转JNB bit,rel 3 3/4若直接寻址位为零则跳转JBC bit,rel 3 3/4若直接寻址位为1则跳转,并清除该位5:控制转移类指令:ACALL addr11 2 3绝对调用子程序LCALL addr16 3 4长调用子程序RET 1 5从子程序返回RETI 1 5从中断返回AJMP addr11 2 3绝对转移LJMP addr16 3 4长转移SJMP rel 2 3短转移(相对偏移)JMP @A+DPTR 1 3相对DPTR的间接转移JZ rel 2 2/3累加器为0则转移JNZ rel 2 2/3累加器为非0则转移CJNE A,direct,rel 3 3/4比较直接寻址字节与A,不相等则转移CJNE A,#data,rel 3 3/4 比较立即数与A,不相等则转移CJNE Rn,#data,rel 3 3/4比较立即数与寄存器,不相等则转移CJNE @Ri,#data,rel 3 4/5比较立即数与间接寻址RAM,不相等则转移DJNZ Rn,rel 2 2/3寄存器减1,不为零则转移DJNZ direct,rel 3 3/4直接寻址字节减1,不为零则转移NOP 1 1空操作注释:Rn –当前选择的寄存器区的寄存器R0-R7。

C51指令表

C51指令表

)→))C51汇编伪指令:1、DS ---预留存储区命令格式:〔标号:〕DS 表达式值其功能是从指定地址开始,定义一个存储区,以备源程序使用。

存储区预留的存储单元数由表达式的值决定。

TMP: DS 1从标号TEP地址处开始保留1个存储单元(字节)。

2、BIT---定义位命令格式:字符名称BIT 位地址其功能用于给字符名称定义位地址。

SPK BIT P3.7经定义后,允许在指令中用SPK代替P3.7。

3、USING指令USING指令通知汇编器使用8051的哪一个工作寄存器组。

格式:USING 表达式(值必须为0-3,默认值为0。

)USING 0使用第0组工作寄存器。

4、SEGMENT指令SEGMENT 指令用来声明一个再定位段和一个可选的再定位类型。

格式:再定位段名SEGMENT 段类型〔再定位类型〕其中,“再定位段名”用于指明所声明的段。

“段类型”用于指定所声明的段将处的存储器地址空间。

可用的段类型有CODE、XDA TA、DA TA、IDA TA和BIT。

STACK_SEG SEGMENT IDA TADA TA_SEG SEGMENT DATA5、RSEG---再定位段选择指令再定位段选择指令为RSEG,用于选择一个已在前面定义过的再定位段作为当前段。

格式:RSEG 段名段名必须是在前面已经声明过的再定位段。

DA TA_SEG SEGMENT DATA ;声明一个再定位DA TA段RSEG DATA_SEG ;选择前面声明的再定位DA TA段作为当前段6、绝对段选择指令CSEG---绝对代码段DSEG---内部绝对数据段XSEG---外部绝对数据段ISEG---内部间接寻址数据段BSEG---绝对位寻址数据段格式:CSEG [AT 绝对地址表达式]DSEG [AT 绝对地址表达式]XSEG [AT 绝对地址表达式]ISEG [AT 绝对地址表达式]BSEG [AT 绝对地址表达式]括号内是可选项,用来指定当前绝对段的基地址。

51单片机汇编指令集(附记忆方法)

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。

(完整版)C51单片机汇编语言指令集,推荐文档

(完整版)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位的内容交换。

C51指令表

C51指令表

42 A 和直接。字节"或"
2 12
ORL dircect,#data 43 立即数和直接字节相"或"
3 24
ORL C,bit
72 直接位和进位相"或"
2 24ORL C,/bit源自A0 直接位的反和进位相"或"
2 24
POP direct
D0 直接字节退栈,SP 减 1
2 24
PUSH direct
1
ADDC A,dircet 35 直接字节、进位位和 A 相加
2
ADDC A,@R
36,37 间接 RAM、进位位和 A 相加
1
ADDC A,dircet 34 立即数、进位位和 A 相加
2
AJMP addrll
Y1** 绝对转移
2
ANL A,Rn
58~5F 寄存器和 A 相”与”
1
ANL A,direct 55 直接字节和 A 相”与"
84 A 除以 B
1 48
DJNE Rn,rel
DB~DF 寄存器减 1,不为零则相对转移
3 24
DJNE direct,rel D5 直接字节减 1,不为零则相对转移 3 24
INC A
04 A 加 1
1 12
INC Rn
08~0F 寄存器加 1
1 12
INC direct
05 直接字节加 1
2 12
(指令中的符号标识) Rn 工作寄存器 R0-R7 Ri 工作寄存器 R0 和 R1 @Ri 间接寻址的 8 位 RAM 单元地址(00H-FFH) #data8 8 位常数 #data16 16 位常数 addr16 16 位目标地址,能转移或调用到 64KROM 的任何地方 addr11 11 位目标地址,在下条指令的 2K 范围内转移或调用 Rel 8 位偏移量,用于 SJMP 和所有条件转移指令,范围-128~+127 Bit 片内 RAM 中的可寻址位和 SFR 的可寻址位 Direct 直接地址,范围片内 RAM 单元(00H-7FH)和 80H-FFH $ 指本条指令的起始位 Rn (n=0~7),当前选中的工作寄存器组 R0~R7。它在片内数据存储器中的地址 由 PSW 中的 RSl 和 RS0 确定,可以是 00H~07H(第 0 组)、08H~0FH(第 1 组)、 10H~17H(第 2 组)或 18H~1FH(第 3 组)。 Ri (i=0,1),当前选中的工作寄存器组中可以用于寄存器间接寻址的的两个工 作寄存器 R0、R1。它在片内数据存储器中的地址由 RSl、RS0 确定,分别有 01H, 02H;08H,09H;10H,11H 和 18H,19H。 #data,8 位立即数,即包含在指令中的 8 位操作数。 #data16,16 位立即数,即包含在指令中的 16 位操作数。 direct,8 位片内 RAM 单元(包括 SFR)的直接地址。 addr11,11 位目的地址,用于 ACALL 和 AJMP 指令中。 addr16,16 位目的地址,用于 LCALL 和 LJMP 指令中。 rel,补码形式的 8 位地址偏移量,以下条指令第一字节地址为基值。

51单片机汇编指令集(附记忆方法)

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。

单片机指令表汇总

单片机指令表汇总

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. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

格式功能简述字节数周期一、数据传送类指令MOV A, Rn 寄存器送累加器 1 1MOV Rn,A 累加器送寄存器 1 1MOV A ,@Ri 内部RAM单元送累加器 1 1MOV @Ri ,A 累加器送内部RAM单元 1 1MOV A ,#data 立即数送累加器 2 1MOV A ,direct 直接寻址单元送累加器 2 1MOV direct ,A 累加器送直接寻址单元 2 1MOV Rn,#data 立即数送寄存器 2 1MOV direct ,#data 立即数送直接寻址单元 3 2MOV @Ri ,#data 立即数送内部RAM单元 2 1MOV direct ,Rn 寄存器送直接寻址单元 2 2MOV Rn ,direct 直接寻址单元送寄存器 2 2MOV direct ,@Ri 内部RAM单元送直接寻址单元 2 2 MOV @Ri ,direct 直接寻址单元送内部RAM单元 2 2 MOV direct2,direct1 直接寻址单元送直接寻址单元 3 2 MOV DPTR ,#data16 16位立即数送数据指针 3 2MOVX A ,@Ri 外部RAM单元送累加器(8位地址) 1 2 MOVX @Ri ,A 累加器送外部RAM单元(8位地址) 1 2 MOVX A ,@DPTR 外部RAM单元送累加器(16位地址) 1 2 MOVX @DPTR ,A 累加器送外部RAM单元(16位地址) 1 2 MOVC A ,@A+DPTR 查表数据送累加器(DPTR为基址) 1 2 MOVC A ,@A+PC 查表数据送累加器(PC为基址) 1 2 XCH A ,Rn 累加器与寄存器交换 1 1XCH A ,@Ri 累加器与内部RAM单元交换 1 1 XCHD A ,direct 累加器与直接寻址单元交换 2 1 XCHD A ,@Ri 累加器与内部RAM单元低4位交换 1 1 SWAP A 累加器高4位与低4位交换 1 1POP direct 栈顶弹出指令直接寻址单元 2 2 PUSH direct 直接寻址单元压入栈顶 2 2二、算术运算类指令ADD A, Rn 累加器加寄存器 1 1ADD A,@Ri 累加器加内部RAM单元 1 1ADD A, direct 累加器加直接寻址单元 2 1ADD A, #data 累加器加立即数 2 1ADDC A, Rn 累加器加寄存器和进位标志 1 1 ADDC A,@Ri 累加器加内部RAM单元和进位标志 1 1 ADDC A, #data 累加器加立即数和进位标志 2 1 ADDC A, direct 累加器加直接寻址单元和进位标志 2 1 INC A 累加器加1 1 1INC Rn 寄存器加1 1 1INC direct 直接寻址单元加1 2 1INC @Ri 内部RAM单元加1 1 1INC DPTR 数据指针加1 1 2DA A 十进制调整 1 1SUBB A, Rn 累加器减寄存器和进位标志 1 1 SUBB A,@Ri 累加器减内部RAM单元和进位标志 1 1 SUBB A, #data 累加器减立即数和进位标志 2 1 SUBB A, direct 累加器减直接寻址单元和进位标志 2 1 DEC A 累加器减1 1 1DEC Rn 寄存器减1 1 1DEC @Ri 内部RAM单元减1 1 1DEC direct 直接寻址单元减1 2 1MUL AB 累加器乘寄存器B 1 4DIV AB 累加器除以寄存器B 1 4三、逻辑运算类指令ANL A, Rn 累加器与寄存器 1 1ANL A,@Ri 累加器与内部RAM单元 1 1ANL A, #data 累加器与立即数 2 1ANL A, direct 累加器与直接寻址单元 2 1ANL direct, A 直接寻址单元与累加器 2 1ANL direct, #data 直接寻址单元与立即数 3 1ORL A, Rn 累加器或寄存器 1 1ORL A,@Ri 累加器或内部RAM单元 1 1ORL A,#data 累加器或立即数 2 1ORL A,direct 累加器或直接寻址单元 2 1ORL direct, A 直接寻址单元或累加器 2 1ORL direct, #data 直接寻址单元或立即数 3 1XRL A, Rn 累加器异或寄存器 1 1XRL A,@Ri 累加器异或内部RAM单元 1 1XRL A,#data 累加器异或立即数 2 1XRL A,direct 累加器异或直接寻址单元 2 1XRL direct, A 直接寻址单元异或累加器 2 1XRL direct, #data 直接寻址单元异或立即数 3 2RL A 累加器左循环移位 1 1RLC A 累加器连进位标志左循环移位 1 1 RR A 累加器右循环移位 1 1RRC A 累加器连进位标志右循环移位 1 1 CPL A 累加器取反 1 1CLR A 累加器清零 1 1四、控制转移类指令类ACCALL addr11 2KB 范围内绝对调用 2 2AJMP addr11 2KB 范围内绝对转移 2 2LCALL addr16 2KB 范围内长调用 3 2LJMP addr16 2KB 范围内长转移 3 2SJMP rel 相对短转移 2 2JMP @A+DPTR 相对长转移 1 2RET 子程序返回 1 2RET1 中断返回 1 2JZ rel 累加器为零转移 2 2JNZ rel 累加器非零转移 2 2CJNE A ,#data ,rel 累加器与立即数不等转移 3 2CJNE A ,direct ,rel 累加器与直接寻址单元不等转移 3 2 CJNE Rn,#data ,rel 寄存器与立即数不等转移 3 2CJNE @Ri ,#data,rel RAM 单元与立即数不等转移 3 2DJNZ Rn ,rel 寄存器减1不为零转移 2 2DJNZ direct ,rel 直接寻址单元减1不为零转移 3 2 NOP 空操作 1 1五、布尔操作类指令MOV C, bit 直接寻址位送C 2 1MOV bit, C C 送直接寻址位 2 1CLR C C 清零 1 1CLR bit 直接寻址位清零 2 1CPL C C 取反 1 1CPL bit 直接寻址位取反 2 1SETB C C 置位 1 1SETB bit 直接寻址位置位 2 1ANL C, bit C 逻辑与直接寻址位 2 2ANL C, /bit C 逻辑与直接寻址位的反 2 2ORL C, bit C 逻辑或直接寻址位 2 2ORL C, /bit C 逻辑或直接寻址位的反 2 2JC rel C为1 转移 2 2JNC rel C为零转移 2 2JB bit,rel 直接寻址位为1转移 3 2JNB bit,rel 直接寻址为0转移1、D1~D8八个彩灯按规定顺序依次点亮(间隔1秒),最后全亮;2、按规定顺序依次熄灭(间隔1秒),最后全灭;3、八个灯同时点亮,保持1秒;4、八个灯同时熄灭,保持0.5秒;再将第3、4步重复4遍,最后整个程序再重复N遍。

5、让八个灯依次显示为0100 1001 1.假设1:D1~D8八个彩灯接在P1口,输出低电平发光 2.假设2:系统晶振为12MHz 3.假设3:N = 5ORG 0000HMOV R3, #5 ;N=5LOOP0:MOV A, #0FFHMOV P1, #0FFH ;开始时全灭;-------------------------------逐个点亮MOV R2, #8LOOP1: CLR CRLC AMOV P1, ACALL DL500MSDJNZ R2, LOOP1;-------------------------------逐个熄灭MOV R2, #8LOOP2: SETB CRLC AMOV P1, ACALL DL500MSDJNZ R2, LOOP2;-------------------------------全亮、全灭交替MOV R2, #4LOOP3: MOV P1, #0 ;全亮CALL DL500MSCALL DL500MS ;共1sMOV P1, #255 ;全灭CALL DL500MS ;0.5sDJNZ R2, LOOP3;-------------------------------DJNZ R3, LOOP0MOV P1, #01001001B ;5、显示为0100 1001CALL DL500MSCALL DL500MS ;共1sSJMP 0000H ;重新开始N遍;-------------------------------延时子程序DL500MS:MOV R5, #9 ;1TDL1: MOV R6, #128 ;1TDL2: MOV R7, #215 ;1TNOP ;1TDL3: DJNZ R7, DL3 ;2T 2 * 215 = 430 TDJNZ R6, DL2 ;2T [1+1+430+2] * 128 = 55552 T DJNZ R5, DL1 ;2T [1+55552+2] * 9 = 499995 T RET ;2T 1 + 499995 + 2 = 499998 T ;-------------------------------------END。

相关文档
最新文档