微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > ARM基础:ARM 伪指令详解

ARM基础:ARM 伪指令详解

时间:11-20 来源:互联网 点击:

后指令的类型,并不能对处理器进行状态的切换。

使用示例:

AREA Init,CODE,READONLY

……

CODE32 ;通知编译器其后的指令为32位的ARM指令

LDR R0,=NEXT+1 ;将跳转地址放入寄存器R0

BX R0 ;程序跳转到新的位置执行,并将处理器切换到Thumb工作状态

……

CODE16 ;通知编译器其后的指令为16位的Thumb指令

NEXT LDR R3,=0x3FF

……

END ;程序结束

4、 ENTRY

语法格式:

ENTRY

ENTRY伪指令用于指定汇编程序的入口点。在一个完整的汇编程序中至少要有一个ENTRY(也可以有多个,当有多个ENTRY时,程序的真正入口点由链接器指定),但在一个源文件里最多只能有一个ENTRY(可以没有)。

使用示例:

AREA Init,CODE,READONLY

ENTRY ;指定应用程序的入口点

……

5、 END

语法格式:

END

END伪指令用于通知编译器已经到了源程序的结尾。

使用示例:

AREA Init,CODE,READONLY

……

END ;指定应用程序的结尾

6、 EQU

语法格式:

名称 EQU 表达式{,类型}

EQU伪指令用于为程序中的常量、标号等定义一个等效的字符名称,类似于C语言中的#define。其中EQU可用“*”代替。

名称为EQU伪指令定义的字符名称,当表达式为32位的常量时,可以指定表达式的数据类型,可以有以下三种类型:

CODE16、CODE32和DATA

使用示例:

Test EQU 50 ;定义标号Test的值为50

Addr EQU 0x55,CODE32 ;定义Addr的值为0x55,且该处为32位的ARM指令。

7、 EXPORT(或GLOBAL)

语法格式:

EXPORT 标号{[WEAK]}

EXPORT伪指令用于在程序中声明一个全局的标号,该标号可在其他的文件中引用。EXPORT可用GLOBAL代替。标号在程序中区分大小写,[WEAK]选项声明其他的同名标号优先于该标号被引用。

使用示例:

AREA Init,CODE,READONLY

EXPORT Stest ;声明一个可全局引用的标号Stest

……

END

8、 IMPORT

语法格式:

IMPORT 标号{[WEAK]}

IMPORT伪指令用于通知编译器要使用的标号在其他的源文件中定义,但要在当前源文件中引用,而且无论当前源文件是否引用该标号,该标号均会被加入到当前源文件的符号表中。

标号在程序中区分大小写,[WEAK]选项表示当所有的源文件都没有定义这样一个标号时,编译器也不给出错误信息,在多数情况下将该标号置为0,若该标号为B或BL指令引用,则将B或BL指令置为NOP操作。

使用示例:

AREA Init,CODE,READONLY

IMPORT Main ;通知编译器当前文件要引用标号Main,但Main在其他源文件中定义

……

END

9、 EXTERN

语法格式:

EXTERN 标号{[WEAK]}

EXTERN伪指令用于通知编译器要使用的标号在其他的源文件中定义,但要在当前源文件中引用,如果当前源文件实际并未引用该标号,该标号就不会被加入到当前源文件的符号表中。

标号在程序中区分大小写,[WEAK]选项表示当所有的源文件都没有定义这样一个标号时,编译器也不给出错误信息,在多数情况下将该标号置为0,若该标号为B或BL指令引用,则将B或BL指令置为NOP操作。

使用示例:

AREA Init,CODE,READONLY

EXTERN Main ;通知编译器当前文件要引用标号Main,但Main在其他源文件中定义

……

END

10、 GET(或INCLUDE)

语法格式:

GET 文件名

GET伪指令用于将一个源文件包含到当前的源文件中,并将被包含的源文件在当前位置进行汇编处理。可以使用INCLUDE代替GET。

汇编程序中常用的方法是在某源文件中定义一些宏指令,用EQU定义常量的符号名称,用MAP和FIELD定义结构化的数据类型,然后用GET伪指令将这个源文件包含到其他的源文件中。使用方法与C语言中的“include”相似。

GET伪指令只能用于包含源文件,包含目标文件需要使用INCBIN伪指令

使用示例:

AREA Init,CODE,READONLY

GET a1.s ;通知编译器当前源文件包含源文件a1.s

GE T C:a2.s ;通知编译器当前源文件包含源文件C: a2.s

……

END

11、 INCBIN

语法格式:

INCBIN 文件名

INCBIN伪指令用于将一个目标文件或数据文件包含到当前的源文件中,被包含的文件不作任何变动的存放在当前文件中,编译器从其后开始继续处理。

使用示例:

AREA Init,CODE,READONLY

INCBIN a1.dat ;通知编译器当前源文件包含文件a1.dat

INCBIN C:a2.txt ;通知编译器当前源文件包含文件C:a2.txt

……

END

12、 RN

语法格式:

名称 RN 表达式

RN伪指令用于给一个寄存器定义一个别名。采用这种方式可以方便程序员记忆该寄存器的功能。其中,名称为给寄存器定义的别名,表达式为寄存器的编码。

使用示例:

Temp RN R0 ;将R0定义一

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

网站地图

Top