ARM學習之常用的偽指令詳解


  AREA就是常見的偽指令之一。AREA是聲明區域段,數據區,代碼區等等。什么是數據段呢?數據段是來定義數據結構體的。格式是AREA test,CODE,READONLY。還有指令CODE16CODE32,格式就直接寫上就是。目的是聲明以下是32位還是16位指令,注意不是切換armthunmb模式。如果是16位,那就是thunmb指令。

  操作:這是之前的,如果在這里做一個聲明,CODE32,也就是表示ARM指令。如果這里CODE16,就表示一下代碼是16位指令,也就是thunmb指令,

  也就是說在編譯的時候會按照thunmb指令來進行匯編。大家注意一點,在這里通過這個切換,並不會改變處理器的運行的處理模式。不會把ARM指令狀態切換為thunmb指令狀態。這個切換是在狀態寄存器里面去切換T。這個地方只是告訴匯編器而已,所以並不會更換運行時候的指令切換方式。

  entryentry偽指令用於指定匯編程序的入口點。在一個完整的匯編程序中至少要一個entry(也可以多個,當有多個entry時,程序的真正入口點由鏈接器指定),但在一源文件里最多只能有一個entry(可以沒有)。

  ENDEND偽指令用於通知編譯器已經到了源程序的結尾。

  EQUEQU偽指令用於為程序中的常量、標號等定義一個等效的字符名稱,類似於c語言的#define。格式是 UARTLCON0 EQU.0x3FFD00。比方說:SUNDYCON1 EQU 0x3200000,我們定義了一個常量,這個常量可以拿來直接用。這里注意一點,我們編譯先看一下。這里就出錯了。

  未知的操作代碼。這是怎么回事?匯編這一塊,跟自己的匯編器,編譯器是有關系的,有時跟ID的環境都有關。在ARM里面,特別ADS里面,他對是否頂頭,和Tab要求非常嚴格。因為我們這里不是一個標准指令,它會看第一個是什么操作碼,這里操作碼是不識別的,所以這里就出錯認不出來。這是應該怎樣做呢?首先把SUNDY頂頭,就可以知道只是個偽指令。

  EXPOETexport偽指令用於程序中聲明一個全局的標號,該標號可在其他的文件中引用。export可用GLOBAL代替。標號在程序中區分大小寫,weak選項聲明其他的同名標號優先於該標號被引用。

  IMPORT 相當於靜態引用。IMPORT偽指令用於通知編譯器要使用的標號在其他的源文件中定義,但要在當前源文件中引用,而且無論當前源文件是否引用該標號,該標號都會被加入到當前源文件的符號表中。

  EXTERN相當於動態引用。EXTERN偽指令用於通知編譯器要使用的標號在其他的源文件中定義,但要在當前的源文件中引用,如果當前源文件實際未引用該標號,該標號就不會被加到當前源文件的符號表中。

  GET 相當於引用文件。GET偽指令用於將一個源文件包含到當前的源文件中,並將被包含的源文件在當前位置進行匯編處理。可以使用INCLUDE代替GET

  RNRN偽指令用於給一個寄存器定義一個別名。采用這種方式可以方便程序員記憶該寄存器的功能。其中,名稱為給寄存器定義的別名,表達式為寄存器的編碼。

  RN的格式:name RN Rn。鑒於這種方式,這里應該頂頭。比方說這里給一個別名SRegisterSRegister RN R0。再用就可以MOV SRegjister #0x12。這樣可以通過SRegister來代替R0寄存器。這就是關於常用的偽指令的符號。這些都很容易理解,就只有EQU,其實EQU只要記住類似於define就可以了。匯編語言程序中常見的符號。之前學過的有很多條件操作符號,比如,EQLTGTNE等等,用這些東西進行中一些數據運算。有時需要把某一個值臨時存到一個臨時的變量里,然后回過頭在用到這個變量。以前是沒有辦法的,只能去操作,定一些值,把這些值存儲到臨時寄存器里面,然后用完再把它取出來。這樣很麻煩。

 

原文鏈接:http://www.maiziedu.com/wiki/arm/common/


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM