微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 嵌入式Linux三常用ARM汇编指令

嵌入式Linux三常用ARM汇编指令

时间:11-20 来源:互联网 点击:
嵌入式开发中,汇编程序常常用于非常关键的地方,比如系统启动时初始化,进出中断时的环境保护,恢复等对性能有要求的地方。

ARM指令集可以分为六大类,分别为数据处理指令、Load/Store指令、跳转指令、程序状态寄存器处理指令、协处理器指令和异常产生指令。
ARM指令使用的基本格式如下:
〈opcode〉{〈cond〉}{S}〈Rd〉,〈Rn〉{,〈operand2〉}
opcode操作码;指令助记符,如LDR、STR等。
cond可选的条件码;执行条件,如EQ、NE等。
S可选后缀;若指定“S”,则根据指令执行结果更新CPSR中的条件码。
Rd目标寄存器。
Rn存放第1操作数的寄存器。
operand2第2个操作数

arm的寻址方式如下:
立即寻址
寄存器寻址
寄存器间接寻址
基址加偏址寻址
堆栈寻址
块拷贝寻址
相对寻址
这里不作详细描述,可以查阅相关文档。

数据处理指令
Load/Store指令
程序状态寄存器与通用寄存器之间的传送指令
转移指令
异常中断指令
协处理器指令

在S3C2410、S3C2440的数据手册中对各种汇编指令有详细的描述;这里只对较常见的作写介绍。
1、相对跳转指令:b、bl
这两条指令的不同之处在于bl指令除了跳转之外,还将返回地址(bl的下一条指令的地址)保存在lr寄存器中。
这两条指令的可跳转范围是当前指令前后32M。

bfuna
....
funa:
bfunb
....
funb:
....

2、数据传送指令mov,地址读取伪指令ldr
mov指令可以把一个寄存器的值赋给另外一个寄存器,或者把一个常数赋给寄存器。
movr1,r2
/*上面是r1=r2*/
movr1,#1024
/*r1=1024*/

mov传送的常数必须能用立即数来表示。当不能用立即数表示时,可以用ldr命令来赋值。
ldr是伪命令,不是真实存在的指令,编译器会把它扩展成真正的指令;如果该常数能用“立即数”来表示,则使用mov指令,否则编译时将该常数保存在某个位置,使用内存读取指令把它读出来。
ldrr1,=1024
/*r1=1024*/

3、内存访问指令ldr、str、ldm、stm
ldr既可以指低至读取伪指令,也可以是内存访问指令。当他的第二个参数前面有=时标伪指令,否则表内存访问指令。
ldr指令从内存中读取数据到寄存器,str指令把寄存器的指存储到内存中,他们的操作数都是32位的。

ldrr1,[r2,#4]/*将地址为r2+4的内存单元数据读取到r1中*/
ldrr1,[r2]/*将地址为r2的内存单元数据读取到r1中*/
ldrr1,[r2],#4/*将地址为r2的内存单元数据读取到r1中,然后r2=r2+4*/
strr1,[r2,#4]/*将r1的数据保存到地址为r2+4的内存单元中*/
strr1,[r2]/*。。。。*/
strr1,[r2],#4/*将r1的数据保存到地址为r2的内存单元,然后r2=r2+4*/

多寄存器传送指令可以用一条指令将16个可见寄存器(R0~R15)的任意子集合(或全部)存储到存储器或从存储器中读取数据到该寄存器集合中。与单寄存器存取指令相比,多寄存器数据存取可用的寻址模式更加有限。多寄存器存取指令的汇编格式如下:

LDM/STM{}Rn{!},

4、加减指令add、sub

addr1,r2,#1/*r1=r2+1*/
subr1,r2,#1/*r1=r2-1*/

5、程序状态寄存器的访问指令msr,mrs

ARM指令中有两条指令,用于在状态寄存器和通用寄存器之间传送数据。修改状态寄存器一般是通过“读取-修改-写回”三个步骤的操作来实现的。这两条指令分别是:
状态寄存器到通用寄存器的传送指令(MRS)
通用寄存器到状态寄存器的传送指令(MSR)

其汇编格式如下:
MRS{}Rd,CPSR|SPSR
其汇编格式如下:
MSR{}CPSR_f|SPSR_f,#<32-bitimmediate>
MSR{}CPSR_|SPSR_,Rm

msrcpsr,r0/*r0到cpsr中*/
mrsr0,cpsr/*cpsr到r0中*/

6、逻辑运算指令

AND逻辑"与"操作指令
指令格式:
AND{cond}{S}Rd,Rn,operand2

AND指令将操作数operand2与Rn的值按位逻辑"与",结果存放到目的寄存器Rd中。若设置S,则根据运算结果影响N、Z位,在计算第二操作数时,更新C位,不影响V位(指令ORR、EOR、BIC对标志位的影响同AND指令)。

指令示例:
ANDSR1,R1,R2;R1=R1&R2,并根据运算的结果更新标志位
ANDR0,R0,#0x0F;R0=R0&0x0F,取出R0最低4位数据。

ORR逻辑"或"操作指令
指令格式:ORR{cond}{S}Rd,Rn,operand2ORR指令将操作数operand2与Rn的值按位逻辑"或",结果存放到目的寄存器Rd中。指令示例:
ORRSR1,R1,R2;R1=R1|R2,并根据运算的结果更新标志位

ORRR0,R0,#0x0F;R0=R0|0x0F,将R0最低4位置1,其余位不变。

BIC位清除指令
指令格式:
BIC{cond}{S}Rd,Rn,operand2

BIC指令将Rn的值与操作数operand2的反码按位逻辑"与",结果存放到目的寄存器Rd中。指令示例:BICR0,R0,#0x0F;将R0最低4位清零,其余位不变。

7、异常中断指令
异常中断指令可以分为一下两种:
软件中断指令(SWI)
断点指令(BKPT—仅用于v5T体系)
软件中断指令SWI用于产生SWI异常中断,用来实现在用户模式下对操作系统中特权模式的程序的调用;断点中断指令BKPT主要用于产生软件断点,供调试程序用。

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

网站地图

Top