色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > ARM匯編偽指令詳解(2)

          ARM匯編偽指令詳解(2)

          作者: 時(shí)間:2016-11-21 來源:網(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://cafeforensic.com/article/201611/319391.htm

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

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


          符號(hào)定義( Symbol Definition )偽指令
          符號(hào)定義偽指令用于定義 ARM 匯編程序中的變量、對(duì)變量賦值以及定義寄存器的別名等操作。
          常見的符號(hào)定義偽指令有如下幾種:
          — 用于定義全局變量的 GBLA 、 GBLL 和 GBLS 。
          — 用于定義局部變量的 LCLA 、 LCLL 和 LCLS 。
          — 用于對(duì)變量賦值的 SETA 、 SETL 、 SETS 。
          — 為通用寄存器列表定義名稱的 RLIST 。
          1、 GBLA、GBLL 和GBLS
          語法格式:
          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
          語法格式:
          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
          語法格式:
          變量名 SETA ( SETL 或 SETS )表達(dá)式
          偽指令 SETA 、 SETL 、 SETS 用于給一個(gè)已經(jīng)定義的全局變量或局部變量賦值。
          SETA 偽指令用于給一個(gè)數(shù)學(xué)變量賦值;
          SETL 偽指令用于給一個(gè)邏輯變量賦值;
          SETS 偽指令用于給一個(gè)字符串變量賦值;
          其中,變量名為已經(jīng)定義過的全局變量或局部變量,表達(dá)式為將要賦給變量的值。
          使用示例:
          LCLA Test3 ;聲明一個(gè)局部的數(shù)字變量,變量名為 Test3
          Test3 SETA 0xaa ;將該變量賦值為 0xaa
          LCLL Test4 ;聲明一個(gè)局部的邏輯變量,變量名為 Test4
          Test4 SETL {TRUE} ;將該變量賦值為真

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

          LDM/STM中通過該名稱訪問寄存器列表。

          數(shù)據(jù)定義( Data Definition )偽指令
          數(shù)據(jù)定義偽指令一般用于為特定的數(shù)據(jù)分配存儲(chǔ)單元,同時(shí)可完成已分配存儲(chǔ)單元的初始化。
          常見的數(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
          語法格式:
          標(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)
          語法格式:
          標(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)
          語法格式:
          標(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)
          語法格式:
          標(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)
          語法格式:
          標(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)
          語法格式:
          標(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
          語法格式:
          標(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
          語法格式:
          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 偽指令配合使用來定義結(jié)構(gòu)化的內(nèi)存表。
          使用示例:
          MAP 0x100 , R0 ;定義結(jié)構(gòu)化內(nèi)存表首地址的值為 0x100 + R0 。

          9、 FILED
          語法格式:
          標(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 偽指令配合使用來定義結(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ù)專區(qū)

          關(guān)閉