微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > ARM汇编书写格式及符号(symbol)和表达式(expr)

ARM汇编书写格式及符号(symbol)和表达式(expr)

时间:11-20 来源:互联网 点击:
汇编语言的语句格式如下:

{symbol}{instruction/directive/pseud0-instruction}{;comment}

symbol:标号/局部标号/常量/变量

instruction:指令

directive:伪操作

pseudo-instruction:伪指令

comment:注释

{}中括号内是可选

注意:

1.symbol必须顶格书写。(ARM汇编其后不加“:”)(GUN汇编要加“:”)

2.symbol命名规则:由字母,数字,下划线组成;除局部标号外,不能以数字开头。

3.指令不能顶格书写。

4.ARM指令,伪指令,伪操作,寄存器名可以全部为大写字母,也可全部为小写字母;不可大小写混用。

5.如果语句太长,可以将一条语句分几行来书写,在行末用“”表示换行(即下一行与本行为同一语句)。“”后不能有任何字符,包含空格和制表符(Tab)。

ARM汇编语言中的符号

symbol(标号)

本质:代表一个地址值。段内标号的地址值在汇编时确定;段外标号的地址值在连接时确定。

分类:3类(分类依据了 标号的生成方式)

基于PC的标号。基于PC的标号是位于目标指令前的标号或者程序中数据定义伪操作前的标号。这种标号在汇编时将被处理成PC值加上(或减去)一个数字常量。(常用于表示跳转指令的目标地址,或者代码段中所嵌入的少量数据。)
基于寄存器的标号。基于寄存器的标号常用MAP和FIELD来定义,也可以用EQU来定义。这种标号在汇编时将被处理成寄存器的值加上(或减去)一个数字常量。(常用于访问数据段中的数据。)
绝对地址。绝对地址是一个32位 数据。它可以寻址的范围为[0,232-1]即可以直接寻址整个内存空间。

symbol(局部标号)
局部标号主要在局部范围内使用。它由两部组成:开头是一个0-99直接的数字,后面紧接一个通常表示该局部变量作用范围的符号。
局部变量的作用范围通常为当前段,也可以用ROUT来定义局部变量的作用范围。
局部变量定义的语法格式:N{routname}
N:为0~99之间的数字。

routname:当前局部范围的名称(为符号),通常为该变量作用范围的名称(用ROUT伪操作定义的)。
局部变量引用的语法格式:%{F|B}{A|T}N{routname}
%:表示引用操作

N:为局部变量的数字号。
routname 为当前作用范围的名称(用ROUT伪操作定义的)
%:表示引用操作
F:指示编译器只向前搜索
B:指示编译器只向后搜索
A:指示编译器搜索宏的所有嵌套层次
T:指示编译器搜索宏的当前层次
注意:1.如果F和B都没有指定,编译器先向前搜索,再向后搜索
2.如果A和T都没有指定,编译器搜索所有从当前层次到宏的最高层次,比当前层次低的层次不再搜索。
3.如果指定了routname,编译器向前搜索最近的ROUT伪操作,若routname与该ROUT伪操作定义的名称不匹配,编译器报告错误,汇编失败。

symbol(常量)

数字常量是32位的整数。在ARM汇编语言中,使用EQU来定义数字常量。数字常量一经定义就不可修改。进行大小比较时,认为数字常量都是无符号数。

{数字常量:十进制数,十六进制数,n_XXX(n表示n(2-9)进制数,XXX是具体的数,例如:8_3777)

字符常量:用一对单引号括起,包含一个单字符或标准C中的转义字符。例如:‘A’‘n’

字符串常量:由一对双引号括起,包含一个字符串或标准C中的转义字符

布尔常量:{TRUE}和{FALSE}

}

注意:1.汇编器对-n和2^32-1不做区别;汇编时对关系运算符采用无符号数方式处理,这就意味着当0>-1是

{FLASE}的

symbol(变量)

在程序中,变量的值在汇编处理过程中可能会发生改变。在ARM汇编中变量有数字变量、逻辑变量和字符串变量3种类型。变量的类型在程序中是不可以改变的。
数字变量的取值范围为数字常量和数字表达式所能表示的数值;

无符号数[0,2的32次方-1],有符号数[负2的31次方,正2的31次方-1]

逻辑变量的取值范围为{true}和{flash};

字符串变量的取值范围为串表达式可以表达的范围。[0,512]字节

注意:汇编时变量的替换
1.如果在字符串变量前有一个$字符,在汇编时编译器将用改串的数值来取代该字符串变量。
2.如果在数字变量前面有一个$字符,在汇编时编译器将该数字变量的数值转换成十六进制的串,然后用该十六进制的串取代$字符后的数字变量。
3.如果在逻辑变量前面有一个$字符,在汇编时编译器将该逻辑变量替换成它的取值(T或者F)
4.如果程序中需要字符$,则用$$来表示,编译器将不进行变量替换,而是将$$当作$.
通常情况下,包含在两个竖线(|)之间的$并不表示进行变量替换。但是如果竖线(|)是在双引号内,则将进行变量替换。
5.使用“.”来表示变量名称的结束。

“.”也可能表示 当前指令地址(见下表)

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

网站地图

Top