新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > ARM匯編中偽指令的介紹

        ARM匯編中偽指令的介紹

        作者: 時間:2016-11-28 來源:網絡 收藏
        偽指令沒有相對應的操作碼,他們所完成的操作稱為偽操作。

        偽指令在源程序中的作用是為完成匯編程序作各種準備工作的,這些偽指令僅在匯編過程中起作用,一旦匯編結束,偽指令的使命就完成(就如你睡覺她為你鋪床,鋪在哪兒和鋪床技巧由她安排,但她不陪你睡覺,鋪好了就走 :-( )。
          在 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、 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
          匯編控制( Assembly Control )偽指令
          匯編控制偽指令用于控制匯編程序的執行流程,常用的匯編控制偽指令包括以下幾條:
          — IF 、 ELSE 、 ENDIF
          — WHILE 、 WEND
          — MACRO 、 MEND
          — MEXIT
          1、 IF、ELSE、ENDIF
          語法格式:
          IF 邏輯表達式
          指令序列 1
          ELSE
          指令序列 2
          ENDIF
          IF 、 ELSE 、 ENDIF 偽指令能根據條件的成立與否決定是否執行某個指令序列。當 IF 后面的邏輯表達式為真,則執行指令序列 1 ,否則執行指令序列 2 。其中, ELSE 及指令序列 2 可以沒有,此時,當 IF 后面的邏輯表達式為真,則執行指令序列 1 ,否則繼續執行后面的指令。
          IF 、 ELSE 、 ENDIF 偽指令可以嵌套使用。
          使用示例:
          GBLL Test ;聲明一個全局的邏輯變量,變量名為 Test……
          IF Test = TRUE
          指令序列 1
          ELSE
          指令序列 2
          ENDIF
          2、 WHILE、WEND
          語法格式:
          WHILE 邏輯表達式
          指令序列
          WEND
          WHILE 、 WEND 偽指令能根據條件的成立與否決定是否循環執行某個指令序列。當 WHILE 后面的邏輯表達式為真,則執行指令序列,該指令序列執行完畢后,再判斷邏輯表達式的值,若為真則繼續執行,一直到邏輯表達式的值為假。


        上一頁 1 2 下一頁

        關鍵詞: ARM匯編偽指

        評論


        技術專區

        關閉
        主站蜘蛛池模板: 灌南县| 喀喇| 集安市| 三明市| 湟中县| 阳高县| 广饶县| 广昌县| 苍溪县| 旺苍县| 安丘市| 博爱县| 突泉县| 房山区| 余庆县| 崇明县| 保亭| 海丰县| 平阳县| 增城市| 大港区| 谷城县| 扎兰屯市| 香港 | 昌宁县| 称多县| 博爱县| 渭源县| 沁阳市| 织金县| 石柱| 乌拉特后旗| 蓬安县| 红原县| 高雄县| 隆林| 翁牛特旗| 南涧| 临泽县| 巴彦淖尔市| 宣城市|