《电子技术应用》
您所在的位置:首页 > 嵌入式技术 > 解决方案 > ARM汇编伪指令介绍1

ARM汇编伪指令介绍1

2017-06-22
关键词: 汇编语言

  在 ARM 汇编语言程序里,有一些特殊指令助记符,这些助记符与指令系统的助记符不同,没有相对应的操作码,通常称这些特殊指令助记符为伪指令,他们所完成的操作称为伪操作。伪指令在源程序中的作用是为完成汇编程序作各种准备工作的,这些伪指令仅在汇编过程中起作用,一旦汇编结束,伪指令的使命就完成。     
 
    在 ARM 的汇编程序中,有如下几种伪指令:符号定义伪指令、数据定义伪指令、汇编控制伪指令、宏指令以及其他伪指令。

    符号定义( Symbol Definition )伪指令    
    符号定义伪指令用于定义 ARM 汇编程序中的变量、对变量赋值以及定义寄存器的别名等操作。    
    常见的符号定义伪指令有如下几种:    
    — 用于定义全局变量的 GBLA 、 GBLL 和 GBLS 。    
    — 用于定义局部变量的 LCLA 、 LCLL 和 LCLS 。    
    — 用于对变量赋值的 SETA 、 SETL 、 SETS 。    
    — 为通用寄存器列表定义名称的 RLIST 。    
    1、 GBLA、GBLL 和GBLS    
    语法格式:    
    GBLA ( GBLL 或 GBLS ) 全局变量名    
    GBLA 、 GBLL 和 GBLS 伪指令用于定义一个 ARM 程序中的全局变量,并将其初始化。其中:    
    GBLA 伪指令用于定义一个全局的数字变量,并初始化为 0 ;    
    GBLL 伪指令用于定义一个全局的逻辑变量,并初始化为 F (假);    
    GBLS 伪指令用于定义一个全局的字符串变量,并初始化为空;    
    由于以上三条伪指令用于定义全局变量,因此在整个程序范围内变量名必须唯一。    
    使用示例:    
    GBLA Test1 ;定义一个全局的数字变量,变量名为 Test1    
    Test1 SETA 0xaa ;将该变量赋值为 0xaa    
    GBLL Test2 ;定义一个全局的逻辑变量,变量名为 Test2    
    Test2 SETL {TRUE} ;将该变量赋值为真    
    GBLS Test3 ;定义一个全局的字符串变量,变量名为 Test3    
    Test3 SETS “ Testing ” ;将该变量赋值为 “ Testing ”  
  
    2、 LCLA、LCLL 和LCLS    
    语法格式:    
    LCLA ( LCLL 或 LCLS ) 局部变量名    
    LCLA 、 LCLL 和 LCLS 伪指令用于定义一个 ARM 程序中的局部变量,并将其初始化。其中:    
    LCLA 伪指令用于定义一个局部的数字变量,并初始化为 0 ;    
    LCLL 伪指令用于定义一个局部的逻辑变量,并初始化为 F (假);    
    LCLS 伪指令用于定义一个局部的字符串变量,并初始化为空;    
    以上三条伪指令用于声明局部变量,在其作用范围内变量名必须唯一。    
    使用示例:    
    LCLA Test4 ;声明一个局部的数字变量,变量名为 Test4    
    Test3 SETA 0xaa ;将该变量赋值为 0xaa    
    LCLL Test5 ;声明一个局部的逻辑变量,变量名为 Test5    
    Test4 SETL {TRUE} ;将该变量赋值为真    
    LCLS Test6 ;定义一个局部的字符串变量,变量名为 Test6    
    Test6 SETS “ Testing ” ;将该变量赋值为 “ Testing ”   

 3、 SETA、SETL 和SETS    
    语法格式:    
    变量名 SETA ( SETL 或 SETS ) 表达式    
    伪指令 SETA 、 SETL 、 SETS 用于给一个已经定义的全局变量或局部变量赋值。    
    SETA 伪指令用于给一个数学变量赋值;    
    SETL 伪指令用于给一个逻辑变量赋值;    
    SETS 伪指令用于给一个字符串变量赋值;    
    其中,变量名为已经定义过的全局变量或局部变量,表达式为将要赋给变量的值。    
    使用示例:    
    LCLA Test3 ;声明一个局部的数字变量,变量名为 Test3    
    Test3 SETA 0xaa ;将该变量赋值为 0xaa    
    LCLL Test4 ;声明一个局部的逻辑变量,变量名为 Test4    
    Test4 SETL {TRUE} ;将该变量赋值为真    

    4 、 RLIST    
    语法格式:    
    名称 RLIST { 寄存器列表 }    
    RLIST 伪指令可用于对一个通用寄存器列表定义名称,使用该伪指令定义的名称可在 ARM 指令 LDM/STM 中使用。在 LDM/STM 指令中,列表中的寄存器访问次序为根据寄存器的编号由低到高,而与列表中的寄存器排列次序无关。    
    使用示例:    
    RegList RLIST {R0-R5 , R8 , R10} ;将寄存器列表名称定义为 RegList ,可在 ARM 指令 LDM/STM中通过该名称访问寄存器列表。   

本站内容除特别声明的原创文章之外,转载内容只为传递更多信息,并不代表本网站赞同其观点。转载的所有的文章、图片、音/视频文件等资料的版权归版权所有权人所有。本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如涉及作品内容、版权和其它问题,请及时通过电子邮件或电话通知我们,以便迅速采取适当措施,避免给双方造成不必要的经济损失。联系电话:010-82306118;邮箱:aet@chinaaet.com。