微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 什么是单片机寻址方式与指令系统

什么是单片机寻址方式与指令系统

时间:10-09 来源:互联网 点击:

算术运算指令

算术运算指令的主要功能是实现算术加、减、乘、除等运算。
1.ADD类指令是不带进位的加法运算指令(4条)。
ADD A,Rn ;A+Rn→A, A与Rn寄存器内容相加,结果送到A中
ADD A,direct ;(direct)+A→A, A与直接地址内容相加,和送A
ADD A, @Ri ;(Ri)+A→A, A与Ri间址内容相加,和送A
ADD A, #data ;data+A→A, A与立即数相加,和送A
注意:ADD类指令相加结果均在A中,相加后源操作数不变。若A中最高位有进位,Cy置1;若半加位有进位,AC置1。A的结果还影响奇偶标志位P。
例 A=30H, R0=10H
执行 ADD A,R0 结果:A=40H, R0=10H,标志位 P=1, Cy=0, OV=0, AC=0
2.ADDC类指令(带进位加法4条)
ADDC A, Rn ;A+Rn+Cy→A, A与R n内容、进位状态相加,和送
到A中
ADDC A, direct ;(direct)+Cy+A→A, A与直接地址中内容、进位状态
相加,和送A
ADDC A, @Ri ;(Ri)+Cy+A→A, A与Ri间址单元中内容、进位状态
相加,和送A
ADDC A, #data ;data+Cy+A→A, A与 立即数、进位状态相加,和送A
与ADD类指令的区别是,ADDC指令相加时连同进位标志Cy内容一起相加,主要用于多字节加法中的高位字节的相加,而最低位字节相加用ADD指令。进位位Cy加到字节的最低位。
例 编写计算1234H+0FE7H的程序,将结果存入内部RAM的41H和40H单元,40H存低8位,41H存高8位。
程序
MOV A, #34H ;被加数低8位数34H送A
ADD A, #0E7H ;加数低8位数E7H与之相加,A=1BH,Cy=1
MOV 40H, A ;A→40H即34H+E7H结果存入40H中(40H=1BH)
MOV A, #12H ;被加数高8位数12H送A
ADDC A, #0FH ;加数高8位0FH和Cy与A相加,A=22H
MOV 41H, A ;高8位与进位位之和存入41H中(41H)=22H
;总和为221BH,总结果在41H,40H单元中
3.SUBB类指令(4条)
SUBB类指令是带借位减法指令,其功能是将A中被减数减去源操作数指出的内容,再减去借位标志Cy(原进位标志)状态,差值在A中。
SUBB A, Rn ;A-Rn-Cy→A ,A减寄存器Rn内容及进位标志
SUBB A, direct ;A-(direct)-Cy→A,A减直接地址内容和进位标志
SUBB A, Ri ;A-(Ri)-Cy→A, A减Ri间址单元内容和进位位标志
SUBB A, #data ;A-data-Cy→A, A减立即数和进位标志
说明:
1) 多字节减法时,低位相减有借位则把Cy置1,否则Cy为0。
2) MCS-51系列指令中没有不带借位的减法指令,所以在单字节或低位字节减法时用SUBB类指令前要先将Cy清0。
3)减去一个数实际上是加上这个数的相反数(负数),减法运算常常用补码相加方式。
4.MUL(乘)和div(除)指令
乘法指令只有一条:
MUL AB ;A×B→B和A,结果16位,高8位存入B,低8位在A中
若乘积大于FFH则将溢出标志OV置1。
除法指令也只有一条:
div AB ; A÷B商→A,余数→B
注意:当除数为0时结果不确定,则溢出将OV置1。
5.INC(加1)和DEC(减1)类指令
加1类指令共5条,其功能是将操作数内容加1。
INC A ;A+1→A, A加1
INC Rn ;Rn+1→Rn, Rn中内容加1
INC direct ;(direct)+1→(direct), 直接地址中内容加1
INC @Ri ;(Ri)+1→(Ri), Ri间址中的内容加1
INC DPTR ;DPTR+1→DPTR, 数据指针加1
例 判断INC R0和INC @R0两条指令结果,比较两者的区别。设R0=30H,(30H)=00H。
执行 INC R0 ;R0+1=30H+1→R0, 结果R0=31H
执行 INC @R0 ;(R0)+1=(30H)+1→(R0),结果(30H)=01H,R0中内
容不变,仍为30H
减1类指令共4条,其功能是将操作数指定单元内容减1。
DEC A ;A-1→A, A中内容减1
DEC Rn ;Rn-1→Rn, Rn中内容减1
DEC direct ;(direct)-1→(direct), 直接地址中内容减1
DEC @Ri ;(Ri)-1→(Ri), Ri间址中的内容减1
操作过程与加1指令类似,这里不再举例。
6.十进制加法调整指令(1条)
DA A
功能:在加法指令后,把A中二进制码自动调整成BCD码。
例 MOV A, #05H ;05H→A
ADD A, #08H ;05H+08H→A=0DH
DA A ;结果调整A=13H,即是13的BCD码
注意:DA A指令只能跟在ADD或ADDC加法指令后,不适用于减法。

