EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
ARM汇编指令之伪指令介绍。 ARM汇编伪指令 在ARM汇编语言程序里,有一些特殊指令助记符,这些助记符与指令系统的助记符不同,没有相对应的操作码,通常称这些特殊指令助记符为伪指令,他们所完成的操作称为伪操作。伪指令在源程序中的作用是为完成汇编程序作各种准备工作的,这些伪指令仅在汇编过程中起作用,一旦汇编结束,伪指令的使命就完成。 在ARM 的汇编程序中,有如下几种伪指令:符号定义伪指令、数据定义伪指令、汇编控制伪指令、宏指令以及其他伪指令。
3 S' k. n3 e' v, D( o: v! C$ ~
一、符号定义(Symbol Definition)伪指令 符号定义伪指令用于定义ARM 汇编程序中的变量、对变量赋值以及定义寄存器的别名等操作。 常见的符号定义伪指令有如下几种:
- `, O# }! d* j3 t2 ^2 z — 用于定义全局变量的GBLA 、GBLL 和GBLS 。 5 J- N( o5 Z" O6 o4 C3 d3 E
— 用于定义局部变量的LCLA 、LCLL 和LCLS 。 9 x) k' [+ ]% p9 `# n }
— 用于对变量赋值的SETA 、SETL 、SETS 。
+ _+ A& u9 D/ W; j — 为通用寄存器列表定义名称的RLIST 。 1、GBLA、GBLL 和GBLS 语法格式: * d! B# y, W0 K& H1 }
GBLA (GBLL 或GBLS )全局变量名
$ q" W( ?( U/ I8 r8 B, o GBLA 、GBLL 和GBLS 伪指令用于定义一个ARM 程序中的全局变量,并将其初始化。其中: / L/ q. F, S$ h0 n- v# a; X# v0 @- C6 @
GBLA 伪指令用于定义一个全局的数字变量,并初始化为0 ;
# w2 D9 I. { s% d* _ @ GBLL 伪指令用于定义一个全局的逻辑变量,并初始化为F(假); 4 `7 I3 a" @: @: O5 Y
GBLS 伪指令用于定义一个全局的字符串变量,并初始化为空; " k' S7 Q- J1 J/ U7 H2 B
由于以上三条伪指令用于定义全局变量,因此在整个程序范围内变量名必须唯一。 使用示例: GBLA Test1 ; 定义一个全局的数字变量,变量名为 Test1。
( r- v' L( \" z Test1 SETA 0xaa ; 将该变量赋值为0xaa。 + j5 b- x9 s* c( U
GBLL Test2 ; 定义一个全局的逻辑变量,变量名为 Test2。 : B7 c( {" s- J3 n2 H
Test2 SETL {TRUE} ;将该变量赋值为真。 9 K2 o8 e8 ?$ l0 K' z/ y
GBLS Test3 ; 定义一个全局的字符串变量,变量名为 Test3。 5 @# C C* | T
Test3 SETS “Testing” ;将该变量赋值为"Testing”。 # n' W0 W& B- z7 L$ d* S0 b8 B
2、LCLA、LCLL 和LCLS 语法格式:
3 J) o a9 Q0 z. \ LCLA (LCLL 或 LCLS )局部变量名 ) b6 |* \$ C" D6 x7 G) Y
LCLA 、LCLL 和LCLS 伪指令用于定义一个ARM 程序中的局部变量,并将其初始化。其中:
- I5 O9 \6 z I, ^, D9 o LCLA伪指令用于定义一个局部的数字变量,并初始化为0 ; 8 g) }* N- V5 {) ]4 z
LCLL伪指令用于定义一个局部的逻辑变量,并初始化为F(假); # |7 V' w0 o" F4 l0 R
LCLS伪指令用于定义一个局部的字符串变量,并初始化为空;
, D5 A& t; m/ K/ @ @4 u3 h" M 以上三条伪指令用于声明局部变量,在其作用范围内变量名必须唯一。 使用示例: LCLA Test4 ; 声明一个局部的数字变 量,变量名为Test4。
5 k2 C+ ^9 j! u o2 l Test3 SETA 0xaa ; 将该变量赋值为0xaa。
3 p8 p2 r9 F% |4 Y6 w- Y# I. S4 q( \- w LCLL Test5 ; 声明一个局部的逻辑变 量,变量名为Test5。 8 j+ v* P5 K4 W, `2 x& ]; b6 E
Test4 SETL {TRUE} ;将该变量赋值为真。
7 Y% ~% z7 A; x9 d LCLS Test6 ; 定义一个局部的字 符串变量,变量名为Test6。
4 Y: S. b5 |; v7 p: \ Test6 SETS “Testing” ;将该变量赋值为 "Testing”。
6 |* ?' ^0 i. D( \. \9 O3、SETA、SETL 和SETS 语法格式: 5 \8 O# Q; f: ^' i
变量名 SETA (SETL 或 SETS )表达式 - G+ _& {% G' Y0 d5 m
伪指令 SETA 、SETL 、SETS 用于给一个已经定义的全局变量或局部变量赋值。 9 R o% M/ `5 t4 ^; ~' @
SETA伪指令用于给一个数学变量赋值;
/ k0 W% F7 l1 S, P; d5 _( v SETL伪指令用于给一个逻辑变量赋值; - g; G7 q( b2 e% y, [
SETS伪指令用于给一个字符串变量赋值;
- A5 N( M3 S$ v" \* x5 C% J 其中,变量名为已经定义过的全局变量或局部变量,表达式为将要赋给变量的值。 使用示例:
% a6 A4 ]% I$ x0 z4 V& ?( k, S& O: K LCLA Test3 ; 声明一个局部的数字变量,变量名为 Test3。
' ^. e. {# [# Q' M8 A Test3 SETA 0xaa ; 将该变量赋值为0xaa。
) z0 s% p. z( z: v/ f7 M LCLL Test4 ; 声明一个局部的逻辑变量,变量名为 Test4。
1 y# c( b" J3 u( t Test4 SETL {TRUE} ;将该变量赋值为真。 9 ^$ Q3 r3 t1 p8 S) o' z; d4 v
4 、RLIST 语法格式:
9 s/ V7 a$ K" }1 C 名称 RLIST { 寄存器列表 } RLIST伪指令可用于对一个通用寄存器列表定义名称,使用该伪指令定义的名称可在ARM 指令 LDM/STM中使用。在LDM/STM指令中,列表中的寄存器访问次序为根据寄存器的编号由低到高,而与列表中的寄存器排列次序无关。 使用示例: 7 T; `& Q/ t4 A* B5 G0 V* k! t
RegList RLIST {R0-R5 ,R8 ,R10} ;将寄存器列表名称定义为 RegList ,可在ARM指令LDM/STM中通过该名称访问寄存器列表。 7 u! n, o6 Z9 F m. a* w! l- e% g7 s
二、数据定义(Data Definition)伪指令
6 R! K2 o2 l7 F. s: i( ^
( C2 f9 k1 K& k& [; J- l |