51单片机指令
51单片机汇编指令详解
51单片机汇编指令详解mcs-51系列单片机指令目录:1、a2、x3、r4、s5、n6、o7、p8、m9、j10、l11、d12、i13、c一、以a结尾的指令存有18条,分别为:acalladdr11adda,rnadda,directadda,@riadda,#dataaddca,rnaddca,directaddca,@riaddca,#dataajmpaddr11anla,rnanla,directanla,@rianla,#dataanldirect,aanldirect,#dataanlc,bitanlc,/bit1、acalladdr11指令名称:绝对调用指令指令代码:{a10,a9,a8,10001},a[7:0]指令功能:结构目的地址,展开子程序调用。
其方法就是以指令提供更多的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。
2、adda,rn指令名称:寄存器乘法指令指令代码:28h~2fh指令功能:累加器内容与寄存器内容相加操作内容:a←(a)+(rn),n=0~7字节数:1机器周期;1影响标志位:c,ac,ov3、adda,direct指令名称:轻易串行乘法指令指令代码:25h指令功能:累加器内容与内部ram单元或专用寄存器内容相加操作内容:a←(a)+(direct)字节数:2机器周期:1影响标志位:c,ac,ov4、adda,@ri指令名称:间接串行乘法指令指令代码:26h~27h指令功能:累加器内容与内部ram高128单元内容相乘操作方式内容:a←(a)+((ri)),i=0,1字节数:1机器周期:1影响标志位:c,ac,ov5、adda,#data指令名称:立即数加法指令指令代码:24h指令功能:累加器内容与立即数相乘操作方式内容:a←(a)+data字节数:2机器周期:1影响标志位:c,ac,ov6、addca,rn指令名称:寄存器带进位加法指令指令代码:38h~3fh指令功能:累加器内容、寄存器内容和位次位相乘操作方式内容:a←(a)+(rn)+(c),n =0~7字节数:1机器周期:1影响标志位:c,ac,ov7、addca,direct指令名称:直接寻址带进位加法指令指令代码:35h指令功能:累加器内容、内部ram高128单元或专用寄存器内容与位次位加操作内容:a←(a)+(direct)+(c)字节数:2机器周期:1影响标志位:c,ac,ov8、addca,@ri指令名称:间接串行拎位次乘法指令指令代码:36h~37h指令功能:累加器内容、内部ram低128单元内容及进位位相加操作方式内容:a←(a)+((ri))+(c),i=0,1字节数:1机器周期:1影响标志位:c,ac,ov9、addca,#data指令名称:立即数带位次乘法指令指令代码:34h指令功能:累加器内容、立即数及进位位相加操作内容:a←(a)+data+(c)字节数:2机器周期:1影响标志位:c,ac,ov10、ajmpaddr11指令名称:绝对迁移指令指令代码:{a10,a9,a8,00001},a[7:0]指令功能:构造目的地址,实现程序转移。
51系列单片机指令表
E5direct
2
1
MOVdirect.A
累加器A送直接寻址单元
F5direct
2
I
MOVRn.#data
立即数送寄存器
78~7Fdata
2
I
MOVdirect,#data
立即数送直接寻址单元
75directdata
3
2
MOV@Ri,#data
立即数送内部RAM单元
76~77data
2
1
MOVdirect,Rn
寄存器送直接寻址单元
88~8Fdireci
2
2
MOVRn.direct
直接寻址单元送寄存器
A8~AFdirect
2
2
MOVdirect.@Ri
内部RAM单元送直接寻址单元
86~87direct
2
2
MOV@Ri,direct
直接寻址单元送内部RAM单元
A6-A7direct
DOdireci
2
2
PUSHdirect
直接寻址单元压入栈顶
COdirect
2
2
算术运算类指令
指令
功能简述
指令代码
字节
数
T
ADDA,Rn
累加器A加寄存器
28-2F
1
1
ADDA.@Ri
累器A加内部RAM单元
26-27
1
I
ADDA.direct
照加器A加直接寻址单元
25direct
2
1
ADDA.#data
盛加器A与寄存器交换
C8~CF
1
1
XCHA,@Ri
51单片机指令大全
51单片机指令大全1 MOV A,Rn 寄存器内容送入累加器2 MOV A,direct 直接地址单元中的数据送入累加器3 MOV A,@Ri 间接RAM 中的数据送入累加器4 MOV A,#tata 立即数送入累加器5 MOV Rn,A 累加器内容送入寄存器6 MOV Rn,direct 直接地址单元中的数据送入寄存器7 MOV Rn,#data 立即数送入寄存器8 MOV direct,A 累加器内容送入直接地址单元9 MOV direct,Rn 寄存器内容送入直接地址单元10 MOV direct,direct 直接地址单元中的数据送入另一个直接地址单元11 MOV direct,@Ri 间接RAM 中的数据送入直接地址单元12 MOV direct,#data 立即数送入直接地址单元13 MOV @Ri,A 累加器内容送间接RAM 单元14 MOV @Ri,direct 直接地址单元数据送入间接RAM 单元15 MOV @RI,#data 立即数送入间接RAM 单元16 MOV DRTR,#dat16 16 位立即数送入地址寄存器17 MOVC A,@A+DPTR 以DPTR为基地址变址寻址单元中的数据送入累加器18 MOVC A,@A+PC 以PC 为基地址变址寻址单元中的数据送入累加器19 MOVX A,@Ri 外部RAM(8 位地址)送入累加器20 MOVX A,@DPTR 外部RAM(16 位地址)送入累加器21 MOVX @Ri,A 累计器送外部RAM(8 位地址)22 MOVX @DPTR,A 累计器送外部RAM(16 位地址)23 PUSH direct 直接地址单元中的数据压入堆栈24 POP direct 弹栈送直接地址单元25 XCH A,Rn 寄存器与累加器交换26 XCH A,direct 直接地址单元与累加器交换27 XCH A,@Ri 间接RAM 与累加器交换28 XCHD A,@Ri 间接RAM 的低半字节与累加器交换算术操作类指令:1 ADD A,Rn 寄存器内容加到累加器2 ADD A,direct 直接地址单元的内容加到累加器3 ADD A,@Ri 间接ROM 的内容加到累加器4 ADD A,#data 立即数加到累加器5 ADDC A,Rn 寄存器内容带进位加到累加器6 ADDC A,direct 直接地址单元的内容带进位加到累加器7 ADDC A,@Ri 间接ROM 的内容带进位加到累加器8 ADDC A,#data 立即数带进位加到累加器9 SUBB A,Rn 累加器带借位减寄存器内容10 SUBB A,direct 累加器带借位减直接地址单元的内容11 SUBB A,@Ri 累加器带借位减间接RAM 中的内容12 SUBB A,#data 累加器带借位减立即数13 INC A 累加器加114 INC Rn 寄存器加115 INC direct 直接地址单元加116 INC @Ri 间接RAM 单元加117 DEC A 累加器减118 DEC Rn 寄存器减1 1 1219 DEC direct 直接地址单元减120 DEC @Rj 间接RAM 单元减 121 INC DPTR 地址寄存器DPTR 加 122 MUL AB A 乘以B,结果放在A23 DIV AB A 除以B,结果放在A24 DA A 累加器十进制调整布尔变量操作类指令:1 CLR C 清进位位2 CLR bit 清直接地址位3 SETB C 置进位位4 SETB bit 置直接地址位5 CPL C 进位位求反6 CPL bit 置直接地址位求反7 ANL C,bit 进位位和直接地址位相“与”8 ANL C,bit 进位位和直接地址位的反码相“与”9 ORL C,bit 进位位和直接地址位相“或”10 ORL C,bit 进位位和直接地址位的反码相“或”11 MOV C,bit 直接地址位送入进位位12 MOV bit,C 进位位送入直接地址位13 JC rel 进位位为1 则转移14 JNC rel 进位位为0 则转移15 JB bit,rel 直接地址位为1 则转移16 JNB bit,rel 直接地址位为0 则转移17 JBC bit,rel 直接地址位为1 则转移,该位清零逻辑操作数指令:1 ANL A,Rn 累加器与寄存器相“与”2 ANL A,direct 累加器与直接地址单元相“与”3 ANL A,@Ri 累加器与间接RAM 单元相“与”4 ANL A,#data 累加器与立即数相“与”5 ANL direct,A 直接地址单元与累加器相“与”6 ANL direct,#data 直接地址单元与立即数相“与”7 ORL A,Rn 累加器与寄存器相“或”8 ORL A,direct 累加器与直接地址单元相“或”9 ORL A,@Ri 累加器与间接RAM 单元单元相“或”10 ORL A,#data 累加器与立即数相“或”11 ORL direct,A 直接地址单元与累加器相“或”12 ORL direct,#data 直接地址单元与立即数相“或”13 XRL A,Rn 累加器与寄存器相“异或”14 XRL A,direct 累加器与直接地址单元相“异或”15 XRL A,@Ri 累加器与间接RAM 单元单元相“异或”16 XRL A,#data 累加器与立即数相“异或”17 XRL direct,A 直接地址单元与累加器相“异或”18 XRL direct,#data 直接地址单元与立即数相“异或”19 CLR A 累加器清“0”20 CPL A 累加器求反21 RL A 累加器循环左移22 RLC A 累加器带进位位循环左移23 RR A 累加器循环右移24 RRC A 累加器带进位位循环右移25 SWAP A 累加器半字节交换控制转移类指令:1 ACALL addr11 绝对(短)调用子程序2 LCALL addr16 长调用子程序3 RET 子程序返回4 RETI 中数返回5 AJMP addr11 绝对(短)转移6 LJMP addr16 长转移7 SJMP rel 相对转移8 JMP @A+DPTR 相对于DPTR 的间接转移9 JZ rel 累加器为零转移10 CJNE rel 累加器非零转移11 CJNE A,direct,rel 累加器与直接地址单元比较,不相等则转移12 CJNE A,#data,rel 累加器与立即数比较,不相等则转移13 CJNE Rn,#data,rel 寄存器与立即数比较,不相等则转移14 CJNE @Ri,#data,rel 间接RAM 单元与立即数比较,不相等则转移15 DJNZ Rn,rel 寄存器减1,非零转移16 DJNZ direct,erl 直接地址单元减1,非零转移17 NOP 空操作。
常见51单片机指令及详解
常见51单片机指令及详解1. 简介单片机是一种集成电路,具备处理和控制功能。
51单片机是指Intel公司推出的一系列8位单片机,常用于嵌入式系统和物联网设备。
本文将介绍一些常见的51单片机指令,并对其进行详解。
2. 数据传送指令2.1 MOV指令MOV指令用于将数据从一个寄存器或内存位置传送到另一个寄存器或内存位置。
例如:MOV A, #10 ;将立即数10传送给累加器AMOV R0, R1 ;将寄存器R1的值传送给R02.2 XCH指令XCH指令用于交换两个寄存器或内存位置中的数据。
例如:XCH A, B ;交换累加器A和B的值3. 算术运算指令3.1 ADD指令ADD指令用于将两个操作数相加,并将结果保存在累加器中。
例如:ADD A, B ;将累加器A和寄存器B的值相加,结果存储在A中3.2 SUBB指令SUBB指令用于将第二个操作数的补码与累加器的值相减,并将结果存储在累加器中。
例如:SUBB A, B ;将B的补码与累加器A的值相减,结果存储在A中4. 逻辑运算指令4.1 ANL指令ANL指令用于对两个操作数进行按位与运算,并将结果存储在目的操作数中。
例如:ANL A, B ;将累加器A和寄存器B的值按位与,结果存储在A 中4.2 ORL指令ORL指令用于对两个操作数进行按位或运算,并将结果存储在目的操作数中。
例如:ORL A, B ;将累加器A和寄存器B的值按位或,结果存储在A 中5. 跳转指令5.1 JMP指令JMP指令用于无条件跳转至指定的目标地址。
例如:JMP 2000H ;跳转至内存地址2000H处执行指令5.2 JZ指令JZ指令用于在累加器为零时跳转至指定的目标地址。
例如:JZ 3000H ;当累加器为零时,跳转至内存地址3000H处执行指令6. 输入输出指令6.1 IN指令IN指令用于将外部设备的数据输入到累加器或指定的寄存器中。
例如:IN A, P1 ;将P1端口的数据输入到累加器A中6.2 OUT指令OUT指令用于将累加器或指定的寄存器中的数据输出到外部设备。
51单片机指令
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位地址。
包含0—127(255)内部存储单元地址和特殊功能寄存地址。
#data—指令中的8位常数。
#data16—指令中的16位常数。
addr16—用于LCALL和LJMP指令中的16目的地地址,目的地址的空间为64kB程序存储器地址。
#addr11—用于ACALL和AJMP指令中的11目的地地址,目的地址必须放在与下条指令第一个字节同一个2kB程序存储器空间之中。
rel—8位带符号的偏移字节,用于所有的条件转移和SJMP等指令中,偏移字节对于下条指令的第一个字节开始的-128——+127范围内。
@—间接寄存器寻址或基址寄存器的前缀。
/—为操作的前缀,声明对该位操作书取反。
DPTR—数据指针。
bit—内部RAM和特殊功能寄存器的直接寻址位。
A—累加器。
B—累加器B。
用于乘法和除法指令中。
C—进位标志位。
(x)—某地址单元中的内容。
((x))—由X寻址单元中的内容。
MCS-51的寻址方式[1].直接寻址指令中操作数直接以单元地址形式出现,例如:MOV A,68H这条指令的意义是把内部RAM中的68H单元中的数据内容传送到累加器A中。
值得注意的是直接寻址方式只能使用8位二进制地址,因此这种寻址方式仅限于内部RAM进行寻址。
低128位单元在指令中直接以单元地址的形式给出。
对于特殊功能寄存器可以使用其直接地址进行访问,还可以以它们的符号形式给出,只是特殊功能寄存器只能用直接寻址方式访问,而无其它方法。
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 单片机指令的一部分,实际应用中还有更多的指令和组合使用方式。
在编程时,合理选择和运用这些指令能够实现各种复杂的功能。
比如,通过数据传送指令来初始化变量和读取外部数据;利用算术运算指令进行数值计算;借助逻辑运算指令处理逻辑关系;使用控制转移指令实现程序的分支和循环;运用位操作指令控制单个引脚的状态。
MCS-51单片机的指令
MCS-51单⽚机的指令MCS-51单⽚机的指令⼀.数据传送类指令(29条).1 通⽤传送指令(16条)格式:MOV ⽬的操作数,源操作数功能:把第⼆操作数指定的字节内容传送到第⼀操作数指定的单元中。
不影响源操作数内容,不影响别的寄存器和标志。
根据⽬的操作数的不同,通⽤传送指令⼜分为以下⼏种类型:1.1 以累加器A为⽬的操作数的传送类指令(4条)指令助记符及功能说明如下:⽬的操作数源操作数功能说明源操作数寻址⽅式MO V A, direct ;(A)←(direct)直接寻址MO V A, @Ri ;(A)←((Ri))寄存器间接寻址MO V A, Rn ;(A)←(Rn)寄存器寻址MO A, #data ;(A)←data ⽴即寻址V这类指令的功能是将源操作数送到⽬的操作数A中。
指令执⾏后的结果:除了奇偶标志P始终跟踪A中数据的奇偶性外,不影响PSW中的其他标志位。
1.2 以Rn为⽬的操作数的传送类指令(3条)指令助记符及功能说明如下:⽬的操作数源操作数功能说明源操作数寻址⽅式MOVRn, A ;(Rn)←(A) 寄存器寻址MO V Rn, direct ;(Rn)←(direct)其中,Rn是R0,…,R7中的任意⼀个。
例1 若(A)=20H,则执⾏指令MOV R3, A后,(R3)=20H。
注意:Rn寄存器之间不能直接传送数据。
如指令“MOV R1, R7”是错误的。
该类指令执⾏后,不影响PSW中的标志位。
1.3. 以直接地址directX为⽬的操作数的传送类指令(5条)指令助记符及功能说明如下:⽬的操作数源操作数功能说明源操作数寻址⽅式M OV directX, A ;(directX)←(A)寄存器寻址M directX, Rn ;(directX)←寄存器寻址OV (Rn)M OV directX, directY ;(directX)←(directY)直接寻址M OV directX, @Ri ;(directX)←((Ri))寄存器间接寻址M OV directX, #data ;(directX)←data⽴即寻址这类指令的功能是把源操作数的内容送到直接地址directX中去。
单片机MC51指令表
MCS-51单片机操作数共有5种操作数1、立即数( 常数) #data 例 #20、#14H 、#00010100B2、寄存器 R0~R7、 A 、 B 、 DPTR 等3、存储器4、位操作数5、相对转移地址 relMCS-51单片机操作数1、立即数(常数)操作数 #data例 #20、#14H 、#00010100B例:1)、 MOV A , #14H2)、 MOV R0, #20称为立即数寻址方式2、寄存器操作数 R0~R7、 A 、 B 、 DPTR(1)4组通用工作寄存区共32个工作寄存器。
(2)部分特殊功能寄存器,例如A 、B 以及数据指针寄存器DPTR 等。
例: 1)、 MOV A , R12)、 MOV R5, #00010100B3)MOV DPTR, #1000H称为寄存器寻址方式3、存储器操作数 片内RAM 器 片外RAM ROM片内RAM 器片外RAMROM1)、片内RAM表示方法a、直接地址表示00H~7FH、80H~FFH中21个SFR例MOV A , 30HMOV A , P1 或MOV A , 90H称为直接寻址方式b、寄存器间接地址表示为@R0 、@R1例MOV A , @R1 (假设R1=0030H)称为寄存器间接寻址方式2)、片外RAM表示方法(只能寄存器间接表示)a、8位寄存器间接地址表示为@R0、@R1例MOVX A , @R0 (假设R0=0040H)b、16位寄存器间接地址表示为@DPTR例MOVX A , @DPTR (假设DPTR=1020H) 称为寄存器间接寻址方式3)、ROM表示方法(只能寄存器间接表示)@A+PC、@A+DPTRCPU对ROM的访问用MOVC指令格式1:MOVC A , @A+DPTR格式2:MOVC A , @A+PC格式2: JMP @A+DPTR其中@A+DPTR 与@A+PC表示ROM中某个单元称为基址寄存器加变址寄存器寻址方式4 位操作数位操作数为片内RAM的位寻址区20H~2FH( 位地址00~7FH)及特殊功能寄存器中的可寻址位。
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。
51单片机指令集
51单片机指令集在嵌入式系统的开发中,51单片机是一种常用的微控制器,其指令集对于程序设计和功能实现具有重要的意义。
本文将介绍51单片机指令集的组成结构、常用指令及其功能,以及应用示例。
一、指令集的组成结构51单片机指令集由多条指令组成,这些指令按照不同的功能进行分类和编码。
常见的指令分类包括数据传送指令、算术逻辑指令、位操作指令、分支指令和中断指令等。
1. 数据传送指令数据传送指令主要用于数据在寄存器和内存之间的传输。
其中包括将数据从一个寄存器传送到另一个寄存器、将数据从内存读取到寄存器中以及将数据从寄存器写入内存等操作。
例如,MOV指令用于将一个寄存器的值传送到另一个寄存器,如MOV A, B表示将寄存器B中的值传送到寄存器A中。
2. 算术逻辑指令算术逻辑指令主要用于进行算术和逻辑运算。
其中包括加法、减法、乘法、除法、逻辑与、逻辑或、逻辑非等操作。
例如,ADD A, B用于将寄存器A和寄存器B中的值相加,并将结果保存在寄存器A中。
3. 位操作指令位操作指令主要用于对寄存器或内存中的位进行操作。
其中包括位与、位或、位翻转、位置1、位清零等操作。
例如,ORL A, #0x0F用于将寄存器A的低4位与0x0F进行按位或运算,结果保存在寄存器A中。
4. 分支指令分支指令主要用于程序的跳转和循环控制。
其中包括无条件跳转、条件跳转、循环指令等。
例如,JMP 2000H用于无条件跳转到地址2000H处执行指令。
5. 中断指令中断指令主要用于处理外部中断信号,进行程序的中断与恢复。
例如,ENI指令用于允许外部中断的响应,而DISI指令用于禁止外部中断的响应。
二、常用指令及其功能1. MOV指令MOV指令用于将数据传送给目标操作数。
可以将立即数、寄存器或内存中的值传送给目标寄存器或内存。
2. ADD指令ADD指令用于将源操作数与目标操作数相加,并将结果保存在目标操作数中。
SUB指令用于将源操作数与目标操作数相减,并将结果保存在目标操作数中。
51单片机指令集
单片机指令一.MOVMOV A, #DATA MOV A, RnMOV Rn, #DATA MOV Rn, AMOV @Ri, #DATA MOV direct, Rn MOV direct, #DATA MOV Rn, direct MOV DPTR, #DATA16 MOV A, @RiMOV @Ri, AMOV direct, @RiMOV @Ri,directMOV A,directMOV direct,AMOV direct1, direct2 MOVX A, @DPTRMOVX @DPTR, AMOVC A, @A+PCMOVC A, @A+DPTRMOVX A, @RiMOVX @Ri, A二.交换指令三. 堆栈指令XCH A, Rn PUSH directXCH A, dierct POP directXCH A, @RiXCHD A, @Ri四.算数运算指令ADD A, Rn ADDC A, RnADD A, direct ADDC A, directADD A, @Ri ADDC A, @RiADD A, #DATA ADDC A, #DATASUBB A, Rn MUL AB A↓B↑SUBB A, direct DIV ABSUBB A, @Ri DA ASUBB A, #DATAINC A //加一指令DEC A //减一指令INC Rn DEC RnINC @Ri DEC @RiINC direct DEC directINC DPTR五.逻辑运算指令ANL direct, A //ORL XRLANL direct, #DATA CLR AANL A, Rn CPL AANL A, directANL A, @RiANL A, #DATA六.移动操作指令RL A // RLC RR RRC SWAP A //半字节交换指令七.转移控制指令1.无条件转移指令短跳转指令AJMP addr11 ; pc ←(pc)+2, pc10~0← addr11长跳转指令LJMP addr16 ; pc ←(pc)+3, pc10~0← addr16相对跳转指令SJMP rel ; pc ←(pc)+2, pc ←(pc)+rel2.条件转移指令JZ rel JNZ relCJNE A , #DATA , rel CJNE A , direct , rel CJNE Rn , #DATA , rel CJNE @Ri , #DATA , rel DJNZ Rn , rel DJNZ direct , rel3.调用与返回指令RET RETI八.位操作指令MOV bit , C MOV C , bitCLR bit CLR CSETB bit SETB CANL C , bit ANL C , /bitORL C , bit ORL C , /bitCPL C CPL bit位条件转移指令JBC bit,rel 若(bit) = 1则转移并使(bit) = 0JB bit,relJNB bit,relJC rel ( c ) = 1 ,则转移JNC rel九. 伪指令ORG END DB DWDS(空间定义伪指令) EQU BIT ( ST BIT P1.0 )。
51单片机或命令的用法
51单片机或命令的用法51单片机是一种常见的微控制器,广泛应用于各种嵌入式系统中。
以下是51单片机常用指令的用法:1、数据传输指令数据传输指令主要用于在寄存器、内存单元和输入/输出端口之间进行数据传输。
MOV:将源操作数传送到目标操作数。
MOV A, #data:将8位立即数data传送到累加器A中。
MOV R0, R2:将寄存器R2的值传送到寄存器R0中。
MOV @R0, A:将累加器A的值传送到R0所指定的存储单元中。
MOV DPTR, #data:将16位立即数data传送到数据指针DPTR寄存器中。
2、算术指令算术指令主要用于对两个操作数进行算术运算,并将结果存储在目标操作数中。
ADD:将两个操作数相加,并将结果存储在目标操作数中。
ADD A, R1:将累加器A与R1的值相加,将结果存入累加器A中。
ADD A, #data:将累加器A与8位立即数data相加,将结果存入累加器A中。
ADDC:在相加时,将进位标志位C的状态自动加到结果的最低有效位上。
ADDC A, R2:将累加器A与R2的值以及进位标志位C相加,将结果存入累加器A中。
3、控制转移指令控制转移指令主要用于实现程序的跳转和流程控制。
AJMP:无条件跳转到指定地址。
LJMP:长跳转到指定地址。
SJMP:短跳转到指定地址。
4、位操作指令位操作指令主要用于对单个位进行操作。
SETB:设置位。
CLR:清除位。
CPL:取反位。
:定时器是51单片机中的一个重要模块,它可以用来产生精确的定时/计数功能,常用于测量时间间隔或者产生定时中断。
51单片机的定时器有三种工作模式:模式0(工作方式1):当m1,m2设置成0,0时,定时器/计数器就工作在方式0,工作方式0是一种13位定时器/计数器方式,可用来测量外信号的脉冲宽度所持续的时间。
模式1(工作方式2):工作方式1为16位定时器/计数其结构和操作与工作方式0基本相同,唯一的区别是工作方式1的计数器由tl0的8位和th0的8位共同组成16位的计数器,其定时时间为:t=(2^16-t0初值)×时钟周期×12 。
51单片机汇编指令大全
51单片机汇编指令大全()Rn: 表示当前寄存器区的8 个工作寄存器R0~R7Ri: 表示当前寄存器区的R0 或R1,可作地址指针即间址寄存器(i=0 或1)@: 为间接寄存器或基址寄存器的前缀.Direct: 表示8 位内部数据存储单元的地址.它可以是内部RAM 的单元地址0~127.特殊功能寄存器SFR 的地址(128~255)或名称,A: 累加器ACC.B: .特殊功能寄存器B,用于MUL 和DIV 指令中.C: 进位位Cy.#data: 表示包含在指令中的单字节(8 位)立即数.如果用16 位进制表示,后缀字母为”H”,数据范围00~0FFH,不得一字母开头;如果用16 进制表示无须任何后缀,但必须在0~255 之间.#data16: 表示包含在指令中的双字节(16 位)立即数.Adda16: 表示16 位的目的地址.用于LCALL 和LJMP 指令中,目的地址范围是从0000H~FFFFH 的整个64KB 存储地址空间.Adda11: 表示11 位的目的地址.用于ACALL 和AJMP 的指令中,目的地址必须和下一条指令第一个字节同处一页.Rel: 表示8 位带符号的相对偏移量.用语SJMP 和所有的条件转移指令中.偏移量相对于下一条指令的第一个字节计算,在-128~+127 范围内取值.DPTR: 为数据指针,可用作16 位的地址寄存器./: 加在位操作的前面,表示对该位进行非运算.bit: 表示内部可寻址位或特殊功能寄存器中的直接寻址位.(x): 寄存器或地址单元中的内容.((x)): 由x 间接寻址的单元中的内容.←: 表示将箭头右边的内容传送至箭头的左边.$: 当前指令的地址.单片机指令系统(一) 内部数据传送指令(1) 以累加器A 为目的的传送指令:MOV A, #data ;(A)←dataMOV A, direct ;(A)←(direct)MOV A, Rn ;(A)←(Rn)MOV A, @Ri ;(A)← ((Ri))(2) 以通用寄存器Rn 为目的的传送指令:MOV Rn, A ;(Rn)←(A)MOV Rn, direct ; (Rn)<(direct)-MOV Rn, #data: ; (Rn)←(data)(3) 以直接地址为目的的传送指令:MOV direct, A ;(direct)←(A)MOV direct, Rn ; (direct)←(Rn)MOV direct, direct2 ; (direct)←(direct2)MOV direct, @Ri ; (direct)←((Rn))MOV direct, #data ; (direct)←data(4) 以寄存器间接地址为目的的传送指令:MOV @Ri, A ;((Ri))←(A)MOV @Ri, direct ;((Ri))←(direct)MOV @Ri, #data ;((Ri))←data(二) 数据指针赋值指令(16 位数据传送指令)MOV DPTR, #data16;(三) 片外数据传送指令MOVX A, @Ri ;(A)←((Ri))片外MOVX A, @DPTR ;(A)←((DPTR))片外MOVX @Ri, A ;((Ri))片外←(A)MOVX @DPTR, A ;((DPTR))片外←(A)(四) ROM 数据访问指令(查表指令)MOVC A, @A+DPTR ;(A)←((A)+(DPTR))romMOVC A, @A+PC ;(PC)←(PC)+1,(A)←((A)+(PC))rom(五) 堆栈操作指令PUSH direct ;(SP)←(SP)+1,(SP)←(direct)堆栈指针先加1,将数据压入栈顶POP direct ;(direct)←(SP),(SP)←(SP)-1将数据从栈顶弹出存入direct,SP 再减1(六) 数据交换指令(1)整字节(8 位)交换指令:XCH A, Rn ;A 和Rn 中的数互换XCH A, direct ;A 和direct 单元中的数互换XCH A, @Ri ;A 和Ri 间址单元中的数互换(2)半字节交换指令:XCHD A, @Ri ;A 的低4 位Ri 间接单元的低4 位互换,高4 位不动(3)累加器高低半字节交换指令:SWAP A, ;A 的高4 位(D7~D4)和低4 位(D3~D0)互换(七) 加法指令(1)不带Cy 加法指令:ADD A, Rn ;(A)←(A)+(Rn)ADD A, direct ; (A)←(A)+(direct)ADD A, @Ri ; (A)←(A)+((Ri))ADD A, #data ; (A)←(A)+data(2)带进位加法指令:ADDC A, Rn ;(A)←(A) +Cy+(Rn)ADDC A, direct ; (A)←(A) +Cy+(direct)ADDC A, @Ri ; (A)←(A) +Cy+((Ri))ADDC A, #data ; (A)←(A) +Cy+data(3)加1 指令:INC A, ;(A)←(A)+1INC Rn ;(Rn)←(Rn)+1INC @Ri ;((Ri))←((Ri))+1INC direct ;(direct)←(direct)+1INC DPTR ;(FPTR)←(DPTR)+1(八) 减法指令(1)带进位减法指令:SUBB A, Rn ;(A)←(A) -Cy-(Rn)SUBB A, direct ; (A)←(A) -Cy-(direct)SUBB A, @Ri ; (A)←(A) -Cy-((Ri))SUBB A, #data ; (A)←(A) -Cy-data(2)减1 指令:DEC A ;(A)←(A)-1DEC direct ;(direct)←(durect)-1DEC Rn ;(Rn)←(Rn)-1DEC @Ri ;((Ri))←((Ri))-1(九) 乘除指令(1)乘法指令MUL AB ;(B)(A)←(A)*(B)指令功能是把累加器A 和特殊功能寄存器B 中两个8 位无符号整数相乘,并把积的高8 位字节存入B 寄存器,低8 位字节存入累加器A.(2)除法指令DIV AB ;A/B,商存入A,余数存入B指令的功能是把累加器A 中的8 位无符号整数除以寄存器B 中的8 位无符号整数商的整数部分存入累加器A 中,余数保留在B 中.(十) 十进制调整指令DA A(十一) 逻辑运算指令(1) 逻辑与运算指令:ANL A, Rn ;(A)←(A)∧(Rn)ANL A, direct ; (A)←(A)∧(direct)ANL A, @Ri ; (A)←(A)∧((Ri))ANL A, #data ; (A)←(A)∧dataANL direct, A ;(direct)←(A)∧(direct)ANL direct, #data;(direct←(direct)∧data(2) 逻辑或运算指令:ORL A, Rn ;(A)←(A)∨(Rn)ORL A, direct ; (A)←(A)∨(direct)ORL A, @Ri ; (A)←(A)∨((Ri))ORL A, #data ; (A)←(A)∨dataORL direct, A ;(direct)←(A)∨(direct)ORL direct, #data; (direct)←(direct)∨data(3) 逻辑异或运算指令:XRL A, Rn ;(A)←(A)⊙(Rn)XRL A, direct ; (A)←(A)⊙(direct)XRL A, @Ri ; (A)←(A)⊙((Ri))XRL A, #data ; (A)←(A)⊙dataXRL direct, A ;(direct)←(A)⊙(direct)XRL direct, #data; (direct)←(direct)⊙data(4) 累加器清0 和去反指令CLR A ;(A)←0 (累加器清0 指令)CLR A ;(A)←(A) (累加器取反指令)(5) 累加器移位指令:不带进位Cy 循环左移: RL A ;Dn+1←Dn,D0←D7D7 ←D6 ←D5 ←D4 ←D3 ←D2 ←D1 ←D0 ←D7 ……不带进位Cy 循环右移: RR A :Dn+1→Dn,D0→D7D7→ D6→ D5→ D4→ D3→ D2→ D1→ D0→ D7 ……带进位Cy 循环左移: RLC A ;Cy←D7,Dn+1←Dn,D0←CyD7 ←D6 ←D5 ←D4 ←D3 ←D2 ←D1 ←D0 ←Cy ←D7 ……带进位Cy 循环右移: RRC A ;Cy→D7,Dn+1→Dn,D0→CyCy→ D7→ D6→ D5→ D4→ D3→ D2→ D1→ D0→Cy ……(十二) 控制转移指令[1] 无条件转移指令:(1) 长转移指令LJMP addr16 ;(PC)←addr16(2) 绝对转移指令AJMP addr11 ;(PC)←(PC)+2,(PC)10~0←addr11(3) 短转移指令 SJMP rel ;(PC)←(PC)+2+rel(4) 变址寻址转移指令JMP @A+DPTR ;(PC)←(A)+(DPTR)[2] 条件转移指令:(1) 累加器判0 转移指令:JZ rel ;如果(A)=0,跳转到目标语句,否则顺序执行JNZ rel ;如果(A)≠0,跳转到目标语句,否则顺序执行(2) 比较转移指令:CJNZ A, #data, rel ;如果(A)≠data,则跳转到目标语句,否则程序顺序执行CJNZ A direct, rel ;如果(A)≠(direct),则跳转到目标语句,否则程序顺序执行CJNZ Rn #data, rel ;如果(A)≠data,则跳转到目标语句,否则程序顺序执行CJNZ @Ri #data, rel ;如果(A)≠data,则跳转到目标语句,否则程序顺序执行(3) 循环控制转移指令:DJNZ Rn, rel ;(Rn)先减1,如减1 后(Rn)≠0,则跳转到目标语句;否则顺序执行DJNZ firect, rel ;(direct)先减1,如减1 后(direct)≠0,则跳转到目标语句;否则顺序执行(十三) 子程序调用和返回指令(1) 绝对调用指令:ACALL addr11(2) 长调用指令:LCALL addr16(3) 返回指令:RET 子程序返回RETI 中断服务程序返回(十四) 空操作指令NOP 空操作指令是一条特殊指令,单片机在执行该指令时不进行任何操作,只是消耗1 个机器周期的时间,所以该指令长用于延时程序.软件陷阱程序等(十五) 位操作类指令(1) 位传送指令:MOV C,bit ;(Cy)←(bit),bit 位的状态不变MOV bit,C ; (bit) ← (Cy),Cy 位的状态不变(2) 位置位和复位指令:SETB C ;(Cy)←1SETB bit ;(bit)←1CLR C ;(Cy)←0CLR bit ;(bit)←0(3) 位运算指令:ANL C,bit ;(Cy)←(Cy)∧(bit),Cy 位和bit 位相与,结果赋给CyANL C,/bit ;(Cy)←(Cy)∧(bit),Cy 位和bit 位相与,结果赋给CyORL C,bit ;(Cy)←(Cy)∨(bit),Cy 位和bit 位相或,结果赋给CyORL C,/bit ;(Cy)←(Cy) ∨(bit),Cy 位和bit 位相或,结果赋给Cy CPL C ;(Cy)←(Cy),Cy 位取反CPL bit ;(bit)←(bit),bit 位取反(4) 位测试转移指令:(1) 以Cy 位状态为条件的转移指令JC rel ;如果Cy 位=1,跳转到目标语句,否则顺序执行JNC rel ;如果Cy 位=0,跳转到目标语句,否则顺序执行(2) 以指定位状态为条件的转移指令:JB bit, rel ;如果bit=1,跳转到目标语句,否则顺序执行JNB bit, rel ;如果bit=0,跳转到目标语句,否则顺序执行JBC bit, rel ;如果bit=1,跳转到目标语句,同时将bit 位清0;否则顺序执行。
51单片机汇编语言指令教程汇集
51单片机汇编语言指令教程汇集1.MOV指令:MOV指令用于将一个值从一个寄存器或内存位置复制到另一个寄存器或内存位置。
例如,MOVA,将常数10复制到累加器A中。
2.ADD指令:ADD指令用于将两个操作数相加,并将结果保存在目标操作数中。
例如,ADDA,B将寄存器B的值与累加器A的值相加,并将结果保存在累加器A中。
3.SUB指令:SUB指令用于将源操作数减去目标操作数,并将结果保存在目标操作数中。
例如,SUBA,B将寄存器B的值减去累加器A的值,并将结果保存在累加器A中。
4.INC指令:INC指令用于将指定的操作数加1、例如,INCA将累加器A的值加15.DEC指令:DEC指令用于将指定的操作数减1、例如,DECA将累加器A的值减16.JMP指令:JMP指令用于无条件地跳转到指定的地址。
例如,JMP1000h将跳转到地址1000h处执行指令。
9. ACALL指令:ACALL指令用于调用一个子程序,其地址由指令给出,子程序结束后返回到调用指令的下一条指令。
例如,ACALL Subroutine将调用一个名为Subroutine的子程序。
10.RET指令:RET指令用于从子程序返回到调用指令的下一条指令。
例如,RET将从子程序返回。
11.NOP指令:NOP指令用于空操作,即不执行任何操作。
它通常用于延时或填充空白。
以上是一些常用的51单片机汇编语言指令,这些指令可以用于控制I/O口、进行算术运算、执行跳转和调用子程序等。
学习并熟练掌握这些指令,对于编写高效的51单片机汇编程序非常重要。
希望本文提供的51单片机汇编语言指令教程能够帮助你入门和掌握51单片机汇编语言的基本知识。
如果你想深入学习51单片机汇编语言,建议参考相关的教材或在线资源,进行更加系统和全面的学习。
51单片机汇编指令表
以下是一些常见的51单片机(如8051系列)的汇编指令:
1. 数据传送指令:
- MOV:将一个数据或寄存器的值移动到另一个寄存器或存储器位置。
- MOVC:将数据从外部代码存储器复制到累加器或寄存器。
2. 算术运算指令:
- ADD:将累加器与另一个寄存器或存储器中的值相加。
- SUB:从累加器中减去另一个寄存器或存储器中的值。
- INC:将累加器或寄存器的值加1。
- DEC:将累加器或寄存器的值减1。
3. 逻辑运算指令:
- ANL:对累加器和另一个寄存器或存储器中的值进行逻辑与操作。
- ORL:对累加器和另一个寄存器或存储器中的值进行逻辑或操作。
- XRL:对累加器和另一个寄存器或存储器中的值进行逻辑异或操作。
- CPL:对累加器或寄存器中的值进行按位取反操作。
4. 条件分支指令:
- CJNE:比较两个值,并在不相等时跳转到指定的地址。
- DJNZ:递减累加器或寄存器,并在结果不为零时跳转到指定的地址。
5. 跳转指令:
- JMP:无条件跳转到指定的地址。
- SJMP:短跳转,跳转到相对于当前地址的指定偏移量。
- AJMP:绝对跳转,跳转到指定的地址。
- LCALL:长调用,将当前地址入栈并跳转到指定的子程序地址。
6. 位操作指令:
- SETB:将某个位设置为1。
- CLR:将某个位清零。
- JB:如果某个位为1,则跳转到指定地址。
- JNB:如果某个位为0,则跳转到指定地址。
51单片机位操作指令
51单片机位操作指令51单片机是一种非常常见的嵌入式微控制器,它具有强大的处理能力和广泛的应用领域。
位操作指令是51单片机编程中非常重要的一部分,它们可以直接对单片机的位进行操作,极大地提高了编程的灵活性和效率。
本文将按照不同的类型介绍51单片机的位操作指令。
一、逻辑位操作指令逻辑位操作指令主要用于逻辑运算,包括与、或、非和异或等操作。
其中,与操作用于将两个操作位逻辑相与,结果为1时置位;或操作用于将两个操作位逻辑相或,结果为1时置位;非操作用于将操作位取反,0变1,1变0;异或操作用于两个操作位逻辑相异时置位。
以与操作指令为例,其指令格式如下:ANL A, operand其中,A为累加器,operand为操作数。
执行这条指令后,累加器A的每一位与操作数operand的对应位进行逻辑与运算,结果为1时,对应位置位。
二、移位位操作指令移位位操作指令用于对操作位进行移位操作,包括循环左移、循环右移、逻辑左移和逻辑右移等。
移位操作可以将二进制数向高位或低位移动一位或多位。
以循环左移指令为例,其指令格式如下:RL A执行这条指令后,累加器A的每一位向左循环移动一位,最高位移到最低位,最低位移到次低位,以此类推。
三、组合位操作指令组合位操作指令可以对多个操作位进行组合操作,包括从一个整数中选择一个位、将选择的位放入目标位置、将目标位置的内容置位、将目标位置的内容清零等操作。
组合位操作指令可以灵活地对位进行选择和设置。
以选择位指令为例,其指令格式如下:B0 mov a, @r0执行这条指令后,将r0所指向的存储单元中的内容,也就是一个8位整数,移到累加器A,并且只取第0位的值。
这样就可以根据需要选取整数的某一个位进行操作。
四、控制位操作指令控制位操作指令主要用于控制操作位的状态,包括置位、清零、翻转和测试等操作。
通过对操作位的状态进行控制,可以实现对系统的控制和管理。
以测试位指令为例,其指令格式如下:JNB bit, addr执行这条指令后,如果bit位为0,则跳转到地址addr处继续执行程序。
单片机指令表汇总
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)。
3.2 分类指令在介绍各条分类指令之前,将指令中的操作数及注释中的符号说明如下。
Rn:当前指定的工作寄存器组中的Ro-R7(其中n=0,1,2,…,7)。
Ri:当前指定的工作寄存器组中的RO,R1(其中i=0,1)。
(Ri):Ri间址寻址指定的地址单元。
((Ri)):Ri间址寻址指定地址单元中的内容。
dir:8位直接字节地址(在片内RAM和SFR存储空间中)。
#data8:8位立即数。
#datal6:16位立即数。
addrl6:16位地址值。
addrll:11位地址值。
bit:位地址(在位地址空间中)。
rel:相对偏移量(一字节补码数)。
下面介绍各条分类指令的主要功能和操作,详细的指令操作说明及机器码形式可见附录。
3.2.1数据传送与交换类指令共有28条指令,包括以A,Rn,DPTR,直接地址单元,间接地址单元为目的的操作数的指令;访问外部RAM的指令;读程序存储器的指令;数据交换指令以及准栈操作指令。
9.堆栈操作PUSH dir ;SP十1-6P,(dir)一(SP)POP dir ;((SP))一dir,SP-1--P ,例1 SP=07H,(35H)=55H,指令PUSH 35H执行后,55H送入08H地址单元,SP=08H。
例2 SP=13H,(13H)= 1FH,指令POP 25H执行后,1FH压入25H地址单元,SP此时为12H。
综合例 把片内RAM中50H地址单元中的内容与40H地址单元中的内容互换。
方法一(直接地址传送法):MOV A ,50H数据传送与交换类指令是各类指令中数量最多、使用最频繁的一类指令,编程时应能十分熟练地灵活运用3.2.2算术运算类指令共有24条指令,主要包括加、减、乘、除、增量、减量和十进制调整等指令。
其中,大多数指令都同时以A为源操作数之一和目的操作数。
1. 加说明:借位位来自程序状态字PSW中的进位位C,只是在作减法运算时,被用作借位位。
例 A=38H,R1=20H,(20H)=23H,C=1 指令SUBB A,@R1执行后,A=14H。
4.乘法MUL AB ;A×B-BA说明:本指令实现8位无符号乘法。
A,B中各放一个8位乘数,指令执行后,16位积的高位在B中,低位在A中。
例 A=50H,B=40H,指令MUL AB执行后,A=00H,B=32H5.除法DIV AB ;A÷ B-商在A中,余数在B中说明:本指令实现8位无符号除法。
A放被除数,B放除数,指令执行后,A中为商,B 中为 余数。
若除数B=00H,则指令执行后,溢出标志OV=1,且A,B内容不变。
例1 A=28H,B=12H,指令DIV AB执行后,A=02H,B=04H。
例2 A=08H,B=09H,指令DIV AB执行后,A=00H,B=08H。
综合例1 把在R4和R5中的两字节数取补(高位在R4中)CLR CMOV A , R5CPL AINC AMoV R5, AMoV A, R4CPL AADDC A, #00HMOV R4,ASJMP $综合例2 把R7中的无符号数扩大10D倍(设原数小于25D)MOV A ,R7MOV B ,#0AHMUL ABMoV R7, ASJMP $综合例3 把R1R0和R3R2中的2个4位跃D数相加,结果送入R5R4中,如有进位则存于进位位C中。
CLR CMOV A,R0ADD A,R2DA AMOV R4,AMOV A,R1ADDC A,R3DA AMOV R5,ASjMP $在MCS-51系列单片机的算术运算类指令中,乘除法指令是许多8位微处理器和一些8位单片机所没有的,执行时间为4个机器周期。
这种指令对编制比较复杂的运算程序,例如,比例-积分-微分(PID)运算、浮点运算、多字节数乘除运算等是经常要用到的。
3.2.3逻辑运算与循环类指令共有24条指令。
逻辑运算指令主要包括逻辑"与"、"或"、"异或"、求反和清零;循环指令则都是对A的大循环操作,包括有左、右方向以及带与不带进位位的不同循环方式。
例A=16H,指令RR A执行后,A=0BH。
综合例 把R2R3中的16位补码数(高位在R2中)右移一位,并不改变符号。
MOV A ,R2MOV C ,ACC.7 ;把符号位存入进位位CRRC AMOV R2, AMOV A, R3RRC AMOV R3 , ASJMP $3.2.4子程序调用与转移类指令共有14条指令。
子程序调用类有绝对调用和长调用两种;转移类分为无条件转移和条件转移两组。
无条件转移包括绝对转移、长转移、短转移和间接转移;条件转移包括结果为零、结果为 非零、减一后结果为非零以及两数不相等的转移条件,它们全部采用相对转移的方式。
绝对于程序调用和绝对转移指令的机器码形式比较特殊,操作码不是在前面而是在中间,并且调用和转移的范围都只在2K地址范围内,这在使用时应予以注意。
1.绝对调用ACALL addrll ;addrll一PC0-10,PC11-16不变说明:①调用范围 本指令在2K地址范围内的子程序调用。
本指令实现的操作将不改变原PC的高5位(PC1l-15),仅把11位地址addrll送入PC的低11位(PC0-10),以此确定子程序的入口地址。
由于整个64K程序存储器空间被分成32个基本2K地址范围(见表2.1),编程时,必须保证紧接AC从L 指令后面的那一条指令的第一字节与被调用于程序的入口地址在同一2K范围内,否则将不能使用ACALL指令实现这种调用。
②机器码形式 本指令为二字节指令。
设子程序入口地址addrll的各位是a10a9a8a7a6a5a4a3a2a1a。
,则ACALL指令的二进制机器码为a10a9a810001a7a6a5a4a3a2a1a0,其中10001为ACALL指令的操作码。
例 子程序调用指令ACALL在程序存储器中的首地址为0100H,子程序入口地址为0250H。
试确定能否使用ACALL指令实现调用?如果能使用,确定该指令的机器码。
解 因为ACALL指令的首地址在0100H,而ACALL是2字节指令,所以下一条指令的首地址在0102H。
由表2.1可见,0102H和0250H在同一2K地址范围内,故可用ACALL调用。
调用入口地址为0250H的ACALL指令的机器码形式为:0101000101010000B=5150H2,长调用LCALL addrl6 ;addrl6一PCo-l5说明:本指令为64K程序存储器空间中的全范围子程序调用指令,子程序入口地址可在64K地址空间中的任一处。
本指令为3字节指令。
3.无条件转移指令(1)绝对转移AJMP addrll ;addrll一PC0-10说明:①转移范围 本指令为2K地址范围内的转移指令。
对转移目的地址的要求与ACALL指令中对于程序入口地址的要求相同。
②机器码形式 本指令为2字节指令。
设addrll的各位是a10a9a8a7a6a5a4a3a2a1a0,则指令AJMP addrll的二进制机器码为al0a9a800001a7a6a5a4a3a2ala0。
例 绝对转移指令AJMP在程序存储器中的首地址为2500H,要求转移到2250H 地址处执行程序,试确定能否使用AJMP指令实现转移?如能实现,其指令的机器码形式是什么?解 因为AJMP指令的首址为2500H,其下一条指令的首址为2502H,由表2.1可见,2502H与转移目的地址2250H在同一2K地址范围内,故可用AJMP指令实现程序的转移。
指令的机器码:0100000l01010000B=4150H(2)长转移LJMP addrl6 ;addrl6一PC0-15说明:本指令为64K程序存储器空间的全范围转移指令。
转移地址可为16位地址值中的 任一值。
本指令为3字节指令。
(3)短转移SJMP rel ;PC十2十rel-PC说明:本指令为一页地址范围内的相对转移指令。
因为肥l为l字节补码(偏移量),且SJMP rel 指令为2字节指令,所以转移范围为一126D一十129D。
(4)间接转移JMP @A十DPTR ;A十DPTR-PC例1 A=02H,DPTR=2000H,指令JMP @A十DPTR执行后,PC=2002H。
也就是说,程序转移到2002H地址单元去执行。
例2现有一段程序:MOV DPTR ,#TABLEJMP @A十DPTRTABLE:AJMP RoUT0AJMP RoUTlAJMP RoUT2: :AJMP ROUTn根据JMP @A十DPTR指令的操作可知,当A=00H时,程序转入到地址ROUT0处执行;当A=02H时,转到ROUTl处执行……。
可见这是一段多路转移程序,进入的路数由A确定。
因为AJMP指令是2字节指令,所以要求A必定为偶数。
4.条件转移指令(1)累加器为零(非零)转移JZ rel ;A=0则转移(PC十2十rel一PC);A≠0程序顺序执行JNZ rel ;A≠0 则转移(PC+2+rel-PC);A=0程序顺序执行(2)减一非零转移DJNZ Rn,rel; ;Rn一1-Rn,Rn≠ o,则转移(PC十2十re- PC);Rn=0,程序顺序执行DJNZ dir,rel;(dir)一l-dir,(dir)≠0则转移(PC十3十rel-PC); (dir)=o,程序顺序执行说明:UNZ Rn,rel是2字节指令,而DJNz dir,rel是3字节指令,所以在满足转移的条件后,前者是PC十2十rel一PC,而后者是PC十3十rel 一PC。
例 试说明下列一段程序运行后A中的结果。
MOV 23H,# 0AH说明:①CJNE指令都是3字节指令。
②若第一操作数大于或等于第二操作数,则影响标志C=0(如指令CJNE A,dir,rel中A>=(dir)等);若第一操作数小于第二操作数,则C=l(如指令CJNE A,dir,rel中A<(d5r)等)。
利用对C的判断,可使这几条指令实现两操作数相等与否的判断,还可完成两数大小的比较。
例1 R7=56H,指令CJNE R7,#34H,$十08H执行后,程序转移到放本条CJNE指令的首地址($)加08H后的地址单元去执行。
例2 安排程序,要求读Pl端口上的信息,若不为55H则程序停着等待,只有到P1端口为55H时,程序往下顺序执行。
程序为:MOV A, #55HCJNE A, P1,$ '5.相对偏移量rel的求法在短转移和条件转移中,用偏移量rel和转移指令所处的地址值来计算转移的目的地址。
rel是1字节补码值,如rel是正数的补码,程序往前转移;如rel是负数的补码,程序往回转移。
下面介绍计算rel大小的方法。