登录 立即注册

电子DIY创易联盟

查看: 1976|回复: 41

ARM中伪指令简介

[复制链接]
#论坛管理认证#  论坛管理认证

累计签到:112 天
连续签到:1 天

122

帖子

1461

积分

3

听众

版主

Rank: 18Rank: 18

积分
1461
发表于 2017-8-12 18:07:07 | 显示全部楼层 |阅读模式

终于等到你!马上注册,和广大电子DIY爱好者一起玩耍,还有更多功能和福利等着你!

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
大家好!{:3_52:}    我 Alex 又来了!
    这次带来的是《ARM伪指令简介》。
    希望这次能给大家带来点有用的资讯!
    谢谢围观!好人1生平安!



前言
    在 ARM 汇编语言程序里,有一些特殊指令助记符,这些助记符与指令系统的助记符不同,没有相对应的操作码,通常称这些特殊指令助记符为:伪指令,他们所完成的操作称为:伪操作。伪指令在源程序中的作用是为了完成汇编程序作各种准备工作的,这些伪指令仅在汇编过程中起作用,一旦汇编结束,伪指令的使命就OVER了。


在 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_62:}{:3_62:}{:3_62:}




点评

帖子发出来是给别人看的,本来可以发在1-2贴上为什么要分那么多小贴,意义何在?纯粹为了刷数量?  发表于 2017-8-13 10:34
#论坛管理认证#  论坛管理认证

累计签到:112 天
连续签到:1 天

122

帖子

1461

积分

3

听众

版主

Rank: 18Rank: 18

积分
1461
发表于 2017-8-12 18:15:35 | 显示全部楼层

1、 AREA
    语法格式:
AREA 段名 属性 1 ,属性 2 ,……
    AREA 伪指令用于定义一个代码段或数据段。其中,段名若以数字开头,则该段名需用 “ | ” 括起来,如 |1_test| 。
    属性字段表示该代码段(或数据段)的相关属性,多个属性用逗号分隔。常用的属性如下:
— CODE 属性:用于定义代码段,默认为 READONLY 。
— DATA 属性:用于定义数据段,默认为 READWRITE 。
— READONLY 属性:指定本段为只读,代码段默认为 READONLY 。
— READWRITE 属性:指定本段为可读可写,数据段的默认属性为 READWRITE 。
— ALIGN 属性:使用方式为 ALIGN 表达式。在默认时, ELF (可执行连接文件)的代码段和数据段是按字对齐的,表达式的取值范围为 0 ~ 31 ,相应的对齐方式为 2 表达式次方。
— COMMON 属性:该属性定义一个通用的段,不包含任何的用户代码和数据。各源文件中同名的 COMMON 段共享同一段存储单元。
    一个汇编语言程序至少要包含一个段,当程序太长时,也可以将程序分为多个代码段和数据段。

    使用示例:
AREA Init , CODE , READONLY
    该伪指令定义了一个代码段,段名为 Init ,属性为只读。





欲知后事如何,且看跟贴分解!
希望能对您有帮助!!!
#论坛管理认证#  论坛管理认证

累计签到:112 天
连续签到:1 天

122

帖子

1461

积分

3

听众

版主

Rank: 18Rank: 18

积分
1461
发表于 2017-8-12 18:14:31 | 显示全部楼层
3、 MACRO、MEND
    语法格式:
$ 标号 宏名 $ 参数 1 , $ 参数 2 ,……
指令序列
MEND

    MACRO 、 MEND 伪指令可以将一段代码定义为一个整体,称为宏指令,然后就可以在程序中通过宏指令多次调用该段代码。其中, $ 标号在宏指令被展开时,标号会被替换为用户定义的符号, 宏指令可以使用一个或多个参数,当宏指令被展开时,这些参数被相应的值替换。
    宏指令的使用方式和功能与子程序有些相似,子程序可以提供模块化的程序设计、节省存储空间并提高运行速度。但在使用子程序结构时需要保护现场,从而增加了系统的开销,因此,在代码较短且需要传递的参数较多时,可以使用宏指令代替子程序。包含在 MACRO 和 MEND 之间的指令序列称为宏定义体,在宏定义体的第一行应声明宏的原型(包含宏名、所需的参数),然后就可以在汇编程序中通过宏名来调用该指令序列。在源程序被编译时,汇编器将宏调用展开,用宏定义中的指令序列代替程序中的宏调用,并将实际参数的值传递给宏定义中的形式参数。
    MACRO 、 MEND 伪指令可以嵌套使用。




欲知后事如何,且看跟贴分解!
希望能对您有帮助!!!
#论坛管理认证#  论坛管理认证

累计签到:112 天
连续签到:1 天

122

帖子

