EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
ARM汇编指令之伪指令介绍。 ARM汇编伪指令 在ARM汇编语言程序里,有一些特殊指令助记符,这些助记符与指令系统的助记符不同,没有相对应的操作码,通常称这些特殊指令助记符为伪指令,他们所完成的操作称为伪操作。伪指令在源程序中的作用是为完成汇编程序作各种准备工作的,这些伪指令仅在汇编过程中起作用,一旦汇编结束,伪指令的使命就完成。 在ARM 的汇编程序中,有如下几种伪指令:符号定义伪指令、数据定义伪指令、汇编控制伪指令、宏指令以及其他伪指令。
* G" z, S G+ k0 H' h- L+ e: ~
一、符号定义(Symbol Definition)伪指令 符号定义伪指令用于定义ARM 汇编程序中的变量、对变量赋值以及定义寄存器的别名等操作。 常见的符号定义伪指令有如下几种:
6 _6 L$ x- h2 b, X- v — 用于定义全局变量的GBLA 、GBLL 和GBLS 。 5 u4 K8 Q$ T7 x9 v
— 用于定义局部变量的LCLA 、LCLL 和LCLS 。
B- K6 m9 R2 w0 n5 B. g — 用于对变量赋值的SETA 、SETL 、SETS 。 & f$ Q, g V+ `7 |
— 为通用寄存器列表定义名称的RLIST 。 1、GBLA、GBLL 和GBLS 语法格式: a+ ^/ K, _- W% g
GBLA (GBLL 或GBLS )全局变量名
' t: u3 O) w! G GBLA 、GBLL 和GBLS 伪指令用于定义一个ARM 程序中的全局变量,并将其初始化。其中:
/ u- u+ y- W9 `) F# j6 M! t# n7 s GBLA 伪指令用于定义一个全局的数字变量,并初始化为0 ;
4 Y2 X+ o) B/ { K, T GBLL 伪指令用于定义一个全局的逻辑变量,并初始化为F(假);
" [$ i1 z6 b r5 b GBLS 伪指令用于定义一个全局的字符串变量,并初始化为空; 0 W8 h9 z+ w9 Z% i6 ^4 c
由于以上三条伪指令用于定义全局变量,因此在整个程序范围内变量名必须唯一。 使用示例: GBLA Test1 ; 定义一个全局的数字变量,变量名为 Test1。
0 A" d; I0 t+ O2 Q+ o Test1 SETA 0xaa ; 将该变量赋值为0xaa。 8 M! `' J! I, L3 r6 m/ k
GBLL Test2 ; 定义一个全局的逻辑变量,变量名为 Test2。 ) P. Q4 @6 e9 G% I0 |
Test2 SETL {TRUE} ;将该变量赋值为真。 1 g# V# D' B% S8 a
GBLS Test3 ; 定义一个全局的字符串变量,变量名为 Test3。
2 q( @8 G9 a. ^9 G5 g Test3 SETS “Testing” ;将该变量赋值为"Testing”。 ) ]1 G( H9 c: q! S4 y, }
2、LCLA、LCLL 和LCLS 语法格式:
, G& Z9 j2 i8 u( O; z LCLA (LCLL 或 LCLS )局部变量名 ; S8 Q4 g: J }0 W6 t$ J
LCLA 、LCLL 和LCLS 伪指令用于定义一个ARM 程序中的局部变量,并将其初始化。其中: " p& T' B; L$ Y* G6 f
LCLA伪指令用于定义一个局部的数字变量,并初始化为0 ; 4 K# @- y0 ?0 y4 q% h" p! H9 d
LCLL伪指令用于定义一个局部的逻辑变量,并初始化为F(假);
: l2 z, ]3 l& L% F* V LCLS伪指令用于定义一个局部的字符串变量,并初始化为空; & E8 j* J" N: ^( X# c1 J) @
以上三条伪指令用于声明局部变量,在其作用范围内变量名必须唯一。 使用示例: LCLA Test4 ; 声明一个局部的数字变 量,变量名为Test4。
* P9 D0 V+ Z5 S' V" ? Test3 SETA 0xaa ; 将该变量赋值为0xaa。 / x$ ^0 a0 b9 E2 I- ~( B
LCLL Test5 ; 声明一个局部的逻辑变 量,变量名为Test5。
6 F+ h8 n" r4 U2 f9 _- H$ L Test4 SETL {TRUE} ;将该变量赋值为真。 7 |3 i, v* v' {7 M) ^9 c
LCLS Test6 ; 定义一个局部的字 符串变量,变量名为Test6。 & x% ~5 _# U& ^
Test6 SETS “Testing” ;将该变量赋值为 "Testing”。
" i. J$ `1 s5 ~3、SETA、SETL 和SETS 语法格式: 7 H7 g$ {3 A5 L+ y
变量名 SETA (SETL 或 SETS )表达式 3 D3 V+ H$ i! V3 _7 P9 U# r
伪指令 SETA 、SETL 、SETS 用于给一个已经定义的全局变量或局部变量赋值。 , B% s" ~& e! ^) B# ^) y1 v1 F
SETA伪指令用于给一个数学变量赋值; C0 U8 s* v# L( [; B A5 L9 V# c
SETL伪指令用于给一个逻辑变量赋值; 5 _, y' I( Y% g' W
SETS伪指令用于给一个字符串变量赋值; 2 y4 C: v4 K( y B( X5 G
其中,变量名为已经定义过的全局变量或局部变量,表达式为将要赋给变量的值。 使用示例:
# P1 h6 u& f2 Z$ K LCLA Test3 ; 声明一个局部的数字变量,变量名为 Test3。 # E! d& H$ a' n3 w# C9 i( N
Test3 SETA 0xaa ; 将该变量赋值为0xaa。
" @. F, ?1 y2 L1 U LCLL Test4 ; 声明一个局部的逻辑变量,变量名为 Test4。
* J' |, R! X' N I+ N0 A+ ? Test4 SETL {TRUE} ;将该变量赋值为真。 : W) {; ?; O' p6 q, @) y2 y) I
4 、RLIST 语法格式: 9 A2 C/ y7 C2 A/ ]0 t: V
名称 RLIST { 寄存器列表 } RLIST伪指令可用于对一个通用寄存器列表定义名称,使用该伪指令定义的名称可在ARM 指令 LDM/STM中使用。在LDM/STM指令中,列表中的寄存器访问次序为根据寄存器的编号由低到高,而与列表中的寄存器排列次序无关。 使用示例:
, y( O( J/ Z+ n% R; g RegList RLIST {R0-R5 ,R8 ,R10} ;将寄存器列表名称定义为 RegList ,可在ARM指令LDM/STM中通过该名称访问寄存器列表。 ( l- ~, W% D; e, G4 e
二、数据定义(Data Definition)伪指令
" I$ w6 R) U7 N. G
, C7 s- F* t' w3 ` y, V |