当前位置:首页 > 单片机 > 单片机
[导读]数据传送类指令:MOV 访问内部数据储存器MOVX 访问外部数据储存器MOVC 访问ROM储存器XCH 整字节交换XCHD 半字节交换(低四位)PUSH 设置堆栈指针寄存器SP所指向的内容(把字压入堆栈)POP 把字弹出堆栈;SWAP 高低字

数据传送类指令:
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)等;

位数据传送指令MOVC,bit;bit→CYMOVbit,C;CY→bit位变量修改指令CLRC;0→CYCLRbit;0→bit;CPLbit;/bit→bitCPLC;/CY→CYSETBC;1→CY;SETBbit;1→1位变量逻辑与指令ANLC,bit;(CY)^(bit)→CYANLC,/bit;(CY)^(/bit)→CY位变量逻辑或指令ORLC,bit;(CY)|(bit)→CYORLC,/bit;(CY)|(/bit)→CY位变量条件条件转移指令JCrel若CY=1,则转移PC+2+rel→PCJNCrel若CY=0,则转移PC+2+rel→PCJBbit,rel若bit=1,则转移,PC+3+rel→PCJNBbit,rel若bit=0,则转移,PC+3+rel→PCJBCbit,rel若bit=1,则转移,PC+3+rel→PC,并且0→bit;(注意:只有JBC指令执行后,bit位被清0)


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

如果读者朋友已经有过汇编相关基础,能够够好理解本文内容。汇编语言是比C语言更接近机器底层的编程语言,能让我们更好的理解和操纵硬件底层。

关键字: 汇编 C语言

从汇编角度来说,如果“test %al, %al”能改成“test %0x1, %al”就没有匪夷所思的问题了,如此一来应该会降低CPU的效率,毕竟执行指令还需要一个立即数,我没搞过编译器也没设计过CPU,纯属瞎猜,能搞...

关键字: 汇编 CPU 编译器

【说在前面的话】其实我很久之前就想写这篇文章了,但彼时总觉得这是一个伪命题:既然已经用了MDK,编译出来的代码,无论是体积还是性能都甩下armgcc好几条街,谁还会想用gcc来进行Cortex-M开发呢?对那些只能使用a...

关键字: GCC MDK 汇编

1.背景群里有个小伙伴学习设计加密方法,如同某商用软件输入注册码后就能使用扩展功能。设计时他很自然的想着所写的加密措施是否足够健壮安全,是否有什么方法可以绕过加密检查,也就是破解。权限管理仅在启动后检查一次注册码是否有效...

关键字: 指令 汇编 软件

最近很多伙计问我现在搞嵌入式还有没有必要学习汇编?

关键字: 嵌入式 汇编

来源 :智能软件研究中心,作者:罗宇哲,直接来源:华为开发者社区 声明:本公众号转发仅为传播相关技术知识,不作任何商业用途,如有疑义请联系删除。 01 ARM汇编指令 操作系统中硬件相关的部分集中体现在汇编指令和对寄存器...

关键字: ARM 汇编

Part 1. 机器指令 上一次 我们已经了解了 二进制和 CPU 的基本原理,知道了程序运行时,CPU 每秒数以亿次、十亿次、百亿次地震荡着时钟,同步执行着微小的 「电子操作」,例如:从内存读取一个字节的数据到 CPU...

关键字: 高级编程 编程语言 汇编

来源 :智能软件研究中心,作者:罗宇哲,直接来源:华为开发者社区 声明:本公众号转发仅为传播相关技术知识,不作任何商业用途,如有疑义请联系删除。 01 ARM汇编指令 操作系统中硬件相关的部分集中体现在汇编指令和对寄存器...

关键字: ARM 汇编

北京时间4月30日早间消息,据外媒报道,Facebook首席执行官扎克伯格周三警告称,过早重新开放公共空间“几乎可以肯定”将会导致新冠病毒的继续爆发,并带来不良的经济后果。 扎克伯格在公司第一季度财报

关键字: 扎克伯格 FACEBOOK LTE 汇编

北京时间4月30日早间消息,据外媒报道,Facebook首席执行官扎克伯格周三警告称,过早重新开放公共空间“几乎可以肯定”将会导致新冠病毒的继续爆发,并带来不良的经济后果。扎克伯格在公司第一季度财报电

关键字: 扎克伯格 FACEBOOK LTE 汇编
关闭