AREA就是常見的偽指令之一。AREA是聲明區域段,數據區,代碼區等等。什么是數據段呢?數據段是來定義數據結構體的。格式是AREA test,CODE,READONLY。還有指令CODE16、CODE32,格式就直接寫上就是。目的是聲明以下是32位還是16位指令,注意不是切換arm和thunmb模式。如果是16位,那就是thunmb指令。
操作:這是之前的,如果在這里做一個聲明,CODE32,也就是表示ARM指令。如果這里CODE16,就表示一下代碼是16位指令,也就是thunmb指令,
也就是說在編譯的時候會按照thunmb指令來進行匯編。大家注意一點,在這里通過這個切換,並不會改變處理器的運行的處理模式。不會把ARM指令狀態切換為thunmb指令狀態。這個切換是在狀態寄存器里面去切換T。這個地方只是告訴匯編器而已,所以並不會更換運行時候的指令切換方式。
entry:entry偽指令用於指定匯編程序的入口點。在一個完整的匯編程序中至少要一個entry(也可以多個,當有多個entry時,程序的真正入口點由鏈接器指定),但在一源文件里最多只能有一個entry(可以沒有)。
END:END偽指令用於通知編譯器已經到了源程序的結尾。
EQU:EQU偽指令用於為程序中的常量、標號等定義一個等效的字符名稱,類似於c語言的#define。格式是 UARTLCON0 EQU.0x3FFD00。比方說:SUNDYCON1 EQU 0x3200000,我們定義了一個常量,這個常量可以拿來直接用。這里注意一點,我們編譯先看一下。這里就出錯了。
未知的操作代碼。這是怎么回事?匯編這一塊,跟自己的匯編器,編譯器是有關系的,有時跟ID的環境都有關。在ARM里面,特別ADS里面,他對是否頂頭,和Tab要求非常嚴格。因為我們這里不是一個標准指令,它會看第一個是什么操作碼,這里操作碼是不識別的,所以這里就出錯認不出來。這是應該怎樣做呢?首先把SUNDY頂頭,就可以知道只是個偽指令。
EXPOET:export偽指令用於程序中聲明一個全局的標號,該標號可在其他的文件中引用。export可用GLOBAL代替。標號在程序中區分大小寫,weak選項聲明其他的同名標號優先於該標號被引用。
IMPORT 相當於靜態引用。IMPORT偽指令用於通知編譯器要使用的標號在其他的源文件中定義,但要在當前源文件中引用,而且無論當前源文件是否引用該標號,該標號都會被加入到當前源文件的符號表中。
EXTERN相當於動態引用。EXTERN偽指令用於通知編譯器要使用的標號在其他的源文件中定義,但要在當前的源文件中引用,如果當前源文件實際未引用該標號,該標號就不會被加到當前源文件的符號表中。
GET 相當於引用文件。GET偽指令用於將一個源文件包含到當前的源文件中,並將被包含的源文件在當前位置進行匯編處理。可以使用INCLUDE代替GET。
RN:RN偽指令用於給一個寄存器定義一個別名。采用這種方式可以方便程序員記憶該寄存器的功能。其中,名稱為給寄存器定義的別名,表達式為寄存器的編碼。
RN的格式:name RN Rn。鑒於這種方式,這里應該頂頭。比方說這里給一個別名SRegister,SRegister RN R0。再用就可以MOV SRegjister #0x12。這樣可以通過SRegister來代替R0寄存器。這就是關於常用的偽指令的符號。這些都很容易理解,就只有EQU,其實EQU只要記住類似於define就可以了。匯編語言程序中常見的符號。之前學過的有很多條件操作符號,比如,EQ,LT,GT,NE等等,用這些東西進行中一些數據運算。有時需要把某一個值臨時存到一個臨時的變量里,然后回過頭在用到這個變量。以前是沒有辦法的,只能去操作,定一些值,把這些值存儲到臨時寄存器里面,然后用完再把它取出來。這樣很麻煩。