ARM汇编伪指令.docx
- 文档编号:18393977
- 上传时间:2023-08-16
- 格式:DOCX
- 页数:78
- 大小:668.72KB
ARM汇编伪指令.docx
《ARM汇编伪指令.docx》由会员分享,可在线阅读,更多相关《ARM汇编伪指令.docx(78页珍藏版)》请在冰点文库上搜索。
ARM汇编伪指令
ARM汇编伪指令(转载)
2007-09-0619:
26
其他常用的伪指令
还有一些其他的伪指令,在汇编程序中经常会被使用,包括以下几条:
—AREA
—ALIGN
—CODE16、CODE32
—ENTRY
—END
—EQU
—EXPORT(或GLOBAL)
—IMPORT
—EXTERN
—GET(或INCLUDE)
—INCBIN
—RN
—ROUT
1、AREA
语法格式:
AREA段名属性1,属性2,……
AREA伪指令用于定义一个代码段或数据段。
其中,段名若以数字开头,则该段名需用“|”括起来,如|1_test|。
属性字段表示该代码段(或数据段)的相关属性,多个属性用逗号分隔。
常用的属性如下:
—CODE属性:
用于定义代码段,默认为READONLY。
—DATA属性:
用于定义数据段,默认为READWRITE。
—READONLY属性:
指定本段为只读,代码段默认为READONLY。
—READWRITE属性:
指定本段为可读可写,数据段的默认属性为READWRITE。
—ALIGN属性:
使用方式为ALIGN表达式。
在默认时,ELF(可执行连接文件)的代码段和数据段是按字对齐的,表达式的取值范围为0~31,相应的对齐方式为2表达式次方。
—COMMON属性:
该属性定义一个通用的段,不包含任何的用户代码和数据。
各源文件中同名的COMMON段共享同一段存储单元。
一个汇编语言程序至少要包含一个段,当程序太长时,也可以将程序分为多个代码段和数据段。
使用示例:
AREAInit,CODE,READONLY
该伪指令定义了一个代码段,段名为Init,属性为只读
2、ALIGN
语法格式:
ALIGN{表达式{,偏移量}}
ALIGN伪指令可通过添加填充字节的方式,使当前位置满足一定的对其方式|。
其中,表达式的值用于指定对齐方式,可能的取值为2的幂,如1、2、4、8、16等。
若未指定表达式,则将当前位置对齐到下一个字的位置。
偏移量也为一个数字表达式,若使用该字段,则当前位置的对齐方式为:
2的表达式次幂+偏移量。
使用示例:
AREAInit,CODE,READONLY,ALIEN=3;指定后面的指令为8字节对齐。
指令序列
END
3、CODE16、CODE32
语法格式:
CODE16(或CODE32)
CODE16伪指令通知编译器,其后的指令序列为16位的Thumb指令。
CODE32伪指令通知编译器,其后的指令序列为32位的ARM指令。
若在汇编源程序中同时包含ARM指令和Thumb指令时,可用CODE16伪指令通知编译器其后的指令序列为16位的Thumb指令,CODE32伪指令通知编译器其后的指令序列为32位的ARM指令。
因此,在使用ARM指令和Thumb指令混合编程的代码里,可用这两条伪指令进行切换,但注意他们只通知编译器其后指令的类型,并不能对处理器进行状态的切换。
使用示例:
AREAInit,CODE,READONLY
……
CODE32;通知编译器其后的指令为32位的ARM指令
LDRR0,=NEXT+1;将跳转地址放入寄存器R0
BXR0;程序跳转到新的位置执行,并将处理器切换到Thumb工作状态
……
CODE16;通知编译器其后的指令为16位的Thumb指令
NEXTLDRR3,=0x3FF
……
END;程序结束
4、ENTRY
语法格式:
ENTRY
ENTRY伪指令用于指定汇编程序的入口点。
在一个完整的汇编程序中至少要有一个ENTRY(也可以有多个,当有多个ENTRY时,程序的真正入口点由链接器指定),但在一个源文件里最多只能有一个ENTRY(可以没有)。
使用示例:
AREAInit,CODE,READONLY
ENTRY;指定应用程序的入口点
……
5、END
语法格式:
END
END伪指令用于通知编译器已经到了源程序的结尾。
使用示例:
AREAInit,CODE,READONLY
……
END;指定应用程序的结尾
6、EQU
语法格式:
名称EQU表达式{,类型}
EQU伪指令用于为程序中的常量、标号等定义一个等效的字符名称,类似于C语言中的#define。
其中EQU可用“*”代替。
名称为EQU伪指令定义的字符名称,当表达式为32位的常量时,可以指定表达式的数据类型,可以有以下三种类型:
CODE16、CODE32和DATA
使用示例:
TestEQU50;定义标号Test的值为50
AddrEQU0x55,CODE32;定义Addr的值为0x55,且该处为32位的ARM指令。
7、EXPORT(或GLOBAL)
语法格式:
EXPORT标号{[WEAK]}
EXPORT伪指令用于在程序中声明一个全局的标号,该标号可在其他的文件中引用。
EXPORT可用GLOBAL代替。
标号在程序中区分大小写,[WEAK]选项声明其他的同名标号优先于该标号被引用。
使用示例:
AREAInit,CODE,READONLY
EXPORTStest;声明一个可全局引用的标号Stest……
END
8、IMPORT
语法格式:
IMPORT标号{[WEAK]}
IMPORT伪指令用于通知编译器要使用的标号在其他的源文件中定义,但要在当前源文件中引用,而且无论当前源文件是否引用该标号,该标号均会被加入到当前源文件的符号表中。
标号在程序中区分大小写,[WEAK]选项表示当所有的源文件都没有定义这样一个标号时,编译器也不给出错误信息,在多数情况下将该标号置为0,若该标号为B或BL指令引用,则将B或BL指令置为NOP操作。
使用示例:
AREAInit,CODE,READONLY
IMPORTMain;通知编译器当前文件要引用标号Main,但Main在其他源文件中定义……
END
9、EXTERN
语法格式:
EXTERN标号{[WEAK]}
EXTERN伪指令用于通知编译器要使用的标号在其他的源文件中定义,但要在当前源文件中引用,如果当前源文件实际并未引用该标号,该标号就不会被加入到当前源文件的符号表中。
标号在程序中区分大小写,[WEAK]选项表示当所有的源文件都没有定义这样一个标号时,编译器也不给出错误信息,在多数情况下将该标号置为0,若该标号为B或BL指令引用,则将B或BL指令置为NOP操作。
使用示例:
AREAInit,CODE,READONLY
EXTERNMain;通知编译器当前文件要引用标号Main,但Main在其他源文件中定义……
END
10、GET(或INCLUDE)
语法格式:
GET文件名
GET伪指令用于将一个源文件包含到当前的源文件中,并将被包含的源文件在当前位置进行汇编处理。
可以使用INCLUDE代替GET。
汇编程序中常用的方法是在某源文件中定义一些宏指令,用EQU定义常量的符号名称,用MAP和FIELD定义结构化的数据类型,然后用GET伪指令将这个源文件包含到其他的源文件中。
使用方法与C语言中的“include”相似。
GET伪指令只能用于包含源文件,包含目标文件需要使用INCBIN伪指令
使用示例:
AREAInit,CODE,READONLY
GETa1.s;通知编译器当前源文件包含源文件a1.s
GETC:
\a2.s;通知编译器当前源文件包含源文件C:
\a2.s……
END
11、INCBIN
语法格式:
INCBIN文件名
INCBIN伪指令用于将一个目标文件或数据文件包含到当前的源文件中,被包含的文件不作任何变动的存放在当前文件中,编译器从其后开始继续处理。
使用示例:
AREAInit,CODE,READONLY
INCBINa1.dat;通知编译器当前源文件包含文件a1.dat
INCBINC:
\a2.txt;通知编译器当前源文件包含文件C:
\a2.txt……
END
12、RN
语法格式:
名称RN表达式
RN伪指令用于给一个寄存器定义一个别名。
采用这种方式可以方便程序员记忆该寄存器的功能。
其中,名称为给寄存器定义的别名,表达式为寄存器的编码。
使用示例:
TempRNR0;将R0定义一个别名Temp
13、ROUT
语法格式:
{名称}ROUT
ROUT伪指令用于给一个局部变量定义作用范围。
在程序中未使用该伪指令时,局部变量的作用范围为所在的AREA,而使用ROUT后,局部变量的作为范围为当前ROUT和下一个ROUT之间。
第3节ARM指令集
推荐给好友
打印
加入收藏
更新于2008-08-0723:
31:
14
SPSRCPSRMRC
ARM指令集
6种类型(53种主要助记符):
数据处理指令(22种主要助记符)
跳转指令(4种主要助记符)
Load/Store指令(16种主要助记符)
程序状态寄存器指令(2种主要助记符)
协处理器指令(5种主要助记符)
软件中断指令(2种主要助记符)
数据处理指令
数据处理指令大致可分为3类:
数据传送指令;
算术逻辑运算指令;
乘法指令
比较指令。
数据处理指令只能对寄存器的内容进行操作,而不能对内存中的数据进行操作。
所有ARM数据处理指令均可选择使用S后缀,并影响状态标志。
数据处理指令1
MOV数据传送指令
格式:
MOV{
功能:
Rd=op1
op1可以是寄存器、被移位的寄存器或立即数。
例如:
MOVR0,#5;R0=5
MOVR0,R1;R0=R1
MOVR0,R1,LSL#5;R0=R1左移5位
数据处理指令2
2.MVN数据取反传送指令
格式:
MVN{
功能:
将op1表示的值传送到目的寄存器Rd中,但该值在传送前被按位取反,即Rd=!
op1;
op1可以是寄存器、被移位的寄存器或立即数。
例如:
MVNR0,#0;R0=-1
数据处理指令3
3.ADD加法指令
格式:
ADD{
功能:
Rd=Rn+op2
op2可以是寄存器,被移位的寄存器或立即数。
例如:
ADDR0,R1,#5;R0=R1+5
ADDR0,R1,R2;R0=R1+R2
ADDR0,R1,R2,LSL#5;R0=R1+R2左移5位
数据处理指令4
4.ADC带进位加法指令
格式:
ADC{
功能:
Rd=Rn+op2+carry
op2可以是寄存器、被移位的寄存器或立即数;carry为进位标志值。
该指令用于实现超过32位的数的加法。
例如:
第一个64位操作数存放在寄存器R2,R3中;
第二个64位操作数存放在寄存器R4,R5中;
64位结果存放在R0,R1中。
64位的加法可由以下语句实现:
ADDSR0,R2,R4;低32位相加,S表示结果影响条件标志位的值
ADCR1,R3,R5;高32位相加
数据处理指令5
5.SUB减法指令
格式:
SUB{
功能:
Rd=Rn-op2
op2可以是寄存器、被移位的寄存器或立即数。
例如:
SUBR0,R1,#5;R0=R1-5
SUBR0,R1,R2;R0=R1-R2
SUBR0,R1,R2,LSL#5;R0=R1-R2左移5位
数据处理指令6
6.RSB反向减法指令
格式:
RSB{
功能:
同SUB指令,但倒换了两操作数的前后位置,即Rd=op2-Rn。
例如:
RSBR0,R1,#5;R0=5-R1
RSBR0,R1,R2;R0=R2-R1
RSBR0,R1,R2,LSL#5;R0=R2左移5位-R1
数据处理指令7
7.SBC带借位减法指令
格式:
SBC{
功能:
Rd=Rn-op2-!
carry
op2可以是寄存器、被移位的寄存器或立即数。
SUB和SBC生成进位标志的方式不同于常规,如果需要借位则清除进位标志,所以指令要对进位标志进行一个非操作。
例如:
第一个64位操作数存放在寄存器R2,R3中;
第二个64位操作数存放在寄存器R4,R5中;
64位结果存放在R0,R1中。
64位的减法(第一个操作数减去第二个操作数)可由以下语句实现:
SUBSR0,R2,R4;低32位相减,S表示结果影响条件标志位的值
SBCR1,R3,R5;高32位相减
数据处理指令8
8.RSC带借位的反向减法指令
格式:
RSC{
功能:
同SBC指令,但倒换了两操作数的前后位置,即Rd=op2-Rn-!
carry。
例如:
前提条件与SBC例子相同,操作数1-操作数2的实现语句需改为:
SUBSR0,R2,R4;低32位相减,S表示结果影响寄存器CPSR的值
RSCR1,R5,R3;高32位相减
数据处理指令——乘法指令
ARM7TDMI具有三种乘法指令,分别为:
32×32位乘法指令;
32×32位乘加指令;
32×32位结果为64位的乘/乘加指令。
数据处理指令9
9.MUL32位乘法指令
格式:
MUL{
功能:
Rd=Rn×op2
该指令根据S标志,决定操作是否影响CPSR的值;其中op2必须为寄存器。
Rn和op2的值为32位的有符号数或无符号数。
例如:
MULSR0,R1,R2;R0=R1×R2,结果影响寄存器CPSR的值
数据处理指令10
10.MLA32位乘加指令
格式:
MLA{
功能:
Rd=Rn×op2+op3
op2和op3必须为寄存器。
Rn、op2和op3的值为32位的有符号数或无符号数。
例如:
MLAR0,R1,R2,R3;R0=R1×R2+R3
数据处理指令11
11.SMULL64位有符号数乘法指令
格式:
SMULL{
功能:
RdhRdl=Rn×op2
Rdh、Rdl和op2均为寄存器。
Rn和op2的值为32位的有符号数。
例如:
SMULLR0,R1,R2,R3
;R0=R2×R3的低32位
;R1=R2×R3的高32位
数据处理指令12
12.SMLAL64位有符号数乘加指令
格式:
SMLAL{
功能:
RdhRdl=Rn×op2+RdhRdl
Rdh、Rdl和op2均为寄存器。
Rn和op2的值为32位的有符号数,RdhRdl的值为64位的加数。
例如:
SMLALR0,R1,R2,R3
;R0=R2×R3的低32位+R0
;R1=R2×R3的高32位+R1
数据处理指令13
13.UMULL64位无符号数乘法指令
格式:
UMULL{
功能:
同SMULL指令,但指令中Rn和op2的值为32位的无符号数。
例如:
UMULLR0,R1,R2,R3
;R0=R2×R3的低32位
;R1=R2×R3的高32位
其中R2,R3的值为无符号数
数据处理指令14
14.UMLAL64位无符号数乘加指令
格式:
UMLAL{
功能:
同SMLAL指令,但指令中Rn,op2的值为32位的无符号数,RdhRdl的值为64位无符号数。
例如:
UMLALR0,R1,R2,R3
;R0=R2×R3的低32位+R0
;R1=R2×R3的高32位+R1
其中R2,R3的值为32位无符号数
R1,R0的值为64位无符号数
数据处理指令15
15.AND逻辑与指令
格式:
AND{
功能:
Rd=RnANDop2
op2可以是寄存器,被移位的寄存器或立即数。
一般用于清除Rn的特定几位。
例如:
ANDR0,R0,#5
;保持R0的第0位和第2位,其余位清0
数据处理指令16
16.ORR逻辑或指令
格式:
ORR{
功能:
Rd=RnORop2
op2可以是寄存器、被移位的寄存器或立即数。
一般用于设置Rn的特定几位。
例如:
ORRR0,R0,#5
;R0的第0位和第2位设置为1,其余位不变
数据处理指令17
17.EOR逻辑异或指令
格式:
EOR{
功能:
Rd=RnEORop2
op2可以是寄存器、被移位的寄存器或立即数。
一般用于将Rn的特定几位取反。
例如:
EORR0,R0,#5
;R0的第0位和第2位取反,其余位不变
数据处理指令18
18.BIC位清除指令
格式:
BIC{
功能:
Rd=RnAND(!
op2)
用于清除寄存器Rn中的某些位,并把结果存放到目的寄存器Rd中.
操作数op2是一个32位掩码(mask),如果在掩码中设置了某一位,则清除Rn中的这一位;未设置的掩码位指示Rn中此位保持不变。
其中,op2可以是寄存器、被移位的寄存器或立即数。
例如:
BICR0,R0,#5
;R0中第0位和第2位清0,其余位不变
数据处理指令19
19.CMP比较指令
格式:
CMP{
功能:
Rn-op1
该指令进行一次减法运算,但不存储结果,根据结果更新CPSR中条件标志位的值。
该指令不需要显式地指定S后缀来更改状态标志。
其中,操作数op1为寄存器或立即数。
例如:
CMPR0,#5
;计算R0-5,根据结果设置条件标志位
ADDGTR0,R0,#5
;如果R0>5,则执行ADDGT指令
数据处理指令20
20.CMN反值比较指令
格式:
CMN{
功能:
同CMP指令,但寄存器Rn的值是和op1取负的值进行比较。
例如:
CMNR0,#5
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- ARM 汇编 指令
![提示](https://static.bingdoc.com/images/bang_tan.gif)