ARM的汇编指令讲解

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

汇编知识点的要求:

1、能看的懂

2、可以做修改

3、不需要用汇编直接编写程序

汇编代码的应用场合:

1、ARM的启动代码必须要汇编,如:uboot最开始初始化硬件的代码

2、内核在最开始初始化的位置。。。。

一、ARM汇编指令的编码格式

1、编码格式

ARM汇编指令编译成机器码以后,机器码的长度是32bits,这32bits的编码有一个固定的格式。不同ARM 汇编指令,编码格式不同。

2、举例

C:

if(a==10)

a++;

else

a--;

汇编1:

CMP R0, #10;

ADDEQ R0,R0,#1

SUBNE R0,R0,#1

汇编2

SUBS R1, R0, #10; //S ---运算的结果会影响条件码标志位:CPSR:NZCV

ADDEQ R0,R0,#1

SUBNE R0,R0,#1

提示:

空指令NOP,实际上是占用CPU的时间,但是执行后,没有什么意义。

NOP ---- MOV R0,R0

3、条件码标识

10 -10

Z = 1

C = 0

N = 0

V = 0

=================================================================================

二、ARM的寻址方式

1、立即数寻址

操作数,有立即数。

ADD R0,R0,#1

MOV R1,#10

ORR R1,R1,#0xf @ R1=R1 | 0xf

BIC R1,R1,#0xf @R1 = R1&(~(0xf))

错误:

ADD R1,#1,#2

注意:立即数合法的条件

在ARM汇编指令中,并不是所有的立即数,立即数是有一定的限制的。

什么样的立即数是合法的???

1、如果一个立即数是小于256的(即该立即数是8bits以内的,0~255),该立即数是合法的。

2、如果一个立即数是大于等于256,该立即数经过循环左移偶数位,可以得到一个小于256的数,则该立即数合法。

256 = 0x100 ------→左移20位0x10000000----→左移4 0x1 合法

0x111 非法

0x102 非法

0x104 合法

0xfff

0xff00

0x12000

0x450000

0xab

原因:

在数据处理指令编码的时候,立即数用12bits来表示:

高4bits:循环左移左移偶数位除以2

低8bits:循环左移后的结果。

重要问题:

ADD R1,R0,#0xffff 非法

解决:

LDR R2,=0xffff // R2=0xffff,将立即数0xffff的值传送给R2

ADD R1, R0, R2

2、寄存器寻址

所有的操作数都是寄存器,没有立即数

ADD R0,R0,R1

MOV R1,R0

ORR R1,R1,R0 @ R1=R1 | 0xf

BIC R1,R1,R0 @R1 = R1&(~(0xf))

3、寄存器间接寻址

本质上,相当于C语言的指针

问题:读取0x30008000地址下的内容,该内容是int型的???

C:

int a;

a = *(int *)0x30008000

汇编:

LDR R0,=0x30008000

LDR R1,[R0] //LDR = loader,数据加载指令,加载一个地址下的内容

STR R2,[R1] //STR---store,数据存储指令,将一个数据存放到一个地址下。

错误的写法:

LDR R1, [0x30008000]

注意:间接寻址的地址需要存放到一个通用寄存器中,然后在使用。

4、寄存器的偏移寻址

MOV R0, R2,LSL #3 //LSL—逻辑左移。R0 = R2<<3

ADD R0,R1,R2,LSL #4 //R0 = R1 + (R2<<4)

SUB R0, R1, R2,LSL R3 //R0= R1- (R2<

5、基址变址寻址

是一个间接寻址的变形,地址是由基地址和偏移量组成的

1)先变址

LDR R0, [R1, #4] //将R1+4作为新地址,将新的地址下的内容加载给R0

2)后变址

LDR R0, [R1],#4 //先将R1地址下的内容加载给R0,然后R1=R1+4

3)自动变址

LDR R0, [R1, #4]! //!---》自动变址,将R1+4作为新地址,将新的地址下的内容加载给R0;然后R1=R1+4

6、栈的寻址

栈有四种寻址方式

对栈的操作:

STM --→多个STR,一次可以完成多个数据的存储LDM--→多个LDR,一次可以完成多个数据的加载例:

在操作满递减栈的时候:

出栈:LDMFD

入栈:STMFD

7、相对寻址

BL delay

B loop

三、ARM的汇编指令

1、跳转指令(B)---分支指令branch

B :单纯的跳转

BL :跳转的同时保存返回地址

BX :带状态切换的跳转

BLX:带状态切换的跳转,并保存返回地址

注意:受跳转指令编码格式的限制,跳转的范围是-32MB~32MB。

例:

BL delay //delay与跳转指令的不能超过32MB

注意,如果跳转的范围超过32MB,使用:

LDR PC, =delay

2、数据处理指令

需要注意:

相关文档
最新文档