字(Word):在ARM體系結(jié)構(gòu)中,字的長度為32位,而在8位/16位處理器體系結(jié)構(gòu)中,字的長度一般為16位。半字(Half-Word):在ARM體系結(jié)構(gòu)中,半字的長度為16位,與8位/16位處理器體系結(jié)構(gòu)中字的長度一致。
字節(jié)(Byte):在ARM體系結(jié)構(gòu)和8位/16位處理器體系結(jié)構(gòu)中,字節(jié)的長度均為8位。
本文引用地址:http://m.butianyuan.cn/article/201611/319391.htm***********************************************************************************************
在 ARM 匯編語言程序里,有一些特殊指令助記符,這些助記符與指令系統(tǒng)的助記符不同,沒有相對應(yīng)的操作碼,通常稱這些特殊指令助記符為偽指令,他們所完成的操作稱為偽操作。偽指令在源程序中的作用是為完成匯編程序作各種準(zhǔn)備工作的,這些偽指令僅在匯編過程中起作用,一旦匯編結(jié)束,偽指令的使命就完成。
在 ARM 的匯編程序中,有如下幾種偽指令:符號定義偽指令、數(shù)據(jù)定義偽指令、匯編控制偽指令、宏指令以及其他偽指令。
符號定義( 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 偽指令用于定義一個全局的數(shù)字變量,并初始化為 0 ;
GBLL 偽指令用于定義一個全局的邏輯變量,并初始化為 F (假);
GBLS 偽指令用于定義一個全局的字符串變量,并初始化為空;
由于以上三條偽指令用于定義全局變量,因此在整個程序范圍內(nèi)變量名必須唯一。
使用示例:
GBLA Test1 ;定義一個全局的數(shù)字變量,變量名為 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 偽指令用于定義一個局部的數(shù)字變量,并初始化為 0 ;
LCLL 偽指令用于定義一個局部的邏輯變量,并初始化為 F (假);
LCLS 偽指令用于定義一個局部的字符串變量,并初始化為空;
以上三條偽指令用于聲明局部變量,在其作用范圍內(nèi)變量名必須唯一。
使用示例:
LCLA Test4 ;聲明一個局部的數(shù)字變量,變量名為 Test4
Test4 SETA 0xaa ;將該變量賦值為 0xaa
LCLL Test5 ;聲明一個局部的邏輯變量,變量名為 Test5
Test5 SETL {TRUE} ;將該變量賦值為真
LCLS Test6 ;定義一個局部的字符串變量,變量名為 Test6
Test6 SETS “ Testing ” ;將該變量賦值為 “ Testing ”
3、 SETA、SETL 和SETS
語法格式:
變量名 SETA ( SETL 或 SETS )表達式
偽指令 SETA 、 SETL 、 SETS 用于給一個已經(jīng)定義的全局變量或局部變量賦值。
SETA 偽指令用于給一個數(shù)學(xué)變量賦值;
SETL 偽指令用于給一個邏輯變量賦值;
SETS 偽指令用于給一個字符串變量賦值;
其中,變量名為已經(jīng)定義過的全局變量或局部變量,表達式為將要賦給變量的值。
使用示例:
LCLA Test3 ;聲明一個局部的數(shù)字變量,變量名為 Test3
Test3 SETA 0xaa ;將該變量賦值為 0xaa
LCLL Test4 ;聲明一個局部的邏輯變量,變量名為 Test4
Test4 SETL {TRUE} ;將該變量賦值為真
4 、 RLIST
語法格式:
名稱 RLIST { 寄存器列表 }
RLIST 偽指令可用于對一個通用寄存器列表定義名稱,使用該偽指令定義的名稱可在 ARM 指令LDM/STM 中使用。在 LDM/STM 指令中,列表中的寄存器訪問次序為根據(jù)寄存器的編號由低到高,而與列表中的寄存器排列次序無關(guān)。
使用示例:
RegList RLIST {R0-R5 , R8 , R10} ;將寄存器列表名稱定義為 RegList ,可在 ARM 指令
LDM/STM中通過該名稱訪問寄存器列表。
數(shù)據(jù)定義( Data Definition )偽指令
數(shù)據(jù)定義偽指令一般用于為特定的數(shù)據(jù)分配存儲單元,同時可完成已分配存儲單元的初始化。
常見的數(shù)據(jù)定義偽指令有如下幾種:
—DCB 用于分配一片連續(xù)的字節(jié)存儲單元并用指定的數(shù)據(jù)初始化。
—DCW ( DCWU )用于分配一片連續(xù)的半字存儲單元并用指定的數(shù)據(jù)初始化。
—DCD ( DCDU )用于分配一片連續(xù)的字存儲單元并用指定的數(shù)據(jù)初始化。
— DCFD ( DCFDU )用于為雙精度的浮點數(shù)分配一片連續(xù)的字存儲單元并用指定的數(shù)據(jù)初始
化。
— DCFS ( DCFSU )用于為單精度的浮點數(shù)分配一片連續(xù)的字存儲單元并用指定的數(shù)據(jù)初
始化。
— DCQ ( DCQU ) 用于分配一片以 8 字節(jié)為單位的連續(xù)的存儲單元并用指定的數(shù)據(jù)初始
化。
— SPACE 用于分配一片連續(xù)的存儲單元
— MAP 用于定義一個結(jié)構(gòu)化的內(nèi)存表首地址
— FIELD 用于定義一個結(jié)構(gòu)化的內(nèi)存表的數(shù)據(jù)域
1、 DCB
語法格式:
標(biāo)號 DCB 表達式
DCB 偽指令用于分配一片連續(xù)的字節(jié)存儲單元并用偽指令中指定的表達式初始化。其中,表達式可以為
0 ~ 255 的數(shù)字或字符串。 DCB 也可用 “ = ” 代替。
使用示例:
Str DCB “ This is a test ! ” ;分配一片連續(xù)的字節(jié)存儲單元并初始化。
2、 DCW(或DCWU)
語法格式:
標(biāo)號 DCW (或 DCWU )表達式
DCW (或 DCWU )偽指令用于分配一片連續(xù)的半字存儲單元并用偽指令中指定的表達式初始化。
其中,表達式可以為程序標(biāo)號或數(shù)字表達式。。
用 DCW 分配的字存儲單元是半字對齊的,而用DCWU 分配的字存儲單元并不嚴(yán)格半字對齊。
使用示例:
DataTest DCW 1 , 2 , 3 ;分配一片連續(xù)的半字存儲單元并初始化。
3、 DCD(或DCDU)
語法格式:
標(biāo)號 DCD (或 DCDU )表達式
DCD (或 DCDU )偽指令用于分配一片連續(xù)的字存儲單元并用偽指令中指定的表達式初始化。其中,表
達式可以為程序標(biāo)號或數(shù)字表達式。 DCD 也可用 “ & ” 代替。
用 DCD 分配的字存儲單元是字對齊的,而用 DCDU 分配的字存儲單元并不嚴(yán)格字對齊。
使用示例:
DataTest DCD 4 , 5 , 6 ;分配一片連續(xù)的字存儲單元并初始化。
4、 DCFD(或DCFDU)
語法格式:
標(biāo)號 DCFD (或 DCFDU )表達式
DCFD (或 DCFDU )偽指令用于為雙精度的浮點數(shù)分配一片連續(xù)的字存儲單元并用偽指令中指定的表達式初始化。每個雙精度的浮點數(shù)占據(jù)兩個字單元。用 DCFD 分配的字存儲單元是字對齊的,而用 DCFDU 分配的字存儲單元并不嚴(yán)格字對齊。
使用示例:
FDataTest DCFD 2E115 , -5E7 ;分配一片連續(xù)的字存儲單元并初始化為指定的雙精度數(shù)。
5、 DCFS(或DCFSU)
語法格式:
標(biāo)號 DCFS (或 DCFSU )表達式
DCFS (或 DCFSU )偽指令用于為單精度的浮點數(shù)分配一片連續(xù)的字存儲單元并用偽指令中指定的表達式初始化。每個單精度的浮點數(shù)占據(jù)一個字單元。用 DCFS 分配的字存儲單元是字對齊的,而用 DCFSU 分配的字存儲單元并不嚴(yán)格字對齊。
使用示例:
FDataTest DCFS 2E5 , -5E - 7 ;分配一片連續(xù)的字存儲單元并初始化為指定的單精度數(shù)。
6、 DCQ(或DCQU)
語法格式:
標(biāo)號 DCQ (或 DCQU )表達式
DCQ (或 DCQU )偽指令用于分配一片以 8 個字節(jié)為單位的連續(xù)存儲區(qū)域并用偽指令中指定的表達式
初始化。
用 DCQ 分配的存儲單元是字對齊的,而用 DCQU 分配的存儲單元并不嚴(yán)格字對齊。
使用示例:
DataTest DCQ 100 ;分配一片連續(xù)的存儲單元并初始化為指定的值。
7、 SPACE
語法格式:
標(biāo)號 SPACE 表達式
SPACE 偽指令用于分配一片連續(xù)的存儲區(qū)域并初始化為 0 。其中,表達式為要分配的字節(jié)數(shù)。
SPACE 也可用 “ % ” 代替。
使用示例:
DataSpace SPACE 100 ;分配連續(xù) 100 字節(jié)的存儲單元并初始化為 0 。
8、 MAP
語法格式:
MAP 表達式 { ,基址寄存器 }
MAP 偽指令用于定義一個結(jié)構(gòu)化的內(nèi)存表的首地址。 MAP 也可用 “ ^ ” 代替。
表達式可以為程序中的標(biāo)號或數(shù)學(xué)表達式,基址寄存器為可選項,當(dāng)基址寄存器選項不存在時,表達式的值即為內(nèi)存表的首地址,當(dāng)該選項存在時,內(nèi)存表的首地址為表達式的值與基址寄存器的和。
MAP 偽指令通常與 FIELD 偽指令配合使用來定義結(jié)構(gòu)化的內(nèi)存表。
使用示例:
MAP 0x100 , R0 ;定義結(jié)構(gòu)化內(nèi)存表首地址的值為 0x100 + R0 。
9、 FILED
語法格式:
標(biāo)號 FIELD 表達式
FIELD 偽指令用于定義一個結(jié)構(gòu)化內(nèi)存表中的數(shù)據(jù)域。 FILED 也可用 “ # ” 代替。
表達式的值為當(dāng)前數(shù)據(jù)域在內(nèi)存表中所占的字節(jié)數(shù)。
FIELD 偽指令常與 MAP 偽指令配合使用來定義結(jié)構(gòu)化的內(nèi)存表。 MAP 偽指令定義內(nèi)存表的首地址,FIELD 偽指令定義內(nèi)存表中的各個數(shù)據(jù)域,并可以為每個數(shù)據(jù)域指定一個標(biāo)號供其他的指令引用。
注意 MAP 和 FIELD 偽指令僅用于定義數(shù)據(jù)結(jié)構(gòu),并不實際分配存儲單元。
使用示例:
MAP 0x100 ;定義結(jié)構(gòu)化內(nèi)存表首地址的值為 0x100 。
A FIELD 16 ;定義 A 的長度為 16 字節(jié),位置為 0x100
B FIELD 32 ;定義 B 的長度為 32 字節(jié),位置為 0x110
S FIELD 256 ;定義 S 的長度為 256 字節(jié),位置為 0x130
**********************************************************************************
DCB 可用 “ = ” 代替
DCD 可用 “ & ” 代替
SPACE 也可用 “ % ” 代替
MAP 也可用 “ ^ ” 代替
FILED 也可用 “ # ” 代替
評論