1461

积分

3

听众

版主

Rank: 18Rank: 18

积分
1461
发表于 2017-8-12 18:16:33 | 显示全部楼层
3、 CODE16、CODE32
    语法格式:
CODE16 (或 CODE32 )
CODE16 伪指令通知编译器,其后的指令序列为 16 位的 Thumb 指令。
CODE32 伪指令通知编译器,其后的指令序列为 32 位的 ARM 指令。
    若在汇编源程序中同时包含 ARM 指令和 Thumb 指令时,可用 CODE16 伪指令通知编译器其后的指令序列为 16 位的 Thumb 指令, CODE32 伪指令通知编译器其后的指令序列为 32 位的 ARM 指令。因此,在使用 ARM 指令和 Thumb 指令混合编程的代码里,可用这两条伪指令进行切换,但注意他们只通知编译器其后指令的类型,并不能对处理器进行状态的切换。

    使用示例:
AREA Init , CODE , READONLY
……
CODE32 ;//通知编译器其后的指令为 32 位的 ARM 指令
LDR R0 ,= NEXT + 1 ;//将跳转地址放入寄存器 R0
BX R0 ;//程序跳转到新的位置执行,并将处理器切换到 Thumb 工作状态
……
CODE16 ;//通知编译器其后的指令为 16 位的 Thumb 指令
NEXT LDR R3,=0x3FF
……
END ;//程序结束




欲知后事如何,且看跟贴分解!
希望能对您有帮助!!!
#论坛管理认证#  论坛管理认证

累计签到:112 天
连续签到:1 天

122

帖子

1461

积分

3

听众

版主

Rank: 18Rank: 18

积分
1461
发表于 2017-8-12 18:07:41 | 显示全部楼层
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} ;将该变量赋值为真


欲知后事如何,且看跟贴分解!
希望能对您有帮助!!!
#论坛管理认证#  论坛管理认证

累计签到:112 天
连续签到:1 天

122

帖子

1461

积分

3

听众

版主

Rank: 18Rank: 18

积分
1461
发表于 2017-8-12 18:08:08 | 显示全部楼层
4 、 RLIST
    语法格式:
名称 RLIST { 寄存器列表 }
    RLIST 伪指令可用于对一个通用寄存器列表定义名称,使用该伪指令定义的名称可在 ARM 指令 LDM/STM 中使用。在 LDM/STM 指令中,列表中的寄存器访问次序为根据寄存器的编号由低到高,而与列表中的寄存器排列次序无关。

    使用示例:
RegList RLIST {R0-R5 , R8 , R10} ;将寄存器列表名称定义为 RegList ,可在 ARM 指令 LDM/STM中通过该名称访问寄存器列表。


欲知后事如何,且看跟贴分解!
希望能对您有帮助!!!
#论坛管理认证#  论坛管理认证

累计签到:112 天
连续签到:1 天

122

帖子

1461

积分

3

听众

版主

Rank: 18Rank: 18

积分
1461
发表于 2017-8-12 18:08:43 | 显示全部楼层
本帖最后由 AlexOne.Link 于 2017-8-12 18:22 编辑

    数据定义( Data Definition )伪指令
    数据定义伪指令一般用于为特定的数据分配存储单元,同时可完成已分配存储单元的初始化。
    常见的数据定义伪指令有如下几种:
— DCB 用于分配一片连续的字节存储单元并用指定的数据初始化。
— DCW ( DCWU ) 用于分配一片连续的半字存储单元并用指定的数据初始化。
— DCD ( DCDU ) 用于分配一片连续的字存储单元并用指定的数据初始化。
— DCFD ( DCFDU )用于为双精度的浮点数分配一片连续的字存储单元并用指定的数据初始化。
— DCFS ( DCFSU ) 用于为单精度的浮点数分配一片连续的字存储单元并用指定的数据初始化。
— DCQ ( DCQU ) 用于分配一片以 8 字节为单位的连续的存储单元并用指定的数据初始化。
— SPACE 用于分配一片连续的存储单元。
— MAP 用于定义一个结构化的内存表首地址。
— FIELD 用于定义一个结构化的内存表的数据域。





欲知后事如何,且看跟贴分解!
希望能对您有帮助!!!
#论坛管理认证#  论坛管理认证

累计签到:112 天
连续签到:1 天

122

帖子

1461

积分

3

听众

版主

Rank: 18Rank: 18

积分
1461
发表于 2017-8-12 18:09:15 | 显示全部楼层
1、 DCB
    语法格式:
标号 DCB 表达式
    DCB 伪指令用于分配一片连续的字节存储单元并用伪指令中指定的表达式初始化。其中,表达式可以为 0 ~ 255 的数字或字符串。 DCB 也可用 “ = ” 代替。
    使用示例:
Str DCB “ This is a test ! ” ;//分配一片连续的字节存储单元并初始化。





欲知后事如何,且看跟贴分解!
希望能对您有帮助!!!
#论坛管理认证#  论坛管理认证

累计签到:112 天
连续签到:1 天

122

帖子

1461

积分

3

听众

版主

Rank: 18Rank: 18

积分
1461
发表于 2017-8-12 18:09:37 | 显示全部楼层
2、 DCW(或DCWU)
    语法格式:
标号 DCW (或 DCWU ) 表达式
    DCW (或 DCWU )伪指令用于分配一片连续的半字存储单元并用伪指令中指定的表达式初始化。
    其中,表达式可以为程序标号或数字表达式。用 DCW 分配的字存储单元是半字对齐的,而用 DCWU 分配的字存储单元并不严格半字对齐。
    使用示例:
DataTest DCW 1 , 2 , 3 ;//分配一片连续的半字存储单元并初始化。



欲知后事如何,且看跟贴分解!
希望能对您有帮助!!!
#论坛管理认证#  论坛管理认证

累计签到:112 天
连续签到:1 天

122

帖子

1461

积分

3

听众

版主

Rank: 18Rank: 18

积分
1461
发表于 2017-8-12 18:09:57 | 显示全部楼层
3、 DCD(或DCDU)
    语法格式:
标号 DCD (或 DCDU ) 表达式
    DCD (或 DCDU )伪指令用于分配一片连续的字存储单元并用伪指令中指定的表达式初始化。其中,表达式可以为程序标号或数字表达式。 DCD 也可用 “ & ” 代替。用 DCD 分配的字存储单元是字对齐的,而用 DCDU 分配的字存储单元并不严格字对齐。
    使用示例:
DataTest DCD 4 , 5 , 6 ;//分配一片连续的字存储单元并初始化。




欲知后事如何,且看跟贴分解!
希望能对您有帮助!!!
#论坛管理认证#  论坛管理认证

累计签到:112 天
连续签到:1 天

122

帖子

1461

积分

3

听众

版主

Rank: 18Rank: 18

积分
1461
发表于 2017-8-12 18:10:15 | 显示全部楼层
4、 DCFD(或DCFDU)
    语法格式:
标号 DCFD (或 DCFDU ) 表达式
    DCFD (或 DCFDU )伪指令用于为双精度的浮点数分配一片连续的字存储单元并用伪指令中指定的表达式初始化。每个双精度的浮点数占据两个字单元。用 DCFD 分配的字存储单元是字对齐的,而用 DCFDU 分配的字存储单元并不严格字对齐。
    使用示例:
FDataTest DCFD 2E115 , -5E7 ;//分配一片连续的字存储单元并初始化为指定的双精度数。




欲知后事如何,且看跟贴分解!
希望能对您有帮助!!!
#论坛管理认证#  论坛管理认证

累计签到:112 天
连续签到:1 天

122

帖子

1461

积分

3

听众

版主

Rank: 18Rank: 18

积分
1461
发表于 2017-8-12 18:11:03 | 显示全部楼层
5、 DCFS(或DCFSU)
    语法格式:
标号 DCFS (或 DCFSU ) 表达式
    DCFS (或 DCFSU )伪指令用于为单精度的浮点数分配一片连续的字存储单元并用伪指令中指定的表达式初始化。每个单精度的浮点数占据一个字单元。用 DCFS 分配的字存储单元是字对齐的,而用 DCFSU 分配的字存储单元并不严格字对齐。
    使用示例:
FDataTest DCFS 2E5 , -5E - 7 ;//分配一片连续的字存储单元并初始化为指定的单精度数。




欲知后事如何,且看跟贴分解!
希望能对您有帮助!!!
#论坛管理认证#  论坛管理认证

累计签到:112 天
连续签到:1 天

122

帖子

1461

积分

3

听众

版主

Rank: 18Rank: 18

积分
1461
发表于 2017-8-12 18:11:26 | 显示全部楼层
6、 DCQ(或DCQU)
    语法格式:
标号 DCQ (或 DCQU ) 表达式
    DCQ (或 DCQU )伪指令用于分配一片以 8 个字节为单位的连续存储区域并用伪指令中指定的表达式初始化。 用 DCQ 分配的存储单元是字对齐的,而用 DCQU 分配的存储单元并不严格字对齐。
    使用示例:
DataTest DCQ 100 ;//分配一片连续的存储单元并初始化为指定的值。




欲知后事如何,且看跟贴分解!
希望能对您有帮助!!!

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 收藏帖子 搜索
快速回复 返回顶部 返回列表