逻辑运算指令

1.ANL类指令(6条)
ANL类是逻辑与指令,其功能是将源操作数作数内容和目的操作数内容按位相“与”,结果存入目的操作数指定单元中,源操作数不变。
ANL A, Rn ;A∩Rn→A
ANL A, direct ;A∩(direct) →A
ANL A, @Ri ;A∩(Ri) →A
ANL A, #data ;A∩data→A
ANL direct, A ;(direct)∩A→(direct)
ANL direct, #data ;(direct)∩data→(direct)
例 设A=F6H,(30H)=0FH
执行 ANL A, 30H ;A∩ (30H) →A
操作如下:
11110110 (F6H)
∩ 00001111 (0FH) 注意:按位相“与”
00000110 (06H)
结果:A=06H, 30H地址内容不变,即(30H)=0FH
若执行ANL 30H, A ;(30H)∩ A→(30H)
操作同上,结果放在30H地址中,A中内容不变,即(30H)=06H, A=F6H。
2.ORL类指令(6条)
ORL类指令是逻辑或指令,其功能是将源操作数作数内容和目的操作数内容按位逻辑“或”,结果存入目的操作数指定单元中,源操作数不变。
ORL A, Rn ;A∪Rn→A
ORL A,direct ;A∪(direct) →A
ORL A, @Ri ;A∪(Ri) →A
ORL A, #data ;A∪data→A
ORL direct, A ;(direct)∪A→(direct)
ORL direct, #data ;(direct)∪data→(direct)
“或”运算和“与”运算过程类似,这里不再举例。
3.XRL类指令(6条)
XRL类是异或指令,其功能是将两个操作数指定内容按位“异或”,结果存于目的操作数指定单元中。“异或”原则是相同为“0”,相异为“1”。
XRL A, Rn ;A⊕Rn→A
XRL A, direct ;A⊕(direct) →A
XRL A, @Ri ;A⊕(Ri) →A
XRL A, #data ;A⊕data→A
XRL direct, A ;(direct)⊕A →(direct)
XRL direct, #data ;(direct)⊕data→(direct)
例 (50H)=05H
执行 XRL 50H, #06H ;(50H)⊕06H→(50H)
操作如下:
00000101 (05H)
⊕ 00000110 (06H)
00000011 (03H)
结果:(50H)=03H
4.循环移位指令(4条)
循环移位指令的功能是将累加器A中内容循环位移或者和进位位一起移位。
例 A=01H, Cy=1
若执行一次 RRC A后,结果为:A=10000000B Cy=1
若执行一次 RLC A后,结果为:A=00000011B Cy=0
5.取反、清0指令
CPL A ;累加器内容按位取反。如果1就变0,如果0就变1
CLR A ;累加器A清0

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top