資料介紹
AREA就是常見的偽指令之一。AREA是聲明區(qū)域段,數據區(qū),代碼區(qū)等等。什么是數據段呢?數據段是來定義數據結構體的。格式是AREA test,CODE,READONLY。還有指令CODE16、CODE32,格式就直接寫上就是。目的是聲明以下是32位還是16位指令,注意不是切換arm和thunmb模式。如果是16位,那就是thunmb指令。
操作:這是之前的,如果在這里做一個聲明,CODE32,也就是表示ARM指令。如果這里CODE16,就表示一下代碼是16位指令,也就是thunmb指令,
也就是說在編譯的時候會按照thunmb指令來進行匯編。大家注意一點,在這里通過這個切換,并不會改變處理器的運行的處理模式。不會把ARM指令狀態(tài)切換為thunmb指令狀態(tài)。這個切換是在狀態(tài)寄存器里面去切換T。這個地方只是告訴匯編器而已,所以并不會更換運行時候的指令切換方式。
entry:entry偽指令用于指定匯編程序的入口點。在一個完整的匯編程序中至少要一個entry(也可以多個,當有多個entry時,程序的真正入口點由鏈接器指定),但在一源文件里最多只能有一個entry(可以沒有)。
END:END偽指令用于通知編譯器已經到了源程序的結尾。
EQU:EQU偽指令用于為程序中的常量、標號等定義一個等效的字符名稱,類似于c語言的#define。格式是 UARTLCON0 EQU.0x3FFD00。比方說:SUNDYCON1 EQU 0x3200000,我們定義了一個常量,這個常量可以拿來直接用。這里注意一點,我們編譯先看一下。這里就出錯了。
未知的操作代碼。這是怎么回事?匯編這一塊,跟自己的匯編器,編譯器是有關系的,有時跟ID的環(huán)境都有關。在ARM里面,特別ADS里面,他對是否頂頭,和Tab要求非常嚴格。因為我們這里不是一個標準指令,它會看第一個是什么操作碼,這里操作碼是不識別的,所以這里就出錯認不出來。這是應該怎樣做呢?首先把SUNDY頂頭,就可以知道只是個偽指令。
EXPOET:export偽指令用于程序中聲明一個全局的標號,該標號可在其他的文件中引用。export可用GLOBAL代替。標號在程序中區(qū)分大小寫,weak選項聲明其他的同名標號優(yōu)先于該標號被引用。
IMPORT 相當于靜態(tài)引用。IMPORT偽指令用于通知編譯器要使用的標號在其他的源文件中定義,但要在當前源文件中引用,而且無論當前源文件是否引用該標號,該標號都會被加入到當前源文件的符號表中。
EXTERN相當于動態(tài)引用。EXTERN偽指令用于通知編譯器要使用的標號在其他的源文件中定義,但要在當前的源文件中引用,如果當前源文件實際未引用該標號,該標號就不會被加到當前源文件的符號表中。
GET 相當于引用文件。GET偽指令用于將一個源文件包含到當前的源文件中,并將被包含的源文件在當前位置進行匯編處理??梢允褂肐NCLUDE代替GET。
RN:RN偽指令用于給一個寄存器定義一個別名。采用這種方式可以方便程序員記憶該寄存器的功能。其中,名稱為給寄存器定義的別名,表達式為寄存器的編碼。
RN的格式:name RN Rn。鑒于這種方式,這里應該頂頭。比方說這里給一個別名SRegister,SRegister RN R0。再用就可以MOV SRegjister #0x12。這樣可以通過SRegister來代替R0寄存器。這就是關于常用的偽指令的符號。這些都很容易理解,就只有EQU,其實EQU只要記住類似于define就可以了。匯編語言程序中常見的符號。之前學過的有很多條件操作符號,比如,EQ,LT,GT,NE等等,用這些東西進行中一些數據運算。有時需要把某一個值臨時存到一個臨時的變量里,然后回過頭在用到這個變量。以前是沒有辦法的,只能去操作,定一些值,把這些值存儲到臨時寄存器里面,然后用完再把它取出來。這樣很麻煩。
轉自:
原文鏈接:
(mbbeetchina)
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- AD常用規(guī)則圖片詳解下載 0次下載
- ARM匯編指令(6)——批量數據加載/存儲指令資料下載
- 單片機教程之單片機常用指令的詳細資料說明 16次下載
- 常用的ARM指令集及匯編 24次下載
- ARM匯編器所支持的偽指令淺析 2次下載
- ARM指令系統(tǒng) 0次下載
- μ’nSP?匯編器偽指令集 0次下載
- ARM匯編偽指令 78次下載
- MCS-51單片機匯編語言中的偽指令
- ARM指令集詳解
- arm指令詳解手冊(精華)
- arm匯編指令詳解
- 常用arm指令集及匯編
- ARM指令集下載 arm指令集參考手冊
- 常用ARM指令集與匯編
- 講講ARM指令集格式以及常用的ARM匯編指令 2543次閱讀
- 詳解ARM WFI和WFE指令 1298次閱讀
- 零基礎學ARM:匯編偽指令、lds詳解 2548次閱讀
- 匯編語言中常用的偽指令 7663次閱讀
- 指令和偽指令分得清嗎? 6725次閱讀
- 一文詳解ARM7_ARM9和ARM11的區(qū)別 4w次閱讀
- GSM模塊常用AT指令詳解 2.5w次閱讀
- ARM程序的執(zhí)行過程詳解 7123次閱讀
- 淺談ARM偽指令地址讀取 2036次閱讀
- Matlab常用操作指令詳解 6307次閱讀
- AVR單片機匯編器的部分偽指令詳解 7396次閱讀
- thumb指令集是什么_thumb指令集與arm指令集的區(qū)別 1.8w次閱讀
- arm的匯編指令精選合輯 2058次閱讀
- 干貨分享:PIC單片機常用指令介紹與指令功能分類表 4067次閱讀
- 單片機編程之匯編語言基礎-PIC單片機匯編指令 2977次閱讀
評論
查看更多