百度文库
INC R0
AJMP LOOP POP DPL POP DPH RET
TAB: DB 05H,08H,02H, 05H, 06H, 60H, 42H,21H ,88H, 70H
END
[6]. 累加器A与片外数据存储器RAM传送指令(4条)
这4条指令的作用是累加器A 与片外RAM间的数据传送。使用寄存器寻址方式: MOVX @DPTR,A ;(A)→((DPTR)) 累加器中的内容送到数据指针指向片外RAM 地址中MOVX A, @DPTR ;((DPTR))→(A) 数据指针指向片外RAM 地址中的内容送到累加器A 中 MOVX A, @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所指的存储单元。
PUSH data ;(SP)+1→(SP),(data)→(SP) 堆栈指针首先加1,直接寻址单元中的数据送到堆栈指针SP所指的单元中。
POP data ;(SP)→(data)(SP)-1→(SP), 堆栈指针SP 所指的单元数据送到直接寻址单元中,堆栈指针SP 再进行减1操作。
[8]. 交换指令(5条)
这5条指令的功能是把累加器A 中的内容与源操作数所指的数据相互交换 XCH A,Rn ;(A)←→(Rn)累加器与工作寄存器Rn中的内容互换 XCH A,@Ri ;(A)←→((Ri))累加器与工作寄存器Ri所指的存储单元中的内容互换 XCH A,data ;(A)←→(data)累加器与直接地址单元中的内容互换 XCHD A,@Ri ;(A3-0)←→((Ri)3-0)累加器与工作寄存器Ri 所指的存储单元中的内容低半字节互换
SWAP A ;(A3-0)←→(A7-4)累加器中的内容高低半字节互换 如果(R0)=20H,(A)=3FH,(20H)=75H XCH A,@R0;A=75H ,(20H)=3FH XCHD A,@R0; A=35H ,(20H)=7FH SWAP A; A=53H
[9]. 16 位数据传送指令(1条)
这条指令的功能是把16 位常数送入数据指针寄存器。
MOV DPTR,#data16 ;#dataH→(DPH),#dataL→(DPL)16位常数的高8位送到DPH,低8位送到DPL
第三节 MCS-51 算术运算指令
算术运算指令共有24条,算术运算主要是执行加、减、乘、除法四则运算。另外MCS-51指令系统中有相当一部分是进行加、减1 操作,BCD码的运算和调整,我们都归类为运算指令。虽然MCS-51 单片机的算术逻辑单元ALU 仅能对8 位无符号整数进行运算,但利用进位标志C,则可进行多字节无符号整数的运算。同时利用溢出标志,还可以对带符号数进行补码运算。
21
百度文库
需要指出的是,除加、减1指令外,这类指令大多数都会对PSW(程序状态字)有影响。这在使用中应特别注意。
[1]. 加法指令(4条)
这4条指令的作用是把立即数,直接地址、工作寄存器及间接地址内容与累加器A 的内容相加,运算结果存在A中。
ADD A,#data ;(A)+#data→(A) 累加器A中的内容与立即数#data相加,结果存在A中 ADD A,data ;(A)+(data)→(A) 累加器A中的内容与直接地址单元中的内容相加,结果存在A中
ADD A,Rn ;(A)+(Rn)→(A) 累加器A中的内容与工作寄存器Rn中的内容相加,结果存在A中
ADD A,@Ri ;(A)+((Ri))→(A) 累加器A中的内容与工作寄存器Ri所指向地址单元中的内容相加,结果存在A中
例如:
MOV A,#0C3H ADD A,#0AAH 结果:A=6DH
[2]. 带进位加法指令(4条)
这4条指令除与[1]功能相同外,在进行加法运算时还需考虑进位问题。
ADDC A,data ;(A)+(data)+(C)→(A)累加器A中的内容与直接地址单元的内容连同进位位相加,结果存在A中
ADDC A,#data ;(A)+#data +(C)→(A) 累加器A中的内容与立即数连同进位位相加,结果存在A中
ADDC A,Rn ;(A)+Rn+(C)→(A) 累加器A中的内容与工作寄存器Rn中的内容、连同进位位相加,结果存在A中
ADDC A,@Ri ;(A)+((Ri))+(C)→(A) 累加器A 中的内容与工作寄存器Ri 指向地址单元中的内容、连同进位位
相加,结果存在A中 例如:C=1 MOV A,#0AAH MOV R0,#55H; ADDC A,R0; 结果:A=0
[3]. 带借位减法指令(4条) 这组指令包含立即数、直接地址、间接地址及工作寄存器与累加器A连同借位位C 内容相减,结果送回累加器A中。
这里我们对借位位C的状态作出说明,在进行减法运算中,CY=1 表示有借位,CY=0则无借位。OV=1声明带符号数相减时,从一个正数减去一个负数结果为负数,或者从一个负数中减去一个正数结果为正数的错误情况。在进行减法运算前,如果不知道借位标志位C的状态,则应先对CY进行清零操作。
SUBB A,data ;(A)-(data) - (C)→(A) 累加器A中的内容与直接地址单元中的内容、连同借位位相减,结果存在A中。
SUBB A,#data;(A)-#data -(C)→(A) 累加器A中的内容与立即数、连同借位位相减,结果存在A中。
SUBB A,Rn ;(A)-(Rn) -(C)→(A) 累加器A中的内容与工作寄存器中的内容、连同借位位相减,结果存在A中。
22
百度文库
SUBB A,@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。
MUL AB ;(A)×(B)→(A)和(B) 累加器A中的内容与寄存器B中的内容相乘,结果存在A、B中。
[5]. 除法指令(1条)
这个指令的作用是把累加器A的8位无符号整数除以寄存器B中的8位无符号整数,所得到的商存在累加器A,而余数存在寄存器B中。除法运算总是使OV 和进位标志位CY 等于0。如果OV=1,表明寄存器B中的内容为00H,那么执行结果为不确定值,表示除法有溢出。
DIV AB ;(A)÷(B)→(A)和(B) 累加器A中的内容除以寄存器B中的内容,所得到的商存在累加器A,而余数存在寄存器B中。
[6]. 加1 指令(5条)
这5条指令的的功能均为原寄存器的内容加1,结果送回原寄存器。上述提到,加1 指令不会对任何标志有影响,如果原寄存器的内容为FFH,执行加1后,结果就会是00H。这组指令共有直接、寄存器、寄存器减间址等寻址方式:
INC A ;(A)+1→(A) 累加器A中的内容加1,结果存在A中。
INC data ;(data)+1→(data) 直接地址单元中的内容加1,结果送回原地址单元中。 INC @Ri ;((Ri))+1→((Ri)) 寄存器的内容指向的地址单元中的内容加1,结果送回原地址单元中。
INC Rn ;(Rn)+1→(Rn)寄存器Rn的内容加1,结果送回原地址单元中。
INC DPTR ;(DPTR)+1→(DPTR)数据指针的内容加1,结果送回数据指针中。
在INC data这条指令中,如果直接地址是I/O,其功能是先读入I/O锁存器的内容,然后在CPU进行加1操作,再输出到I/O上,这就是“读—修改—写”操作。
[7]. 减1指令(4条)
这组指令的作用是把所指的寄存器内容减1,结果送回原寄存器,若原寄存器的内容为00H,减1 后即为FFH,运算结果不影响任何标志位,这组指令共有直接、寄存器、寄存器间址等寻址方式,当直接地址是I/O 口锁存器时,“读—修改—写”操作与加1 指令类似。
DEC A ;(A)-1→(A)累加器A中的内容减1,结果送回累加器A中。
DEC data ;(data)-1→(data)直接地址单元中的内容减1,结果送回直接地址单元中。 DEC @Ri ;((Ri))-1→((Ri))寄存器Ri指向的地址单元中的内容减1,结果送回原地址单元中。
DEC Rn ;(Rn)-1→(Rn)寄存器Rn中的内容减1,结果送回寄存器Rn中。
[8]. 十进制调整指令(1条)
在进行BCD 码运算时,这条指令总是跟在ADD 或ADDC 指令之后,其功能是将执行加法运算后存于累加器A 中的结果进行调整和修正。
调整方法:如果[(A0~3)]>9 或者(AC)=1,则(A0~3)←(A0~3)+06H 如果[(A4~7)]>9 或者(CY)=1,则(A4~7)←(A4~7)+60H DA A
第四节 MCS-51 逻辑运算及移位指令
23
百度文库
逻辑运算和移位指令共有25 条,有与、或、异或、求反、左右移位、清0 等逻辑操作,有直接、寄存器和寄存器间址等寻址方式。这类指令一般不影响程序状态字(PSW)标志。
[1]. 循环移位指令(4条)
这4条指令的作用是将累加器中的内容循环左或右移一位,后两条指令是连同进位位CY一起移位。
RL A ;累加器A 中的内容左移一位 RR A ;累加器A 中的内容右移一位
RLC A ;累加器A中的内容连同进位位CY左移一位 RRC A ;累加器A中的内容连同进位位CY右移一位 举例:
MOV A,#01H;0000 0001B RL A ;A=0000 0010B 02H RL A ;A=0000 0100B 04H RR A ;A=0000 0010B 02H 假设:C=1
具体程序如下:
ORG 0000H AJMP MAIN ORG 0030H MAIN:
SETB C
MOV A,#01H; A=01H RL A; A=02H RL A; A=04H RL A; A=08H RR A; A=04H RR A; A=02H
RRC A; 0000 0001 C=1 所以 A=81H 1000 0001H RLC A; A=02H END
[2]. 累加器半字节交换指令(1条)
这条指令是将累加器中的内容高低半字节互换,这在上一节中内容已有介绍。 SWAP A ; 累加器中的内容高低半字节互换 例如:
MOV A,#0A3H SWAP A
结果 A=3AH [3]. 求反指令(1条)
这条指令将累加器中的内容按位取反。 CPL A ; 累加器中的内容按位取反 例子: MOV A,#01H
CPL A
结果 :A=1111 1110B=FEH
24
百度文库
[4]. 清零指令(1条)
这条指令将累加器中的内容清0。 CLR A ; 0→(A),累加器中的内容清0 [5]. 逻辑与操作指令(6条)
这组指令的作用是将两个单元中的内容执行逻辑与操作。如果直接地址是I/O地址,则为“读—修改—写”操作。
ANL A,data ;累加器A中的内容和直接地址单元中的内容执行与逻辑操作。结果存在寄存器A中。
ANL data,#data ;直接地址单元中的内容和立即数执行与逻辑操作。结果存在直接地址单元中。
ANL A,#data ;累加器A的内容和立即数执行与逻辑操作。结果存在累加器A中。 ANL A,Rn ;累加器A的内容和寄存器Rn中的内容执行与逻辑操作。结果存在累加器A中。 ANL data,A ;直接地址单元中的内容和累加器A的内容执行与逻辑操作。结果存在直接地址单元中。
ANL A,@Ri ;累加器A的内容和工作寄存器Ri指向的地址单元中的内容执行与逻辑操作。结果存在累加器A中。
[6]. 逻辑或操作指令(6条)
这组指令的作用是将两个单元中的内容执行逻辑或操作。如果直接地址是I/O地址,则为“读—修改—写”操作。
ORL A,data ;累加器A中的内容和直接地址单元中的内容执行逻辑或操作。结果存在寄存器A中。
ORL data,#data ;直接地址单元中的内容和立即数执行逻辑或操作。结果存在直接地址单元中。
ORL A,#data ;累加器A的内容和立即数执行逻辑或操作。结果存在累加器A中。 ORL A,Rn ;累加器A的内容和寄存器Rn中的内容执行逻辑或操作。结果存在累加器A中。 ORL data,A ;直接地址单元中的内容和累加器A的内容执行逻辑或操作。结果存在直接地址单元中。
ORL A,@Ri ;累加器A的内容和工作寄存器Ri指向的地址单元中的内容执行逻辑或操作。结果存在累加器A中。
[7]. 逻辑异或操作指令(6条)
这组指令的作用是将两个单元中的内容执行逻辑异或操作。如果直接地址是I/O地址,则为“读—修改—写”操作。
XRL A,data ;累加器A中的内容和直接地址单元中的内容执行逻辑异或操作。结果存在寄存器A中。
XRL data,#data ;直接地址单元中的内容和立即数执行逻辑异或操作。结果存在直接地址单元中。
XRL A,#data ;累加器A的内容和立即数执行逻辑异或操作。结果存在累加器A中。
XRL A,Rn ;累加器A的内容和寄存器Rn中的内容执行逻辑异或操作。结果存在累加器A中。
XRL data,A ;直接地址单元中的内容和累加器A的内容执行逻辑异或操作。结果存在直接地
25