您的位置:首页 > 其它

基于MCS-51内核的汇编操作符笔记

2017-04-11 21:25 246 查看
数据传送类指令:

MOV 访问内部数据储存器

MOVX 访问外部数据储存器

MOVC 访问ROM储存器

XCH 整字节交换

XCHD 半字节交换(低四位)

PUSH 设置堆栈指针寄存器SP所指向的内容(把字压入堆栈)

POP 把字弹出堆栈;

SWAP 高低字节交换指令;

数据传送指令不影响标志,只有一有堆栈操作可以直接修改程序状态字PSW,这样可以是某些标志位发生变化;

格式:MOV 操作数 目标操作数

操作数:A,Rn,direct(直接地址),@Ri(间接地址),#data;

源操作数:A,Rn,direct(直接地址),@Ri(间接地址);

提醒:MOV @DPTR,#data; 将16位的数据存入数据指针寄存器DPTR所指向的地址中;

算术运算类指令:

只能是8位

ADD 不带进位相加

ADDC 带进位相加

INC 加1指令

SUBB 减法指令,操作数-源操作数-CY

DEC 减1指令

DAA 十进制调整指令;

MUL 乘法指令

DIV 除法指令

算术标志指令将会影响进位标志CY,辅助进位标志AC,溢出标志OV:运算时,如果D7进位,则CY被置1,否则清零;如果D3位有进位,则AC将会被置1,否则会被清零;对于无符号数相加,若CY置1,则表示D7进位溢出(大于255);对于无符号数,若和数溢出(大于127或小于-128),则OV被置1;

逻辑运算指令:

CLR 清0操作数

CPL 对操作数按位取反

ANL 与

ORL 或

XRL 异或

RL 操作数左移1位

RLC 带进位标志左移1位

RR 右移一位

RRC 带进位标志右移一位

控制转移指令

AJMP

LJMP

SJMP

JMP

ACALL

LCALL

JZ

JNZ

CJNE

DJNZ

1条件转移指令

绝对转移指令 AJMP addr11;PC→PC+2+addr11

2KB范围内无条件跳转指令,执行该指令时,先将PC+2,然后再将addr11的值送入PC10~PC0,而PC11~P15保持不变,这样得到跳转的目的地址。

相对转移指令 SJMP rel;PC→PC+2+rel

执行指令时,先将PC+2,再把指令中带符号的偏移量加上PC上,得到跳转的目的地地址送入PC;目标地址=源地址+2+rel。源地址是SJMP指令操作码(PC)的所在地;相对偏移量rel是一个用补码表示的8位带符号数,转移范围为当前PC的值的+127~-128共256个单元;

若要求用动态停机可以用SIMP指令来实现:”HERE:SJMP HERE;”或者”HERE:SJMP ;”表示本指令所在单元地址 ($读dollar)

长跳转指令 addr16; addr16→PC

执行指令时,addr16可以指向64KB程序储存器中的任何地址,并且不影响标志位;

间接转移指令(散转指令)

JMP @A+DPTR; A+DPTR→PC

将A中的8位无符号数和数据指针DPTR的16位数相加,然后将之后送到PC,并不改变A和DPTR的值,也不影响标志;间接转移指令特点是采用变址方式实现无条件转移,特点是转移地址可以在程序运行中加以改变,从可以实现多支转移。所以一条指令可以完成多条条件判断转移指令的功能;

2 条件转移指令

JZ rel;A= 0转移

JNZ rel;A≠0转移;

这种类转移一句累加器A的值是否为0。满足条件时转移(这个转移就相当于一个相对转移指令PC+2+rel→PC),条件不满足时则顺序执行下面一条指令。

3 比较转移指令

MCS51没有专门的比较指令,但提供了下面4条比较不相等转移指令:

CJNE A,direct,rel; A≠direct转移

CJNE A,#data,rel; A≠data转移

CJNE Rn,#data,rel; Rn≠data转移

CJNE @Ri,#data,rel; Ri≠data转移

比较操作数和源操作数的大小,如果不想等就转移。相等的话就不转移,继续执行下面的程序;转移地址的计算计算方法与上述两条指令相同。如果第一个操作数(无符号整数)小于第二个操作数,CY将会被置1,否则0,但是不影响任何操作数的内容;

4 减1不为0转移指令

DJNZ Rn,rel;Rn-1→Rn ≠0转移

DJNZ direct,rel;direct-1→direct ≠0转移

这两条指令把原操作数减1,结果送还到源操作数中,如果结果不为0则转移;

5 调用及返回指令

绝对调用指令 ACALL addr11

长调用指令 LCALL addr16

子程序返回指令 RET

中断返回指令 RET1

空操作指令 NOP; PC+1→PC

6 位操作指令

操作范围为内部RAM的位寻址区20H~2FH单元中连续的128位,以及特殊功能寄存器中可以进行位寻址的各位;位地址为(00H~7F);

位操作指令包括布尔变量的传送,逻辑运算,控制转移等指令,共有17条指令,所用到的助记符有MOV,CLR,CPL,SETB,ANL,ORL,JC,JB,JNB,JBC共11种;

在布尔处理机制中,进位标志CY的作用与CPU中的累加器A,通过CY完成位的传送和逻辑运算。

指令中位地址的表达方式有以下几种:直接地址方式(90H),点操作符方式(IE.0),位名称方式(EX0)等;

(1)位数据传送指令
MOV     C,bit;bit→CY
MOV bit,C;CY→bit
(2)位变量修改指令
CLR     C;0→CY
CLR     bit;0→bit;
CPL     bit;/bit→bit
CPL     C;/CY→CY
SETB    C;1→CY;
SETB        bit;1→1
(3)位变量逻辑与指令
ANL C,bit;  (CY)^(bit) →CY
ANL C,/bit; (CY)^(/bit) →CY
(4)位变量逻辑或指令
ORL C,bit;      (CY)|(bit) →CY
ORL C,/bit; (CY)|(/bit) →CY
(5)位变量条件条件转移指令
JC  rel     若CY=1,则转移   PC+2+rel→PC
JNC rel     若CY=0, 则转移  PC+2+rel→PC
JB  bit,rel 若bit=1,则转移,PC+3+rel→PC
JNB bit,rel 若bit=0,则转移,PC+3+rel→PC
JBC bit,rel 若bit=1,则转移,PC+3+rel→PC,并且0→bit;
(注意:只有JBC指令执行后,bit位被清0)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: