新聞中心

ARM匯編偽指令詳解(2)

作者: 時(shí)間:2016-11-21 來(lái)源:網(wǎng)絡(luò) 收藏
字(Word):在ARM體系結(jié)構(gòu)中,字的長(zhǎng)度為32位,而在8位/16位處理器體系結(jié)構(gòu)中,字的長(zhǎng)度一般為16位。

半字(Half-Word):在ARM體系結(jié)構(gòu)中,半字的長(zhǎng)度為16位,與8位/16位處理器體系結(jié)構(gòu)中字的長(zhǎng)度一致。
字節(jié)(Byte):在ARM體系結(jié)構(gòu)和8位/16位處理器體系結(jié)構(gòu)中,字節(jié)的長(zhǎng)度均為8位。

本文引用地址:http://2s4d.com/article/201611/319391.htm

***********************************************************************************************

在 ARM 匯編語(yǔ)言程序里,有一些特殊指令助記符,這些助記符與指令系統(tǒng)的助記符不同,沒(méi)有相對(duì)應(yīng)的操作碼,通常稱這些特殊指令助記符為偽指令,他們所完成的操作稱為偽操作。偽指令在源程序中的作用是為完成匯編程序作各種準(zhǔn)備工作的,這些偽指令僅在匯編過(guò)程中起作用,一旦匯編結(jié)束,偽指令的使命就完成。
在 ARM 的匯編程序中,有如下幾種偽指令:符號(hào)定義偽指令、數(shù)據(jù)定義偽指令、匯編控制偽指令、宏指令以及其他偽指令。


符號(hào)定義( Symbol Definition )偽指令
符號(hào)定義偽指令用于定義 ARM 匯編程序中的變量、對(duì)變量賦值以及定義寄存器的別名等操作。
常見(jiàn)的符號(hào)定義偽指令有如下幾種:
— 用于定義全局變量的 GBLA 、 GBLL 和 GBLS 。
— 用于定義局部變量的 LCLA 、 LCLL 和 LCLS 。
— 用于對(duì)變量賦值的 SETA 、 SETL 、 SETS 。
— 為通用寄存器列表定義名稱的 RLIST 。
1、 GBLA、GBLL 和GBLS
語(yǔ)法格式:
GBLA ( GBLL 或 GBLS )全局變量名
GBLA 、 GBLL 和 GBLS 偽指令用于定義一個(gè) ARM 程序中的全局變量,并將其初始化。其中:
GBLA 偽指令用于定義一個(gè)全局的數(shù)字變量,并初始化為 0 ;
GBLL 偽指令用于定義一個(gè)全局的邏輯變量,并初始化為 F (假);
GBLS 偽指令用于定義一個(gè)全局的字符串變量,并初始化為空;
由于以上三條偽指令用于定義全局變量,因此在整個(gè)程序范圍內(nèi)變量名必須唯一。
使用示例:
GBLA Test1 ;定義一個(gè)全局的數(shù)字變量,變量名為 Test1
Test1 SETA 0xaa ;將該變量賦值為 0xaa
GBLL Test2 ;定義一個(gè)全局的邏輯變量,變量名為 Test2
Test2 SETL {TRUE} ;將該變量賦值為真
GBLS Test3 ;定義一個(gè)全局的字符串變量,變量名為 Test3
Test3 SETS “ Testing ” ;將該變量賦值為 “ Testing ”

2、 LCLA、LCLL 和LCLS
語(yǔ)法格式:
LCLA ( LCLL 或 LCLS )局部變量名
LCLA 、 LCLL 和 LCLS 偽指令用于定義一個(gè) ARM 程序中的局部變量,并將其初始化。其中:
LCLA 偽指令用于定義一個(gè)局部的數(shù)字變量,并初始化為 0 ;
LCLL 偽指令用于定義一個(gè)局部的邏輯變量,并初始化為 F (假);
LCLS 偽指令用于定義一個(gè)局部的字符串變量,并初始化為空;
以上三條偽指令用于聲明局部變量,在其作用范圍內(nèi)變量名必須唯一。
使用示例:
LCLA Test4 ;聲明一個(gè)局部的數(shù)字變量,變量名為 Test4
Test4 SETA 0xaa ;將該變量賦值為 0xaa
LCLL Test5 ;聲明一個(gè)局部的邏輯變量,變量名為 Test5
Test5 SETL {TRUE} ;將該變量賦值為真
LCLS Test6 ;定義一個(gè)局部的字符串變量,變量名為 Test6
Test6 SETS “ Testing ” ;將該變量賦值為 “ Testing ”

3、 SETA、SETL 和SETS
語(yǔ)法格式:
變量名 SETA ( SETL 或 SETS )表達(dá)式
偽指令 SETA 、 SETL 、 SETS 用于給一個(gè)已經(jīng)定義的全局變量或局部變量賦值。
SETA 偽指令用于給一個(gè)數(shù)學(xué)變量賦值;
SETL 偽指令用于給一個(gè)邏輯變量賦值;
SETS 偽指令用于給一個(gè)字符串變量賦值;
其中,變量名為已經(jīng)定義過(guò)的全局變量或局部變量,表達(dá)式為將要賦給變量的值。
使用示例:
LCLA Test3 ;聲明一個(gè)局部的數(shù)字變量,變量名為 Test3
Test3 SETA 0xaa ;將該變量賦值為 0xaa
LCLL Test4 ;聲明一個(gè)局部的邏輯變量,變量名為 Test4
Test4 SETL {TRUE} ;將該變量賦值為真

4 、 RLIST
語(yǔ)法格式:
名稱 RLIST { 寄存器列表 }
RLIST 偽指令可用于對(duì)一個(gè)通用寄存器列表定義名稱,使用該偽指令定義的名稱可在 ARM 指令LDM/STM 中使用。在 LDM/STM 指令中,列表中的寄存器訪問(wèn)次序?yàn)楦鶕?jù)寄存器的編號(hào)由低到高,而與列表中的寄存器排列次序無(wú)關(guān)。
使用示例:
RegList RLIST {R0-R5 , R8 , R10} ;將寄存器列表名稱定義為 RegList ,可在 ARM 指令

LDM/STM中通過(guò)該名稱訪問(wèn)寄存器列表。

數(shù)據(jù)定義( Data Definition )偽指令
數(shù)據(jù)定義偽指令一般用于為特定的數(shù)據(jù)分配存儲(chǔ)單元,同時(shí)可完成已分配存儲(chǔ)單元的初始化。
常見(jiàn)的數(shù)據(jù)定義偽指令有如下幾種:
DCB 用于分配一片連續(xù)的字節(jié)存儲(chǔ)單元并用指定的數(shù)據(jù)初始化。
DCW ( DCWU )用于分配一片連續(xù)的半字存儲(chǔ)單元并用指定的數(shù)據(jù)初始化。
DCD ( DCDU )用于分配一片連續(xù)的字存儲(chǔ)單元并用指定的數(shù)據(jù)初始化。
— DCFD ( DCFDU )用于為雙精度的浮點(diǎn)數(shù)分配一片連續(xù)的字存儲(chǔ)單元并用指定的數(shù)據(jù)初始
化。
— DCFS ( DCFSU )用于為單精度的浮點(diǎn)數(shù)分配一片連續(xù)的字存儲(chǔ)單元并用指定的數(shù)據(jù)初
始化。
— DCQ ( DCQU ) 用于分配一片以 8 字節(jié)為單位的連續(xù)的存儲(chǔ)單元并用指定的數(shù)據(jù)初始
化。
— SPACE 用于分配一片連續(xù)的存儲(chǔ)單元
— MAP 用于定義一個(gè)結(jié)構(gòu)化的內(nèi)存表首地址
— FIELD 用于定義一個(gè)結(jié)構(gòu)化的內(nèi)存表的數(shù)據(jù)域


1、 DCB
語(yǔ)法格式:
標(biāo)號(hào) DCB 表達(dá)式
DCB 偽指令用于分配一片連續(xù)的字節(jié)存儲(chǔ)單元并用偽指令中指定的表達(dá)式初始化。其中,表達(dá)式可以為

0 ~ 255 的數(shù)字或字符串。 DCB 也可用 “ = ” 代替。
使用示例:
Str DCB “ This is a test ! ” ;分配一片連續(xù)的字節(jié)存儲(chǔ)單元并初始化。

2、 DCW(或DCWU)
語(yǔ)法格式:
標(biāo)號(hào) DCW (或 DCWU )表達(dá)式
DCW (或 DCWU )偽指令用于分配一片連續(xù)的半字存儲(chǔ)單元并用偽指令中指定的表達(dá)式初始化。
其中,表達(dá)式可以為程序標(biāo)號(hào)或數(shù)字表達(dá)式。。
用 DCW 分配的字存儲(chǔ)單元是半字對(duì)齊的,而用DCWU 分配的字存儲(chǔ)單元并不嚴(yán)格半字對(duì)齊。
使用示例:
DataTest DCW 1 , 2 , 3 ;分配一片連續(xù)的半字存儲(chǔ)單元并初始化。

3、 DCD(或DCDU)
語(yǔ)法格式:
標(biāo)號(hào) DCD (或 DCDU )表達(dá)式
DCD (或 DCDU )偽指令用于分配一片連續(xù)的字存儲(chǔ)單元并用偽指令中指定的表達(dá)式初始化。其中,表

達(dá)式可以為程序標(biāo)號(hào)或數(shù)字表達(dá)式。 DCD 也可用 “ & ” 代替。
用 DCD 分配的字存儲(chǔ)單元是字對(duì)齊的,而用 DCDU 分配的字存儲(chǔ)單元并不嚴(yán)格字對(duì)齊。
使用示例:
DataTest DCD 4 , 5 , 6 ;分配一片連續(xù)的字存儲(chǔ)單元并初始化。

4、 DCFD(或DCFDU)
語(yǔ)法格式:
標(biāo)號(hào) DCFD (或 DCFDU )表達(dá)式
DCFD (或 DCFDU )偽指令用于為雙精度的浮點(diǎn)數(shù)分配一片連續(xù)的字存儲(chǔ)單元并用偽指令中指定的表達(dá)式初始化。每個(gè)雙精度的浮點(diǎn)數(shù)占據(jù)兩個(gè)字單元。用 DCFD 分配的字存儲(chǔ)單元是字對(duì)齊的,而用 DCFDU 分配的字存儲(chǔ)單元并不嚴(yán)格字對(duì)齊。
使用示例:
FDataTest DCFD 2E115 , -5E7 ;分配一片連續(xù)的字存儲(chǔ)單元并初始化為指定的雙精度數(shù)。

5、 DCFS(或DCFSU)
語(yǔ)法格式:
標(biāo)號(hào) DCFS (或 DCFSU )表達(dá)式
DCFS (或 DCFSU )偽指令用于為單精度的浮點(diǎn)數(shù)分配一片連續(xù)的字存儲(chǔ)單元并用偽指令中指定的表達(dá)式初始化。每個(gè)單精度的浮點(diǎn)數(shù)占據(jù)一個(gè)字單元。用 DCFS 分配的字存儲(chǔ)單元是字對(duì)齊的,而用 DCFSU 分配的字存儲(chǔ)單元并不嚴(yán)格字對(duì)齊。
使用示例:
FDataTest DCFS 2E5 , -5E - 7 ;分配一片連續(xù)的字存儲(chǔ)單元并初始化為指定的單精度數(shù)。

6、 DCQ(或DCQU)
語(yǔ)法格式:
標(biāo)號(hào) DCQ (或 DCQU )表達(dá)式
DCQ (或 DCQU )偽指令用于分配一片以 8 個(gè)字節(jié)為單位的連續(xù)存儲(chǔ)區(qū)域并用偽指令中指定的表達(dá)式

初始化。
用 DCQ 分配的存儲(chǔ)單元是字對(duì)齊的,而用 DCQU 分配的存儲(chǔ)單元并不嚴(yán)格字對(duì)齊。
使用示例:
DataTest DCQ 100 ;分配一片連續(xù)的存儲(chǔ)單元并初始化為指定的值。

7、 SPACE
語(yǔ)法格式:
標(biāo)號(hào) SPACE 表達(dá)式
SPACE 偽指令用于分配一片連續(xù)的存儲(chǔ)區(qū)域并初始化為 0 。其中,表達(dá)式為要分配的字節(jié)數(shù)。
SPACE 也可用 “ % ” 代替。
使用示例:
DataSpace SPACE 100 ;分配連續(xù) 100 字節(jié)的存儲(chǔ)單元并初始化為 0 。

8、 MAP
語(yǔ)法格式:
MAP 表達(dá)式 { ,基址寄存器 }
MAP 偽指令用于定義一個(gè)結(jié)構(gòu)化的內(nèi)存表的首地址。 MAP 也可用 “ ^ ” 代替。
表達(dá)式可以為程序中的標(biāo)號(hào)或數(shù)學(xué)表達(dá)式,基址寄存器為可選項(xiàng),當(dāng)基址寄存器選項(xiàng)不存在時(shí),表達(dá)式的值即為內(nèi)存表的首地址,當(dāng)該選項(xiàng)存在時(shí),內(nèi)存表的首地址為表達(dá)式的值與基址寄存器的和。
MAP 偽指令通常與 FIELD 偽指令配合使用來(lái)定義結(jié)構(gòu)化的內(nèi)存表。
使用示例:
MAP 0x100 , R0 ;定義結(jié)構(gòu)化內(nèi)存表首地址的值為 0x100 + R0 。

9、 FILED
語(yǔ)法格式:
標(biāo)號(hào) FIELD 表達(dá)式
FIELD 偽指令用于定義一個(gè)結(jié)構(gòu)化內(nèi)存表中的數(shù)據(jù)域。 FILED 也可用 “ # ” 代替。
表達(dá)式的值為當(dāng)前數(shù)據(jù)域在內(nèi)存表中所占的字節(jié)數(shù)。
FIELD 偽指令常與 MAP 偽指令配合使用來(lái)定義結(jié)構(gòu)化的內(nèi)存表。 MAP 偽指令定義內(nèi)存表的首地址,FIELD 偽指令定義內(nèi)存表中的各個(gè)數(shù)據(jù)域,并可以為每個(gè)數(shù)據(jù)域指定一個(gè)標(biāo)號(hào)供其他的指令引用。
注意 MAP 和 FIELD 偽指令僅用于定義數(shù)據(jù)結(jié)構(gòu),并不實(shí)際分配存儲(chǔ)單元。
使用示例:
MAP 0x100 ;定義結(jié)構(gòu)化內(nèi)存表首地址的值為 0x100 。
A FIELD 16 ;定義 A 的長(zhǎng)度為 16 字節(jié),位置為 0x100
B FIELD 32 ;定義 B 的長(zhǎng)度為 32 字節(jié),位置為 0x110
S FIELD 256 ;定義 S 的長(zhǎng)度為 256 字節(jié),位置為 0x130

**********************************************************************************

DCB 可用 “ = ” 代替

DCD 可用 “ & ” 代替

SPACE 也可用 “ % ” 代替

MAP 也可用 “ ^ ” 代替

FILED 也可用 “ # ” 代替



關(guān)鍵詞: ARM匯編偽指

評(píng)論


技術(shù)專(zhuān)區(qū)

關(guān)閉