新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > ARM匯編偽指令詳解(2)

        ARM匯編偽指令詳解(2)

        作者: 時間:2016-11-21 來源:網絡 收藏
        字(Word):在ARM體系結構中,字的長度為32位,而在8位/16位處理器體系結構中,字的長度一般為16位。

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

        本文引用地址:http://www.104case.com/article/201611/319391.htm

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

        在 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
        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 用于給一個已經定義的全局變量或局部變量賦值。
        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中通過該名稱訪問寄存器列表。

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


        1、 DCB
        語法格式:
        標號 DCB 表達式
        DCB 偽指令用于分配一片連續的字節存儲單元并用偽指令中指定的表達式初始化。其中,表達式可以為

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

        2、 DCW(或DCWU)
        語法格式:
        標號 DCW (或 DCWU )表達式
        DCW (或 DCWU )偽指令用于分配一片連續的半字存儲單元并用偽指令中指定的表達式初始化。
        其中,表達式可以為程序標號或數字表達式。。
        用 DCW 分配的字存儲單元是半字對齊的,而用DCWU 分配的字存儲單元并不嚴格半字對齊。
        使用示例:
        DataTest DCW 1 , 2 , 3 ;分配一片連續的半字存儲單元并初始化。

        3、 DCD(或DCDU)
        語法格式:
        標號 DCD (或 DCDU )表達式
        DCD (或 DCDU )偽指令用于分配一片連續的字存儲單元并用偽指令中指定的表達式初始化。其中,表

        達式可以為程序標號或數字表達式。 DCD 也可用 “ & ” 代替。
        用 DCD 分配的字存儲單元是字對齊的,而用 DCDU 分配的字存儲單元并不嚴格字對齊。
        使用示例:
        DataTest DCD 4 , 5 , 6 ;分配一片連續的字存儲單元并初始化。

        4、 DCFD(或DCFDU)
        語法格式:
        標號 DCFD (或 DCFDU )表達式
        DCFD (或 DCFDU )偽指令用于為雙精度的浮點數分配一片連續的字存儲單元并用偽指令中指定的表達式初始化。每個雙精度的浮點數占據兩個字單元。用 DCFD 分配的字存儲單元是字對齊的,而用 DCFDU 分配的字存儲單元并不嚴格字對齊。
        使用示例:
        FDataTest DCFD 2E115 , -5E7 ;分配一片連續的字存儲單元并初始化為指定的雙精度數。

        5、 DCFS(或DCFSU)
        語法格式:
        標號 DCFS (或 DCFSU )表達式
        DCFS (或 DCFSU )偽指令用于為單精度的浮點數分配一片連續的字存儲單元并用偽指令中指定的表達式初始化。每個單精度的浮點數占據一個字單元。用 DCFS 分配的字存儲單元是字對齊的,而用 DCFSU 分配的字存儲單元并不嚴格字對齊。
        使用示例:
        FDataTest DCFS 2E5 , -5E - 7 ;分配一片連續的字存儲單元并初始化為指定的單精度數。

        6、 DCQ(或DCQU)
        語法格式:
        標號 DCQ (或 DCQU )表達式
        DCQ (或 DCQU )偽指令用于分配一片以 8 個字節為單位的連續存儲區域并用偽指令中指定的表達式

        初始化。
        用 DCQ 分配的存儲單元是字對齊的,而用 DCQU 分配的存儲單元并不嚴格字對齊。
        使用示例:
        DataTest DCQ 100 ;分配一片連續的存儲單元并初始化為指定的值。

        7、 SPACE
        語法格式:
        標號 SPACE 表達式
        SPACE 偽指令用于分配一片連續的存儲區域并初始化為 0 。其中,表達式為要分配的字節數。
        SPACE 也可用 “ % ” 代替。
        使用示例:
        DataSpace SPACE 100 ;分配連續 100 字節的存儲單元并初始化為 0 。

        8、 MAP
        語法格式:
        MAP 表達式 { ,基址寄存器 }
        MAP 偽指令用于定義一個結構化的內存表的首地址。 MAP 也可用 “ ^ ” 代替。
        表達式可以為程序中的標號或數學表達式,基址寄存器為可選項,當基址寄存器選項不存在時,表達式的值即為內存表的首地址,當該選項存在時,內存表的首地址為表達式的值與基址寄存器的和。
        MAP 偽指令通常與 FIELD 偽指令配合使用來定義結構化的內存表。
        使用示例:
        MAP 0x100 , R0 ;定義結構化內存表首地址的值為 0x100 + R0 。

        9、 FILED
        語法格式:
        標號 FIELD 表達式
        FIELD 偽指令用于定義一個結構化內存表中的數據域。 FILED 也可用 “ # ” 代替。
        表達式的值為當前數據域在內存表中所占的字節數。
        FIELD 偽指令常與 MAP 偽指令配合使用來定義結構化的內存表。 MAP 偽指令定義內存表的首地址,FIELD 偽指令定義內存表中的各個數據域,并可以為每個數據域指定一個標號供其他的指令引用。
        注意 MAP 和 FIELD 偽指令僅用于定義數據結構,并不實際分配存儲單元。
        使用示例:
        MAP 0x100 ;定義結構化內存表首地址的值為 0x100 。
        A FIELD 16 ;定義 A 的長度為 16 字節,位置為 0x100
        B FIELD 32 ;定義 B 的長度為 32 字節,位置為 0x110
        S FIELD 256 ;定義 S 的長度為 256 字節,位置為 0x130

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

        DCB 可用 “ = ” 代替

        DCD 可用 “ & ” 代替

        SPACE 也可用 “ % ” 代替

        MAP 也可用 “ ^ ” 代替

        FILED 也可用 “ # ” 代替



        關鍵詞: ARM匯編偽指

        評論


        技術專區

        關閉
        主站蜘蛛池模板: 田阳县| 原平市| 巴中市| 叙永县| 平顶山市| 武邑县| 江华| 文山县| 泌阳县| 东平县| 林口县| 无极县| 云浮市| 天台县| 万源市| 绥宁县| 龙江县| 比如县| 瑞昌市| 兰州市| 泰顺县| 饶平县| 霍城县| 黑河市| 鹿邑县| 美姑县| 库尔勒市| 云霄县| 潮州市| 罗江县| 松潘县| 宣汉县| 韩城市| 淳化县| 纳雍县| 郧西县| 依安县| 民丰县| 仙桃市| 兴隆县| 泸州市|