第五章、ARM汇编语言程序设计 ·伪操作 ·汇编语言语句格式 ·汇编语言程序格式 ·汇编编译器的使用 ·汇编程序设计举例
第五章、ARM汇编语言程序设计 • 伪操作 • 汇编语言语句格式 • 汇编语言程序格式 • 汇编编译器的使用 • 汇编程序设计举例
一、伪操作 ·伪操作: 一不像机器指令那样在计算机运行期间由机器执 行,它是在汇编程序对源程序汇编期间由汇编 程序处理的。 宏: 一是一段独立的程序代码。 一在程序中通过宏指令调用宏。 一当程序被汇编时,汇编程序将对每个宏调用作 展开,用宏定义体取代程序中的宏指令
一、伪操作 • 伪操作: – 不像机器指令那样在计算机运行期间由机器执 行,它是在汇编程序对源程序汇编期间由汇编 程序处理的。 • 宏: – 是一段独立的程序代码。 – 在程序中通过宏指令调用宏。 – 当程序被汇编时,汇编程序将对每个宏调用作 展开,用宏定义体取代程序中的宏指令
伪操作分为: ·符号定义(Symbol definition)伪操作 ·数据定义(Data definition)伪操作 ● 汇编控制(Assembly control)伪操作 ·框架描述(Frame description)伪操作 ·信息报告(Reporting)伪操作 ·其他(Miscellaneous)伪操作
伪操作分为: • 符号定义(Symbol definition)伪操作 • 数据定义(Data definition)伪操作 • 汇编控制(Assembly control)伪操作 • 框架描述(Frame description)伪操作 • 信息报告(Reporting)伪操作 • 其他(Miscellaneous)伪操作
一.符号定义伪操作 用于定义ARM汇编程序的变量,对变量进行赋值 以及定义寄存器名称。包括以下伪操作: GBLA、GBLL及GBLS声明全局变量。 LCLA、LCLL及LCLS声明局部变量。 SETA、SETL及SETS给变量赋值。 RLIST 为通用寄存器列表定义名称。 CN 为协处理器的寄存器定义名称。 CP 为协处理器定义名称。 DN及SN为VFP的寄存器定义名称。 FN 为FPA的浮点寄存器定义名称
一.符号定义伪操作 用于定义ARM汇编程序的变量,对变量进行赋值 以及定义寄存器名称。包括以下伪操作: • GBLA 、GBLL 及GBLS声明全局变量。 • LCLA 、LCLL 及LCLS 声明局部变量。 • SETA 、SETL 及SETS 给变量赋值。 • RLIST 为通用寄存器列表定义名称。 • CN 为协处理器的寄存器定义名称。 • CP 为协处理器定义名称。 • DN 及SN 为VFP的寄存器定义名称。 • FN 为FPA的浮点寄存器定义名称
1.GBLA、GBLL和GBLS 用于声明一个ARM程序中的全局变量,并将其 初始化。 GBLA声明一个全局的算术变量,并将其初始化成0。 ● GBLL声明一个全局的逻辑变量,并将其初始化成FALSE} GBLS声明一个全局的串变量,并将其初始化成空串“”。 句法: variable 其中:是3种伪操作之一:GBLA、GBLL和GBLS variable是所说明的全局变量的名称。在其作用范围内唯 用法: 如果用这些伪操作重新声明己经声明过的变量,则变量 的值将被初始化成后一次声明语句中的值。 全局变量的作用范围为包含该变量的源程序
1. GBLA、GBLL和GBLS • 用于声明一个ARM程序中的全局变量,并将其 初始化。 • GBLA声明一个全局的算术变量,并将其初始化成0。 • GBLL声明一个全局的逻辑变量,并将其初始化成{FALSE} • GBLS声明一个全局的串变量,并将其初始化成空串“ ”。 • 句法: variable 其中:是3种伪操作之一:GBLA、GBLL和GBLS variable是所说明的全局变量的名称。在其作用范围内唯 一。 • 用法: 如果用这些伪操作重新声明已经声明过的变量,则变量 的值将被初始化成后一次声明语句中的值。 全局变量的作用范围为包含该变量的源程序
1.GBLA、GBLL和GBLS ·例子: GBLA objectsize;声明一个全局的算术变量。 objectsize SETA 0xff;向该变量赋值 SPACE objectsize;引用该变量 GBLL statusB ;声明一个全局逻辑变量statusB statusB SETL{TRUE};向该变量赋值
• 例子: GBLA objectsize ;声明一个全局的算术变量。 objectsize SETA 0xff;向该变量赋值 SPACE objectsize ;引用该变量 GBLL statusB ;声明一个全局逻辑变量statusB statusB SETL {TRUE};向该变量赋值 1. GBLA、GBLL和GBLS
2.LCLA、LCLL和LCLS 用于声明一个ARM程序中的局部变量,并将其 初始化。 ● LCLA声明一个局部的算术变量,并将其初始化成0。 LCLL声明一个局部的逻辑变量,并将其初始化成FALSE} ● LCLS声明一个局部的串变量,并将其初始化成空串“”。 ● 句法: variable 其中:是3种伪操作之一:LCLA、LCLL和LCLS variable是所说明的局部变量的名称。在其作用范围内唯 用法: 如果用这些伪操作重新声明己经声明过的变量,则变量 的值将被初始化成后一次声明语句中的值。 局部变量的作用范围为包含该局部变量的宏代码的一个实例
2. LCLA、LCLL和LCLS • 用于声明一个ARM程序中的局部变量,并将其 初始化。 • LCLA声明一个局部的算术变量,并将其初始化成0。 • LCLL声明一个局部的逻辑变量,并将其初始化成{FALSE} • LCLS声明一个局部的串变量,并将其初始化成空串“ ”。 • 句法: variable 其中:是3种伪操作之一:LCLA、LCLL和LCLS variable是所说明的局部变量的名称。在其作用范围内唯 一。 • 用法: 如果用这些伪操作重新声明已经声明过的变量,则变量 的值将被初始化成后一次声明语句中的值。 局部变量的作用范围为包含该局部变量的宏代码的一个实例
2.LCLA、LCLL和LCLS ·例子: MACRO ;声明一个宏 Slabel r message$a;宏的原型 LCLS err ;声明一个局部串变量err。 err SETS“error no:”;向该变量赋值 Slabel ;代码 INFO O,“err”:CC:STR:$a;使用该串变量 MEND ;宏定义结束
• 例子: MACRO ;声明一个宏 $label message $a;宏的原型 LCLS err ;声明一个局部串变量err。 err SETS “error no:”;向该变量赋值 $label ;代码 INFO 0,“err”:CC::STR:$a ;使用该串变量 MEND ;宏定义结束 2. LCLA、LCLL和LCLS
3.SETA、SETL和SETS 用于给一个ARM程序中的变量赋值。 SETA给一个算术变量赋值。 SETL给一个逻辑变量赋值。 SETS给一个串变量赋值。 句法: variable expr 其中:是3种伪操作之一:SETA、SETL和SETS variable是已定义变量的名称。在其作用范围内唯一。在 向变量赋值前必须先声明该变量。 例子: GBLA objectsize objectsize SETA Oxff SPACE objectsize
3. SETA、SETL和SETS • 用于给一个ARM程序中的变量赋值。 • SETA给一个算术变量赋值。 • SETL给一个逻辑变量赋值。 • SETS给一个串变量赋值。 • 句法: variable expr 其中:是3种伪操作之一:SETA、SETL和SETS variable是已定义变量的名称。在其作用范围内唯一。在 向变量赋值前必须先声明该变量。 • 例子: GBLA objectsize objectsize SETA 0xff SPACE objectsize
4.RLIST 为一个通用寄存器列表定义名称。 句法: name RLIST {list-of-register 其中:name为寄存器列表的名称。 {list-of-register}为通用寄存器列表。 。用法: 定义的名称可以在LDM/STM指令中使用。在LDM/STM 指令中,寄存器列表中的寄存器访问次序总是先访问 编号较低的寄存器,再访问编号较高的寄存器,而不 管寄存器列表中各寄存器的排列顺序。 例子: Context RLIST RO-R6,R8,R10-R12,R15} ;将寄存器列表名称定义为Context
4. RLIST • 为一个通用寄存器列表定义名称。 • 句法: name RLIST {list-of-register} 其中:name为寄存器列表的名称。 {list-of-register}为通用寄存器列表。 • 用法: 定义的名称可以在LDM/STM指令中使用。在LDM/STM 指令中,寄存器列表中的寄存器访问次序总是先访问 编号较低的寄存器,再访问编号较高的寄存器,而不 管寄存器列表中各寄存器的排列顺序。 • 例子: Context RLIST {R0-R6,R8,R10-R12,R15} ;将寄存器列表名称定义为Context