您的位置 首页 IC

ARM 伪指令解说

在ARM汇编语言程序里,有一些特殊指令助记符,这些助记符与指令系统的助记符不同,没有相对应的操作码,通常称这些特殊指令助记符为伪

ARM 汇编语言程序里,有一些特别指令助记符,这些助记符与指令体系的助记符不同,没有相对应的操作码,一般称这些特别指令助记符为伪指令,他们所完结的操作称为伪操作。伪指令在源程序中的效果是为完结汇编程序作各种准备作业的,这些伪指令仅在汇编过程中起效果,一旦汇编完毕,伪指令的任务就完结。

在 ARM 的汇编程序中,有如下几种伪指令:符号界说伪指令、数据界说伪指令、汇编操控伪指令、宏指令以及其他伪指令。

符号界说( Symbol Definition )伪指令
符号界说伪指令用于界说 ARM 汇编程序中的变量、对变量赋值以及界说寄存器的别号等操作。
常见的符号界说伪指令有如下几种:
— 用于界说大局变量的 GBLA 、 GBLL 和 GBLS 。
— 用于界说部分变量的 LCLA 、 LCLL 和 LCLS 。
— 用于对变量赋值的 SETA 、 SETL 、 SETS 。
— 为通用寄存器列表界说称号的 RLIST 。
1、 GBLA、GBLL 和GBLS
语法格局:
GBLA ( GBLL 或 GBLS ) 大局变量名
GBLA 、 GBLL 和 GBLS 伪指令用于界说一个 ARM 程序中的大局变量,并将其初始化。其间:
GBLA 伪指令用于界说一个大局的数字变量,并初始化为 0 ;
GBLL 伪指令用于界说一个大局的逻辑变量,并初始化为 F (假);
GBLS 伪指令用于界说一个大局的字符串变量,并初始化为空;
因为以上三条伪指令用于界说大局变量,因而在整个程序规模内变量名有必要仅有。
运用示例:
GBLA Test1 ;界说一个大局的数字变量,变量名为 Test1
Test1 SETA 0xaa ;将该变量赋值为 0xaa
GBLL Test2 ;界说一个大局的逻辑变量,变量名为 Test2
Test2 SETL {TRUE} ;将该变量赋值为真
GBLS Test3 ;界说一个大局的字符串变量,变量名为 Test3
Test3 SETS “ Testing ” ;将该变量赋值为 “ Testing ”

2、 LCLA、LCLL 和LCLS
语法格局:
LCLA ( LCLL 或 LCLS ) 部分变量名
LCLA 、 LCLL 和 LCLS 伪指令用于界说一个 ARM 程序中的部分变量,并将其初始化。其间:
LCLA 伪指令用于界说一个部分的数字变量,并初始化为 0 ;
LCLL 伪指令用于界说一个部分的逻辑变量,并初始化为 F (假);
LCLS 伪指令用于界说一个部分的字符串变量,并初始化为空;
以上三条伪指令用于声明部分变量,在其效果规模内变量名有必要仅有。
运用示例:
LCLA Test4 ;声明一个部分的数字变量,变量名为 Test4
Test3 SETA 0xaa ;将该变量赋值为 0xaa
LCLL Test5 ;声明一个部分的逻辑变量,变量名为 Test5
Test4 SETL {TRUE} ;将该变量赋值为真
LCLS Test6 ;界说一个部分的字符串变量,变量名为 Test6
Test6 SETS “ Testing ” ;将该变量赋值为 “ Testing ”

3、 SETA、SETL 和SETS
语法格局:
变量名 SETA ( SETL 或 SETS ) 表达式
伪指令 SETA 、 SETL 、 SETS 用于给一个现已界说的大局变量或部分变量赋值。
SETA 伪指令用于给一个数学变量赋值;
SETL 伪指令用于给一个逻辑变量赋值;
SETS 伪指令用于给一个字符串变量赋值;
其间,变量名为现已界说过的大局变量或部分变量,表达式为即将赋给变量的值。
运用示例:
LCLA Test3 ;声明一个部分的数字变量,变量名为 Test3
Test3 SETA 0xaa ;将该变量赋值为 0xaa
LCLL Test4 ;声明一个部分的逻辑变量,变量名为 Test4
Test4 SETL {TRUE} ;将该变量赋值为真

4 、 RLIST
语法格局:
称号 RLIST { 寄存器列表 }
RLIST 伪指令可用于对一个通用寄存器列表界说称号,运用该伪指令界说的称号可在 ARM 指令 LDM/STM 中运用。在 LDM/STM 指令中,列表中的寄存器拜访次第为依据寄存器的编号由低到高,而与列表中的寄存器摆放次第无关。
运用示例:
RegList RLIST {R0-R5 , R8 , R10} ;将寄存器列表称号界说为 RegList ,可在 ARM 指令 LDM/STM中经过该称号拜访寄存器列表。

