常用单片机汇编指令.docx
《常用单片机汇编指令.docx》由会员分享,可在线阅读,更多相关《常用单片机汇编指令.docx(14页珍藏版)》请在冰豆网上搜索。
常用单片机汇编指令
常用单片机汇编指令:
1MOVA,Rn寄存器内容送入累加器
2MOVA,direct直接地址单元中的数据送入累加器
3MOVA,@Ri(i=0,1)间接RAM中的数据送入累加器
4MOVA,#data立即数送入累加器
5MOVRn,A累加器内容送入寄存器
6MOVRn,direct直接地址单元中的数据送入寄存器
7MOVRn,#data立即数送入寄存器
8MOVdirect,A累加器内容送入直接地址单元
9MOVdirect,Rn寄存器内容送入直接地址单元
10MOVdirect,direct直接地址单元中的数据送入另一个直接地址单元
11MOVdirect,@Ri(i=0,1)间接RAM中的数据送入直接地址单元
12MOVdirect,#data立即数送入直接地址单元
13MOV@Ri,A(i=0,1)累加器内容送间接RAM单元
14MOV@Ri,direct(i=0,1)直接地址单元数据送入间接RAM单元
15MOV@Ri,#data(i=0,1)立即数送入间接RAM单元
16MOVDRTR,#data1616位立即数送入地址寄存器
17MOVCA,@A+DPTR以DPTR为基地址变址寻址单元中的数据送入累加器
18MOVCA,@A+PC以PC为基地址变址寻址单元中的数据送入累加器
19MOVXA,@Ri(i=0,1)外部RAM(8位地址)送入累加器
20MOVXA,@DPTR外部RAM(16位地址)送入累加器
21MOVX@Ri,A(i=0,1)累计器送外部RAM(8位地址)
22MOVX@DPTR,A累计器送外部RAM(16位地址)
23PUSHdirect直接地址单元中的数据压入堆栈
24POPdirect弹栈送直接地址单元
25XCHA,Rn寄存器与累加器交换
26XCHA,direct直接地址单元与累加器交换
27XCHA,@Ri(i=0,1)间接RAM与累加器交换
28XCHDA,@Ri(i=0,1)间接RAM的低半字节与累加器交换
算术操作类指令:
1ADDA,Rn寄存器内容加到累加器
2ADDA,direct直接地址单元的内容加到累加器
3ADDA,@Ri(i=0,1)间接ROM的内容加到累加器
4ADDA,#data立即数加到累加器
5ADDCA,Rn寄存器内容带进位加到累加器
6ADDCA,direct直接地址单元的内容带进位加到累加器
7ADDCA,@Ri(i=0,1)间接ROM的内容带进位加到累加器
8ADDCA,#data立即数带进位加到累加器
9SUBBA,Rn累加器带借位减寄存器内容
10SUBBA,direct累加器带借位减直接地址单元的内容
11SUBBA,@Ri(i=0,1)累加器带借位减间接RAM中的内容
12SUBBA,#data累加器带借位减立即数
13INCA累加器加1
14INCRn寄存器加1
15INCdirect直接地址单元加1
16INC@Ri(i=0,1)间接RAM单元加1
17DECA累加器减1
18DECRn寄存器减1
19DECdirect直接地址单元减1
20DEC@Rj间接RAM单元减1
21INCDPTR地址寄存器DPTR加1
22MULABA乘以B,结果放在A
23DIVABA除以B,结果放在A
24DAA累加器十进制调整
布尔变量操作类指令:
1CLRC清进位位
2CLRbit清直接地址位
3SETBC置进位位
4SETBbit置直接地址位
5CPLC进位位求反
6CPLbit置直接地址位求反
7ANLC,bit进位位和直接地址位相“与”
8ANLC,/bit进位位和直接地址位的反码相“与”
9ORLC,bit进位位和直接地址位相“或”
10ORLC,/bit进位位和直接地址位的反码相“或”
11MOVC,bit直接地址位送入进位位
12MOVbit,C进位位送入直接地址位
13JCrel进位位为1则转移
14JNCrel进位位为0则转移
15JBbit,rel直接地址位为1则转移
16JNBbit,rel直接地址位为0则转移
17JBCbit,rel直接地址位为1则转移,该位清零
逻辑操作数指令:
1ANLA,Rn累加器与寄存器相“与”
2ANLA,direct累加器与直接地址单元相“与”
3ANLA,@Ri累加器与间接RAM单元相“与”
4ANLA,#data累加器与立即数相“与”
5ANLdirect,A直接地址单元与累加器相“与”
6ANLdirect,#data直接地址单元与立即数相“与”
7ORLA,Rn累加器与寄存器相“或”
8ORLA,direct累加器与直接地址单元相“或”
9ORLA,@Ri累加器与间接RAM单元单元相“或”
10ORLA,#data累加器与立即数相“或”
11ORLdirect,A直接地址单元与累加器相“或”
12ORLdirect,#data直接地址单元与立即数相“或”
13XRLA,Rn累加器与寄存器相“异或”
14XRLA,direct累加器与直接地址单元相“异或”
15XRLA,@Ri累加器与间接RAM单元单元相“异或”
16XRLA,#data累加器与立即数相“异或”
17XRLdirect,A直接地址单元与累加器相“异或”
18XRLdirect,#data直接地址单元与立即数相“异或”
19CLRA累加器清“0”
20CPLA累加器求反
21RLA累加器循环左移
22RLCA累加器带进位位循环左移
23RRA累加器循环右移
24RRCA累加器带进位位循环右移
25SWAPA累加器半字节交换
控制转移类指令
1ACALLaddr11绝对(短)调用子程序
2LCALLaddr16长调用子程序
3RET子程序返回
4RETI中数返回
5AJMPaddr11绝对(短)转移
6LJMPaddr16长转移
7SJMPrel相对转移
8JMP@A+DPTR相对于DPTR的间接转移
9JZrel累加器为零转移
10JNZrel累加器非零转移
11CJNEA,direct,rel累加器与直接地址单元比较,不相等则转移
12CJNEA,#data,rel累加器与立即数比较,不相等则转移
13CJNERn,#data,rel寄存器与立即数比较,不相等则转移
14CJNE@Ri,#data,rel间接RAM单元与立即数比较,不相等则转移
15DJNZRn,rel寄存器减1,非零转移
16DJNZdirect,erl直接地址单元减1,非零转移
17NOP空操作
MCS-51系列单片机指令系统共有111条指令,其中有49条单字节指令、45条双字节指令和17条三字节指令。
MCS-51数据传送指令:
数据传送指令共有29条,数据传送指令一般的操作是把源操作数传送到目的操作数,指令执行完成后,源操作数不变,目的操作数等于源操作数。
如果要求在进行数据传送时,目的操作数不丢失,则不能用直接传送指令,而采用交换型的数据传送指令,数据传送指令不影响标志C,AC和OV,但可能会对奇偶标志P有影响。
[1].以累加器A为目的操作数类指令(4条)
这4条指令的作用是把源操作数指向的内容送到累加器A。
有直接、立即数、寄存器和寄存器间接寻址方式:
MOVA,data;(data)→(A)直接单元地址中的内容送到累加器A
MOVA,#data;#data→(A)立即数送到累加器A中
MOVA,Rn;(Rn)→(A)Rn中的内容送到累加器A中
MOVA,@Ri;((Ri))→(A)Ri内容指向的地址单元中的内容送到累加器A
[2].以寄存器Rn为目的操作数的指令(3条)
这3条指令的功能是把源操作数指定的内容送到所选定的工作寄存器Rn中。
有直接、立即和寄存器寻址方式:
MOVRn,data;(data)→(Rn)直接寻址单元中的内容送到寄存器Rn中
MOVRn,#data;#data→(Rn)立即数直接送到寄存器Rn中
MOVRn,A;(A)→(Rn)累加器A中的内容送到寄存器Rn中
[3].以直接地址为目的操作数的指令(5条)
这组指令的功能是把源操作数指定的内容送到由直接地址data所选定的片内RAM中。
有直接、立即、寄存器和寄存器间接4种寻址方式:
MOVdata,data;(data)→(data)直接地址单元中的内容送到直接地址单元
MOVdata,#data;#data→(data)立即数送到直接地址单元
MOVdata,A;(A)→(data)累加器A中的内容送到直接地址单元
MOVdata,Rn;(Rn)→(data)寄存器Rn中的内容送到直接地址单元
MOVdata,@Ri;((Ri))→(data)寄存器Ri中的内容指定的地址单元中数据送到直接地址单元
[4].以间接地址为目的操作数的指令(3条)
这组指令的功能是把源操作数指定的内容送到以Ri中的内容为地址的片内RAM中。
有直接、立即和寄存器3种寻址方式:
MOV@Ri,data;(data)→((Ri))直接地址单元中的内容送到以Ri中的内容为地址的RAM单元
MOV@Ri,#data;#data→((Ri))立即数送到以Ri中的内容为地址的RAM单元
MOV@Ri,A;(A)→((Ri))累加器A中的内容送到以Ri中的内容为地址的RAM单元
[5].查表指令(2条)
这组指令的功能是对存放于程序存储器中的数据表格进行查找传送,使用变址寻址方式:
MOVCA,@A+DPTR;((A))+(DPTR)→(A)表格地址单元中的内容送到累加器A中
MOVCA,@A+PC;((PC))+1→(A),((A))+(PC)→(A)表格地址单元中的内容送到累加器A中
[6].累加器A与片外数据存储器RAM传送指令(4条)
这4条指令的作用是累加器A与片外RAM间的数据传送。
使用寄存器寻址方式:
MOVX@DPTR,A;(A)→((DPTR))累加器中的内容送到数据指针指向片外RAM地址中
MOVXA,@DPTR;((DPTR))→(A)数据指针指向片外RAM地址中的内容送到累加器A中
MOVXA,@Ri;((Ri))→(A)寄存器Ri指向片外RAM地址中的内容送到累加器A中
MOVX@Ri,A;(A)→((Ri))累加器中的内容送到寄存器Ri指向片外RAM地址中
[7].堆栈操作类指令(2条)
这4类指令的作用是把直接寻址单元的内容传送到堆栈指针SP所指的单元中,以及把SP所指单元的内容送到直接寻址单元中。
这类指令只有两条,下述的第一条常称为入栈操作指令,第二条称为出栈操作指令。
需要指出的是,单片机开机复位后,(SP)默认为07H,但一般都需要重新赋值,设置新的SP首址。
入栈的第一个数据必须存放于SP+1所指存储单元,故实际的堆栈底为SP+1所指的存储单元。
PUSHdata;(SP)+1→(SP),(data)→(SP)堆栈指针首先加1,直接寻址单元中的数据送到堆栈指针SP所指的单元中
POPdata;(SP)→(data)(SP)-1→(SP),堆栈指针SP所指的单元数据送到直接寻址单元中,堆栈指针SP再进行减1操作
[8].交换指令(5条)
这5条指令的功能是把累加器A中的内容与源操作数所指的数据相互交换。
XCHA,Rn;(A)←→(Rn)累加器与工作寄存器Rn中的内容互换
XCHA,@Ri;(A)←→((Ri))累加器与工作寄存器Ri所指的存储单元中的内容互换
XCHA,data;(A)←→(data)累加器与直接地址单元中的内容互换
XCHDA,@Ri;(A3-0)←→((Ri)3-0)累加器与工作寄存器Ri所指的存储单元中的内容低半字节互换
SWAPA;(A3-0)←→(A7-4)累加器中的内容高低半字节互换
[9].16位数据传送指令(1条)
这条指令的功能是把16位常数送入数据指针寄存器。
MOVDPTR,#data16;#dataH→(DPH),#dataL→(DPL)16位常数的高8位送到DPH,低8位送到DPL
MCS-51算术运算指令
算术运算指令共有24条,算术运算主要是执行加、减、乘、除法四则运算。
另外MCS-51指令系统中有相当一部分是进行加、减1操作,BCD码的运算和调整,我们都归类为运算指令。
虽然MCS-51单片机的算术逻辑单元ALU仅能对8位无符号整数进行运算,但利用进位标志C,则可进行多字节无符号整数的运算。
同时利用溢出标志,还可以对带符号数进行补码运算。
需要指出的是,除加、减1指令外,这类指令大多数都会对PSW(程序状态字)有影响。
这在使用中应特别注意。
[1].加法指令(4条)
这4条指令的作用是把立即数,直接地址、工作寄存器及间接地址内容与累加器A的内容相加,运算结果存在A中。
ADDA,#data;(A)+#data→(A)累加器A中的内容与立即数#data相加,结果存在A中
ADDA,data;(A)+(data)→(A)累加器A中的内容与直接地址单元中的内容相加,结果存在A中
ADDA,Rn;(A)+(Rn)→(A)累加器A中的内容与工作寄存器Rn中的内容相加,结果存在A中
ADDA,@Ri;(A)+((Ri))→(A)累加器A中的内容与工作寄存器Ri所指向地址单元中的内容相加,结果存在A中
[2].带进位加法指令(4条)
这4条指令除与[1]功能相同外,在进行加法运算时还需考虑进位问题。
ADDCA,data;(A)+(data)+(C)→(A)累加器A中的内容与直接地址单元的内容连同进位位相加,结果存在A中
ADDCA,#data;(A)+#data+(C)→(A)累加器A中的内容与立即数连同进位位相加,结果存在A中
ADDCA,Rn;(A)+Rn+(C)→(A)累加器A中的内容与工作寄存器Rn中的内容、连同进位位相加,结果存在A中
ADDCA,@Ri;(A)+((Ri))+(C)→(A)累加器A中的内容与工作寄存器Ri指向地址单元中的内容、连同进位位相加,结果存在A中
[3].带借位减法指令(4条)
这组指令包含立即数、直接地址、间接地址及工作寄存器与累加器A连同借位位C内容相减,结果送回累加器A中。
这里我们对借位位C的状态作出说明,在进行减法运算中,CY=1表示有借位,CY=0则无借位。
OV=1声明带符号数相减时,从一个正数减去一个负数结果为负数,或者从一个负数中减去一个正数结果为正数的错误情况。
在进行减法运算前,如果不知道借位标志位C的状态,则应先对CY进行清零操作。
SUBBA,data;(A)-(data)-(C)→(A)累加器A中的内容与直接地址单元中的内容、连同借位位相减,结果存在A中
SUBBA,#data;(A)-#data-(C)→(A)累加器A中的内容与立即数、连同借位位相减,结果存在A中
SUBBA,Rn;(A)-(Rn)-(C)→(A)累加器A中的内容与工作寄存器中的内容、连同借位位相减,结果存在A中
SUBBA,@Ri;(A)-((Ri))-(C)→(A)累加器A中的内容与工作寄存器Ri指向的地址单元中的内容、连同借位位相减,结果存在A中
[4].乘法指令(1条)
这个指令的作用是把累加器A和寄存器B中的8位无符号数相乘,所得到的是16位乘积,这个结果低8位存在累加器A,而高8位存在寄存器B中。
如果OV=1,说明乘积大于FFH,否则OV=0,但进位标志位CY总是等于0。
MULAB;(A)×(B)→(A)和(B)累加器A中的内容与寄存器B中的内容相乘,结果存在A、B中
[5].除法指令(1条)
这个指令的作用是把累加器A的8位无符号整数除以寄存器B中的8位无符号整数,所得到的商存在累加器A,而余数存在寄存器B中。
除法运算总是使OV和进位标志位CY等于0。
如果OV=1,表明寄存器B中的内容为00H,那么执行结果为不确定值,表示除法有溢出。
DIVAB;(A)÷(B)→(A)和(B)累加器A中的内容除以寄存器B中的内容,所得到的商存在累加器A,而余数存在寄存器B中。
[6].加1指令(5条)
这5条指令的的功能均为原寄存器的内容加1,结果送回原寄存器。
上述提到,加1指令不会对任何标志有影响,如果原寄存器的内容为FFH,执行加1后,结果就会是00H。
这组指令共有直接、寄存器、寄存器减间址等寻址方式:
INCA;(A)+1→(A)累加器A中的内容加1,结果存在A中
INCdata;(data)+1→(data)直接地址单元中的内容加1,结果送回原地址单元中
INC@Ri;((Ri))+1→((Ri))寄存器的内容指向的地址单元中的内容加1,结果送回原地址单元中
INCRn;(Rn)+1→(Rn)寄存器Rn的内容加1,结果送回原地址单元中
INCDPTR;(DPTR)+1→(DPTR)数据指针的内容加1,结果送回数据指针中
在INCdata这条指令中,如果直接地址是I/O,其功能是先读入I/O锁存器的内容,然后在CPU进行加1操作,再输出到I/O上,这就是“读—修改—写”操作。
[7].减1指令(4条)
这组指令的作用是把所指的寄存器内容减1,结果送回原寄存器,若原寄存器的内容为00H,减1后即为FFH,运算结果不影响任何标志位,这组指令共有直接、寄存器、寄存器间址等寻址方式,当直接地址是I/O口锁存器时,“读—修改—写”操作与加1指令类似。
DECA;(A)-1→(A)累加器A中的内容减1,结果送回累加器A中
DECdata;(data)-1→(data)直接地址单元中的内容减1,结果送回直接地址单元中
DEC@Ri;((Ri))-1→((Ri))寄存器Ri指向的地址单元中的内容减1,结果送回原地址单元中
DECRn;(Rn)-1→(Rn)寄存器Rn中的内容减1,结果送回寄存器Rn中
[8].十进制调整指令(1条)
在进行BCD码运算时,这条指令总是跟在ADD或ADDC指令之后,其功能是将执行加法运算后存于累加器A中的结果进行调整和修正。
DAA
MCS-51逻辑运算及移位指令
逻辑运算和移位指令共有25条,有与、或、异或、求反、左右移位、清0等逻辑操作,有直接、寄存器和寄存器间址等寻址方式。
这类指令一般不影响程序状态字(PSW)标志。
[1].循环移位指令(4条)
这4条指令的作用是将累加器中的内容循环左或右移一位,后两条指令是连同进位位CY一起移位。
RLA;累加器A中的内容左移一位
RRA;累加器A中的内容右移一位
RLCA;累加器A中的内容连同进位位CY左移一位
RRCA;累加器A中的内容连同进位位CY右移一位
[2].累加器半字节交换指令(1条)
这条指令是将累加器中的内容高低半字节互换,这在上一节中内容已有介绍。
SWAPA;累加器中的内容高低半字节互换
[3].求反指令(1条)
这条指令将累加器中的内容按位取反。
CPLA;累加器中的内容按位取反
[4].清零指令(1条)
这条指令将累加器中的内容清0。
CLRA;0→(A),累加器中的内容清0
[5].逻辑与操作指令(6条)
这组指令的作用是将两个单元中的内容执行逻辑与操作。
如果直接地址是I/O地址,则为“读—修改—写”操作。
ANLA,data;累加器A中的内容和直接地址单元中的内容执行与逻辑操作。
结果存在寄存器A中。
ANLdata,#data;直接地址单元中的内容和立即数执行与逻辑操作。
结果存在直接地址单元中。
ANLA,#data;累加器A的内容和立即数执行与逻辑操作。
结果存在累加器A中。
ANLA,Rn;累加器A的内容和寄存器Rn中的内容执行与逻辑操作。
结果存在累加器A中。
ANLdata,A;直接地址单元中的内容和累加器A的内容执行与逻辑操作。
结果存在直接地址单元中。
ANLA,@Ri;累加器A的内容和工作寄存器Ri指向的地址单元中的内容执行与逻辑操作。
结果存在累加器A中。
[6].逻辑或操作指令(6条)
这组指令的作用是将两个单元中的内容执行逻辑或操作。
如果直接地址是I/O地址,则为“读—修改—写”操作。
ORLA,data;累加器A中的内容和直接地址单元中的内容执行逻辑或操作。
结果存在寄存器A中。
ORLdata,#data;直接地址单元中的内容和立即数执行逻辑或操作。
结果存在直接地址单元中。
ORLA,#data;累加器A的内容和立即数执行逻辑或操作。
结果存在累加器A中。
ORLA,Rn;累加器A的内容和寄存器Rn中的内容执行逻辑或操作。
结果存在累加器A中。
ORLdata,A;直接地址单元中的内容和累加器A的内容执行逻辑或操作。
结果存在直接地址单元中。
ORLA,@Ri;累加器A的内容和工作寄存器Ri指向的地址单元中的内容执行逻辑或操作。
结果存在累加器A中。
[7].逻辑异或操作指令(6条)
这组指令的作用是将两个单元中的内容执行逻辑异或操作。
如果直接地址是I/O地址,则为“读—修改—写”操作。
XRLA,data;累加器A中的内容和直接地址单元中的内容执行逻辑异或操作。
结果存在寄存器A中。
XRLdata,#data;直接地址单元中的内容和立即数执行逻辑异或操作。
结果存在直接地址单元中。
XRLA,#data;累加器A的内容和立即数