EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
ARM汇编指令之伪指令介绍。 ARM汇编伪指令 在ARM汇编语言程序里,有一些特殊指令助记符,这些助记符与指令系统的助记符不同,没有相对应的操作码,通常称这些特殊指令助记符为伪指令,他们所完成的操作称为伪操作。伪指令在源程序中的作用是为完成汇编程序作各种准备工作的,这些伪指令仅在汇编过程中起作用,一旦汇编结束,伪指令的使命就完成。 在ARM 的汇编程序中,有如下几种伪指令:符号定义伪指令、数据定义伪指令、汇编控制伪指令、宏指令以及其他伪指令。 4 T% P8 E8 d7 L' `
一、符号定义(Symbol Definition)伪指令 符号定义伪指令用于定义ARM 汇编程序中的变量、对变量赋值以及定义寄存器的别名等操作。 常见的符号定义伪指令有如下几种: ' m( d, T. P A* }# \$ k
— 用于定义全局变量的GBLA 、GBLL 和GBLS 。 3 {+ B: a- Q. c- D, Q5 o
— 用于定义局部变量的LCLA 、LCLL 和LCLS 。
' P( ]; L( Q! L9 @4 W, m — 用于对变量赋值的SETA 、SETL 、SETS 。 3 G$ c1 ], ^8 i2 x5 n
— 为通用寄存器列表定义名称的RLIST 。 1、GBLA、GBLL 和GBLS 语法格式: ( G6 d: B! W4 ~9 H, y
GBLA (GBLL 或GBLS )全局变量名 a" @* @9 p1 l( H* F* \: e
GBLA 、GBLL 和GBLS 伪指令用于定义一个ARM 程序中的全局变量,并将其初始化。其中:
/ V+ k5 W. f6 d$ \9 G7 K GBLA 伪指令用于定义一个全局的数字变量,并初始化为0 ; 1 P5 ^- b' |+ q3 h, D8 e
GBLL 伪指令用于定义一个全局的逻辑变量,并初始化为F(假);
e( C; W k! C8 Y( `! g2 N3 e GBLS 伪指令用于定义一个全局的字符串变量,并初始化为空; / L7 C @8 i% r7 n& v
由于以上三条伪指令用于定义全局变量,因此在整个程序范围内变量名必须唯一。 使用示例: GBLA Test1 ; 定义一个全局的数字变量,变量名为 Test1。 1 s" J7 v6 C# N; [0 Y9 z7 b+ Z. L; p7 }
Test1 SETA 0xaa ; 将该变量赋值为0xaa。 6 B. r9 S) p$ b y# R6 ?+ J) p
GBLL Test2 ; 定义一个全局的逻辑变量,变量名为 Test2。
6 M' B. Y( ]. t! s6 m+ ~+ `4 L E; d Test2 SETL {TRUE} ;将该变量赋值为真。
" v9 ~9 B( t" [7 r m, n3 H9 @ GBLS Test3 ; 定义一个全局的字符串变量,变量名为 Test3。
2 V( o; W0 H- i5 Z Test3 SETS “Testing” ;将该变量赋值为"Testing”。 & F: o7 m/ [: V' l- N) | a, u
2、LCLA、LCLL 和LCLS 语法格式: # h3 @" A) T( W4 S, A
LCLA (LCLL 或 LCLS )局部变量名
+ o3 S$ V# d# }: @! P- H5 V$ Q3 Z LCLA 、LCLL 和LCLS 伪指令用于定义一个ARM 程序中的局部变量,并将其初始化。其中:
- k9 `& Z- Z( P/ ?4 d* o LCLA伪指令用于定义一个局部的数字变量,并初始化为0 ;
# u+ q) A& u# K3 v% H* X LCLL伪指令用于定义一个局部的逻辑变量,并初始化为F(假);
. y7 @* L+ w3 _2 `; M LCLS伪指令用于定义一个局部的字符串变量,并初始化为空;
. M5 O0 n6 W% z6 a+ X 以上三条伪指令用于声明局部变量,在其作用范围内变量名必须唯一。 使用示例: LCLA Test4 ; 声明一个局部的数字变 量,变量名为Test4。 / z8 ~ a( V' k: F3 _
Test3 SETA 0xaa ; 将该变量赋值为0xaa。
2 r) m8 P. \6 z$ Z! J LCLL Test5 ; 声明一个局部的逻辑变 量,变量名为Test5。
: ?9 I4 K% I* W4 Q2 V/ X, Y- y Test4 SETL {TRUE} ;将该变量赋值为真。
3 ?3 ~& C/ m, x. T; N LCLS Test6 ; 定义一个局部的字 符串变量,变量名为Test6。
! `2 p/ l( p% t; y7 v Test6 SETS “Testing” ;将该变量赋值为 "Testing”。 ' T* U7 F; q2 W b. r5 o, U6 W, N( u
3、SETA、SETL 和SETS 语法格式: 3 d4 u/ `, b2 g4 M, v4 K
变量名 SETA (SETL 或 SETS )表达式
) q$ o2 G+ g: @ d3 D! X 伪指令 SETA 、SETL 、SETS 用于给一个已经定义的全局变量或局部变量赋值。
) K* w$ i- ^$ B# |% X! U+ }, Q0 I: [ SETA伪指令用于给一个数学变量赋值; : {5 d/ G1 _ J7 e5 p' W" i5 o
SETL伪指令用于给一个逻辑变量赋值; ' o. W( y+ ~- i% R
SETS伪指令用于给一个字符串变量赋值;
3 ~/ @( J6 T5 e$ Y8 f 其中,变量名为已经定义过的全局变量或局部变量,表达式为将要赋给变量的值。 使用示例:
+ a2 Q# u- b' A. M% h6 p LCLA Test3 ; 声明一个局部的数字变量,变量名为 Test3。
+ b2 S/ O4 {- M; _; [ Test3 SETA 0xaa ; 将该变量赋值为0xaa。
3 K5 @& _$ n6 E: y' k- o/ k LCLL Test4 ; 声明一个局部的逻辑变量,变量名为 Test4。
! X+ J0 O: Q7 w Test4 SETL {TRUE} ;将该变量赋值为真。 " @0 l; M4 k3 q; d& ]
4 、RLIST 语法格式:
! N+ Y @0 b/ d; c, K9 W1 Z. @% L 名称 RLIST { 寄存器列表 } RLIST伪指令可用于对一个通用寄存器列表定义名称,使用该伪指令定义的名称可在ARM 指令 LDM/STM中使用。在LDM/STM指令中,列表中的寄存器访问次序为根据寄存器的编号由低到高,而与列表中的寄存器排列次序无关。 使用示例:
3 V0 R% P Z6 v- J7 ] RegList RLIST {R0-R5 ,R8 ,R10} ;将寄存器列表名称定义为 RegList ,可在ARM指令LDM/STM中通过该名称访问寄存器列表。 ! j: V: R0 w: Z( o& |4 W6 d' Q
二、数据定义(Data Definition)伪指令
/ D9 Z9 w7 Z& J' p7 _8 p/ h+ a9 \
. @7 b( ]3 d% @" H. ? |