数据界说( Data Definition )伪指令
数据界说伪指令一般用于为特定的数据分配存储单元,一起可完结已分配存储单元的初始化。
常见的数据界说伪指令有如下几种:
— DCB 用于分配一片接连的字节存储单元并用指定的数据初始化。
— DCW ( DCWU ) 用于分配一片接连的半字存储单元并用指定的数据初始化。
— DCD ( DCDU ) 用于分配一片接连的字存储单元并用指定的数据初始化。
— DCFD ( DCFDU )用于为双精度的浮点数分配一片接连的字存储单元并用指定的数据初始
化。
— DCFS ( DCFSU ) 用于为单精度的浮点数分配一片接连的字存储单元并用指定的数据初
始化。
— DCQ ( DCQU ) 用于分配一片以 8 字节为单位的接连的存储单元并用指定的数据初始
化。
— SPACE 用于分配一片接连的存储单元
— MAP 用于界说一个结构化的内存表首地址
— FIELD 用于界说一个结构化的内存表的数据域
1、 DCB
语法格局:
标号 DCB 表达式
DCB 伪指令用于分配一片接连的字节存储单元并用伪指令中指定的表达式初始化。其间,表达式能够为 0 ~ 255 的数字或字符串。 DCB 也可用 “ = ” 替代。
运用示例:
Str DCB “ This is a test ! ” ;分配一片接连的字节存储单元并初始化。

2、 DCW(或DCWU)
语法格局:
标号 DCW (或 DCWU ) 表达式
DCW (或 DCWU )伪指令用于分配一片接连的半字存储单元并用伪指令中指定的表达式初始化。
其间,表达式能够为程序标号或数字表达式。。
用 DCW 分配的字存储单元是半字对齐的,而用 DCWU 分配的字存储单元并不严厉半字对齐。
运用示例:
DataTest DCW 1 , 2 , 3 ;分配一片接连的半字存储单元并初始化。

3、 DCD(或DCDU)
语法格局:
标号 DCD (或 DCDU ) 表达式
DCD (或 DCDU )伪指令用于分配一片接连的字存储单元并用伪指令中指定的表达式初始化。其间,表达式能够为程序标号或数字表达式。 DCD 也可用 “ ” 替代。
用 DCD 分配的字存储单元是字对齐的,而用 DCDU 分配的字存储单元并不严厉字对齐。
运用示例:
DataTest DCD 4 , 5 , 6 ;分配一片接连的字存储单元并初始化。

4、 DCFD(或DCFDU)
语法格局:
标号 DCFD (或 DCFDU ) 表达式
DCFD (或 DCFDU )伪指令用于为双精度的浮点数分配一片接连的字存储单元并用伪指令中指定的表达式初始化。每个双精度的浮点数占有两个字单元。用 DCFD 分配的字存储单元是字对齐的,而用 DCFDU 分配的字存储单元并不严厉字对齐。
运用示例:
FDataTest DCFD 2E115 , -5E7 ;分配一片接连的字存储单元并初始化为指定的双精度数。

5、 DCFS(或DCFSU)
语法格局:
标号 DCFS (或 DCFSU ) 表达式
DCFS (或 DCFSU )伪指令用于为单精度的浮点数分配一片接连的字存储单元并用伪指令中指定的表达式初始化。每个单精度的浮点数占有一个字单元。 用 DCFS 分配的字存储单元是字对齐的,而用 DCFSU 分配的字存储单元并不严厉字对齐。
运用示例:
FDataTest DCFS 2E5 , -5E - 7 ;分配一片接连的字存储单元并初始化为指定的单精度数。

6、 DCQ(或DCQU)
语法格局:
标号 DCQ (或 DCQU ) 表达式
DCQ (或 DCQU )伪指令用于分配一片以 8 个字节为单位的接连存储区域并用伪指令中指定的表达式初始化。
用 DCQ 分配的存储单元是字对齐的,而用 DCQU 分配的存储单元并不严厉字对齐。
运用示例:
DataTest DCQ 100 ;分配一片接连的存储单元并初始化为指定的值。

7、 SPACE
语法格局:
标号 SPACE 表达式
SPACE 伪指令用于分配一片接连的存储区域并初始化为 0 。其间,表达式为要分配的字节数。
SPACE 也可用 “ % ” 替代。
运用示例:
DataSpace SPACE 100 ;分配接连 100 字节的存储单元并初始化为 0 。

8、 MAP
语法格局:
MAP 表达式 { ,基址寄存器 }
MAP 伪指令用于界说一个结构化的内存表的首地址。 MAP 也可用 “ ^ ” 替代。
表达式能够为程序中的标号或数学表达式,基址寄存器为可选项,当基址寄存器选项不存在时,表达式的值即为内存表的首地址,当该选项存在时,内存表的首地址为表达式的值与基址寄存器的和。
MAP 伪指令一般与 FIELD 伪指令合作运用来界说结构化的内存表。
运用示例:
MAP 0x100 , R0 ;界说结构化内存表首地址的值为 0x100 + R0 。

9、 FILED
语法格局:
标号 FIELD 表达式
FIELD 伪指令用于界说一个结构化内存表中的数据域。 FILED 也可用 “ # ” 替代。
表达式的值为当时数据域在内存表中所占的字节数。
FIELD 伪指令常与 MAP 伪指令合作运用来界说结构化的内存表。 MAP 伪指令界说内存表的首地址, FIELD 伪指令界说内存表中的各个数据域,并能够为每个数据域指定一个标号供其他的指令引证。
留意 MAP 和 FIELD 伪指令仅用于界说数据结构,并不实践分配存储单元。
运用示例:
MAP 0x100 ;界说结构化内存表首地址的值为 0x100 。
A FIELD 16 ;界说 A 的长度为 16 字节,方位为 0x100
B FIELD 32 ;界说 B 的长度为 32 字节,方位为 0x110
S FIELD 256 ;界说 S 的长度为 256 字节,方位为 0x130

汇编操控( Assembly Control )伪指令
汇编操控伪指令用于操控汇编程序的履行流程,常用的汇编操控伪指令包括以下几条:
— IF 、 ELSE 、 ENDIF
— WHILE 、 WEND
— MACRO 、 MEND
— MEXIT
1、 IF、ELSE、ENDIF
语法格局:
IF 逻辑表达式
指令序列 1
ELSE
指令序列 2
ENDIF
IF 、 ELSE 、 ENDIF 伪指令能依据条件的建立与否决议是否履行某个指令序列。当 IF 后边的逻辑表达式为真,则履行指令序列 1 ,不然履行指令序列 2 。其间, ELSE 及指令序列 2 能够没有,此刻,当 IF 后边的逻辑表达式为真,则履行指令序列 1 ,不然持续履行后边的指令。
IF 、 ELSE 、 ENDIF 伪指令能够嵌套运用。
运用示例:
GBLL Test ;声明一个大局的逻辑变量,变量名为 Test……
IF Test = TRUE
指令序列 1
ELSE
指令序列 2
ENDIF

2、 WHILE、WEND
语法格局:
WHILE 逻辑表达式
指令序列
WEND
WHILE 、 WEND 伪指令能依据条件的建立与否决议是否循环履行某个指令序列。当 WHILE 后边的逻辑表达式为真,则履行指令序列,该指令序列履行完毕后,再判别逻辑表达式的值,若为真则持续履行,一直到逻辑表达式的值为假。
WHILE 、 WEND 伪指令能够嵌套运用。
运用示例:
GBLA Counter ;声明一个大局的数学变量,变量名为 Counter
Counter SETA 3 ;由变量Counter 操控循环次数
……
WHILE Counter 10
指令序列
WEND

3、 MACRO、MEND
语法格局:
$ 标号 宏名 $ 参数 1 , $ 参数 2 ,……
指令序列
MEND
MACRO 、 MEND 伪指令能够将一段代码界说为一个全体,称为宏指令,然后就能够在程序中经过宏指令屡次调用该段代码。其间, $ 标号在宏指令被打开时,标号会被替换为用户界说的符号,宏指令能够运用一个或多个参数,当宏指令被打开时,这些参数被相应的值替换。
宏指令的运用办法和功用与子程序有些类似,子程序能够供给模块化的程序设计、节约存储空间并进步运转速度。但在运用子程序结构时需求维护现场,然后增加了体系的开支,因而,在代码较短且需求传递的参数较多时,能够运用宏指令替代子程序。
包括在 MACRO 和 MEND 之间的指令序列称为宏界说体,在宏界说体的榜首行应声明宏的原型(包括宏名、所需的参数),然后就能够在汇编程序中经过宏名来调用该指令序列。在源程序被编译时,汇编器将宏调用打开,用宏界说中的指令序列替代程序中的宏调用,并将实践参数的值传递给宏界说中的形式参数。
MACRO 、 MEND 伪指令能够嵌套运用。

4、 MEXIT
语法格局:
MEXIT
MEXIT 用于从宏界说中跳转出去。

其他常用的伪指令
还有一些其他的伪指令,在汇编程序中经常会被运用,包括以下几条:
— 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 段同享同一段存储单元。
一个汇编语言程序至少要包括一个段,当程序太长时,也能够将程序分为多个代码段和数据段。
运用示例:
AREA Init , CODE , READONLY
该伪指令界说了一个代码段,段名为 Init ,特点为只读

2、 ALIGN
语法格局:
ALIGN { 表达式 { ,偏移量 }}
ALIGN 伪指令可经过增加填充字节的办法,使当时方位满意必定的对其办法 | 。其间,表达式的值用于指定对齐办法,或许的取值为 2 的幂,如 1 、 2 、 4 、 8 、 16 等。若未指定表达式,则将当时方位对齐到下一个字的方位。偏移量也为一个数字表达式,若运用该字段,则当时方位的对齐办法为: 2 的表达式次幂+偏移量。
运用示例:
AREA Init , 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 指令混合编程的代码里,可用这两条伪指令进行切换,但留意他们只告诉编译器这以后指令的类型,并不能对处理器进行状况的切换。
运用示例:
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 界说一个别号Temp

13、 ROUT
语法格局:
{ 称号 } ROUT
ROUT 伪指令用于给一个部分变量界说效果规模。在程序中未运用该伪指令时,部分变量的效果规模为地点的 AREA ,而运用 ROUT 后,部分变量的作为规模为当时 ROUT 和下一个 ROUT 之间

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/bandaoti/263419.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部