ARM匯編語言偽指令._第1頁
ARM匯編語言偽指令._第2頁
已閱讀5頁,還剩4頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、ARM 匯編語言偽指令A(yù)RM 匯編語言偽指令A(yù)RM 中偽指令不是真正的 ARM 指令或者 Thumb 指令,這些偽指令在匯編編譯 時對源程序進(jìn)行匯編處理時被替換成對應(yīng)的ARM 或 Thumb 指令(序列。ARM 偽指令包括 ADR、ADRL、LDR 和 NOP 等。1、ADR(小范圍的地址讀取偽指令該指令將基于 PC 的地址值或基于寄存器的地址值讀取到寄存器中。語法格式ADRc ond register, expr其中,cond 為可選的指令執(zhí)行的條件register 為目標(biāo)寄存器expr 為基于 PC 或者基于寄存器的地址表達(dá)式,其取值范圍如下:當(dāng)?shù)刂分挡皇亲謱R時,其取值范圍為-25525

2、5.當(dāng)?shù)刂分凳亲謱R時,其取值范圍為-10201020當(dāng)?shù)刂分凳?16 字節(jié)對齊時,其取值范圍將更大在匯編編譯器處理源程序時,ADR 偽指令被編譯器替換成一條合適的指令。通 常,編譯器用一條 ADD 指令或 SUB 指令來實(shí)現(xiàn)該 ADR 偽指令的功能。因?yàn)?ADR 偽指令中的地址是基于 PC 或者基于寄存器的,所以 ADR 讀取到的 地址為位置無關(guān)的地址。當(dāng) ADR 偽指令中的地址是基于 PC 時,該地址與 ADR 偽 指令必須在同一個代碼段中。示例start MOV r0,#10 ;因?yàn)?PC 值為當(dāng)前指令地址值加 8 字節(jié)ADR r4, start ;本 ADR 偽指令將被編譯器替換成 S

3、UB r4,pc,#0 xc2、ADRL(中等范圍的地址讀取偽指令該指令將基于 PC 或基于寄存器的地址值讀取到寄存器中。 ADRL 偽指令比 ADR 偽指令可以讀取更大范圍的地址。ADRL 偽指令在匯編時被編譯器替換成兩 條指令,即使一條指令可以完成該偽指令的功能。語法格式ADRLc ond register,expr示例start MOV r0,#10 ;因?yàn)?PC 值為當(dāng)前指令地址值加 8 字節(jié)ADRL r4,start+60000 ;本 ADRL 偽指令將被編譯器替換成下面兩條指令A(yù)DD r4,pc,#0 xe800ADD r4,r4,#0 x2543、LDR(大范圍的地址讀取偽指令L

4、DR 偽指令將一個 32 位的常數(shù)或者一個地址值讀取到寄存器中語法格式LDRc ond register, =expr|label-expr其中,expr 為 32 位的常量。編譯器將根據(jù) expr 的取值情況,如下處理 LDR 偽指當(dāng) expr 表示的地址值沒有超過 MOV 或 MVN 指令中地址的取值范圍時,編譯 器用合適的 MOV 或 MVN 指令代替該 LDR 偽指令當(dāng) expr 表示的地址值超過了 MOV 或者 MVN 指令中地址的取值范圍時,編譯 器將該常數(shù)放在數(shù)據(jù)緩沖區(qū)中,同時用一條基于 PC 的 LDR 指令讀取該常數(shù)。label-expr 為基于 PC 的地址表達(dá)式或者是外部

5、表達(dá)式。當(dāng) label-expr 為基于 PC 的地址表達(dá)式時,編譯器將 label-expr 表示的數(shù)值放在數(shù)據(jù)緩沖區(qū)(literal pool 中,然后 將該 LDR 偽指令處理成一條基于 PC 到該數(shù)據(jù)緩沖區(qū)單元的 LDR 指令,從而將該地 址值讀取到寄存器中。這時,要求該數(shù)據(jù)緩沖區(qū)單元到 PC 的距離小于 4KB。當(dāng) label-expr為外部表達(dá)式,或者非當(dāng)前段的表達(dá)式時,匯編編譯器將在目標(biāo)文件中插入 一個地址重定位偽操作,這樣連接器將在連接時生成該地址。LDR 偽指令主要有以下兩種用途:當(dāng)需要讀取到寄存器中的數(shù)據(jù)超過了MOV 及 MVN 指令可以操作的范圍時,可以使用 LDR 偽指

6、令將該數(shù)據(jù)讀取到寄存器中。將一個基于 PC 的地址值或者外部的地址值讀取到寄存器中。由于這種地址值 是在連接時確定的,所以這種代碼不是位置無關(guān)的。同時 LDR 偽指令的 PC 值到數(shù) 據(jù)緩沖區(qū)中的目標(biāo)數(shù)據(jù)所在的地址的偏移量要小于4KB。示例將 OxffO 讀取到 R1 中LDR R1,=0 xFF0匯編后將得到:MOV R1,0 xFF0將 0 xfff 讀取到 R1 中LDR R1,=0 xFFF匯編后將得到:LDR R1,PC,0FFSET_T0_LP00LLPOOL DCD OxFFF將外部地址 ADDR1 讀取到 R1 中LDR R1,=ADDR1匯編后將得到:LDR R1,PC,OF

7、FSET_TO_LPOOLLPOOL DCD ADDR14、NOP 空操作偽指令在匯編時將被替換成 ARM 中的空操作如 MOV R0,R0NOP 偽指令不影響 CPSR 中的條件標(biāo)志位ARM 匯編程序中的符號在 ARM 匯編語言中,符號(symbols 可以代表地址(addresse 變量(variables 和數(shù) 字常量(numeric constants 當(dāng)符號代表地址時,又稱為標(biāo)號(lable。當(dāng)標(biāo)號以數(shù)字開頭時,其作用范圍為當(dāng)前段(當(dāng)前段沒有使用 ROUT 偽操作時,這種標(biāo)號又稱為局部 標(biāo)號(lacal lable。符號變量包括變量、數(shù)字常量、標(biāo)號和局部標(biāo)號。1、變量在程序中,變量的

8、值在匯編處理過程中可能會發(fā)生改變。在 ARM 匯編中變量有 數(shù)字變量、邏輯變量和串變量 3 種類型。變量的類型在程序中是不可以改變的。數(shù)字變量的取值范圍為數(shù)字常量和數(shù)字表達(dá)式所能表示的數(shù)值;邏輯變量的取 值范圍為true和flash;串變量的取值范圍為串表達(dá)式可以表達(dá)的范圍。在 ARM 匯編語言中,使用 GBLA、 GBLL 及 GBLS 聲明全局變量;使用 LCLA、LCLL及 LCLS 聲明局部變量;使用 SETA、SETL 及 SETS 為這些變量賦值。2、數(shù)字常量數(shù)字常量是 32 位的整數(shù)。在 ARM 匯編語言中,使用 EQU 來定義數(shù)字常量。數(shù) 字常量一經(jīng)定義就不可修改。進(jìn)行大小比較

9、時,認(rèn)為數(shù)字常量都是無符號數(shù)。3、匯編時變量的替換如果在串變量前有一個$字符,在匯編時編譯器將用改串的數(shù)值來取代該串變 量。對于數(shù)字變量來說,如果該變量前面有一個$字符,在匯編時編譯器將該數(shù)字變量 的數(shù)值轉(zhuǎn)換成十六進(jìn)制的串,然后用該十六進(jìn)制的串取代$字符后的數(shù)字變量。對于邏輯變量來說,如果該邏輯變量前面有一個$字符,在匯編時編譯器將該邏輯 變量替換成它的取值(T 或者 F如果程序中需要字符$,則用$來表示,編譯器將不進(jìn)行變量替換,而是將$當(dāng)作$.通常情況下,包含在兩個豎線(|之間的$并不表示進(jìn)行變量替換。 但是如果豎線 (| 是在雙引號內(nèi),則將進(jìn)行變量替換。使用“來表示變量名稱的結(jié)束。4、標(biāo)號

10、標(biāo)號是表示程序中的指令或者數(shù)據(jù)地址的符號。根據(jù)標(biāo)號的生成方式可分為3種:基于 PC 的標(biāo)號?;?PC 的標(biāo)號是位于目標(biāo)指令前或者程序中數(shù)據(jù)定義偽操 作前的標(biāo)號。這種標(biāo)號在匯編時將被處理成 PC 值加上(或減去一個數(shù)字常量。常 用于表示跳轉(zhuǎn)指令的目標(biāo)地址,或者代碼段中所嵌入的少量數(shù)據(jù)?;诩拇嫫鞯臉?biāo)號?;诩拇嫫鞯臉?biāo)號常用 MAP 和 FIELD 未定義操作,也可 以該用 EQU 偽定義。這種標(biāo)號在匯編時將被處理成寄存器的值加上(或減去一個數(shù) 據(jù)常量。常用于訪問數(shù)據(jù)段中的數(shù)據(jù)。絕對地址。絕對地址是一個 32 位數(shù)據(jù)。它可以尋址 232 -1 即直接可以尋址整 個內(nèi)存空間。5、局部標(biāo)號局部標(biāo)號主

11、要在局部范圍內(nèi)使用。它由兩部組成:開頭是一個 0-99 直接的數(shù)字, 后面緊接一個通常表示該局部變量作用范圍的符號。局部變量的作用范圍通常為當(dāng)前段,也可以用偽操作 ROUT 來定義局部變量的 作用范圍。局部變量定義的語法格式如下:Nrout name,其中,N 為 099 之間的數(shù)字。 rout name 為符號,通常為該變量作用 范圍的名稱(用 ROUT 偽操作定義的。局部變量引用的語法格式如下:%F|BA|TNrout name其中,N 為局部變量的數(shù)字號rout name 為當(dāng)前作用范圍的名稱(用 ROUT 偽操作定義的%表示引用操作F 指示編譯器只向前搜索B 指示編譯器只向后搜索A 指

12、示編譯器搜索宏的所有嵌套層次T 指示編譯器搜索宏的當(dāng)前層次如果 F 和 B 都沒有指定,編譯器先向前搜索,再向后搜索如果 A 和 T 都沒有指定,編譯器搜索所有從當(dāng)前層次到宏的最高層次,比當(dāng)前層 次低的層次不再搜索。如果指定了 rout name 編譯器向前搜索最近的 ROUT 偽操作若 rout name 與該ROUT 偽操作定義的名稱不匹配,編譯器報告錯誤,匯編失敗。ARM 匯編語言中的表達(dá)式表達(dá)式是由符號、數(shù)值、單目或多目操作符以及括號組成的。1、字符串表達(dá)式字符串表達(dá)式由字符串、字符串變量、操作符以及括號組成。字符串的最大長 度為512 字節(jié),最小長度為 0.下面介紹字符串表達(dá)式的組成

13、元素。字符串:由包含在雙引號內(nèi)的一系列的字符組成。字符串的長度受到ARM 匯編語言語句長度的限制。當(dāng)在字符串中包含美元符號 $或者引號時,用$表示一個$, 用表示一個。字符串變量:用偽操作 GBLS 或者 LCLS 聲明,用 SETS 賦值。操作符:(1LEN:返回字符串的長度:LEN:A其中,A 為字符串變量(2CHR:可以將 0255 之間的整數(shù)作為含一個 ASCII 字符的字符串。當(dāng)有些 ASCII字符不方便放在字符串中時,可以使用 CHR 將其放在字符串表達(dá)式中。:CHR:A其中,A 為某一字符的 ASCII 值(3STR:將一個數(shù)字量或者邏輯表達(dá)式轉(zhuǎn)換成串。對于32 位的數(shù)字量而言,

14、STR將其轉(zhuǎn)換成 8 個十六進(jìn)制數(shù)組成的串;對于邏輯表達(dá)式而言,STR 將其轉(zhuǎn)換成字符串 T或者 F:STR:A其中,A 為數(shù)字量或者邏輯表達(dá)式(4LEFT:返回一個字符串最左端一定長度的子串A:LEFT:B其中,A 為源字符串,B 為數(shù)字量,表示 LEFT 將返回的字符個數(shù)(5RIGHT:返回一個字符串最右端一定長度的子串A:RIGHT:B其中,A 為源字符串,B 為數(shù)字量,表示 RIGHT 將返回的字符個數(shù)(6CC:用于連接兩個字符串A: CC: B 其中,A 為第 1 個源字符串。B 為第 2 個源字符串。CC 操作符將 字符串 B 連接在字符串 A 的后面。2、數(shù)字表達(dá)式 數(shù)字表達(dá)式由

15、數(shù)字常量、數(shù)字 變量、操作符和括號組成數(shù)字變量用偽操作 GBLA 或者 LCLA 聲明,用 SETA 賦 值,它代表一個32 位的數(shù)字量。操作符:(1)NOT:按位取反:NOT: A 其 中,A 為一個 32 位數(shù)字量(2) +、一、X/及 MOD 算術(shù)操作符 A+B , A-B , AXB, A/B A : MOD : B 表示 A 除以 B 的余數(shù) (3) ROL,ROR, SHL,SHR 移 位 A: ROL : B 將整數(shù) A 循環(huán)左移 B位 A : SHL: B 將整數(shù) A 左移 B 位(4) AND、OR 及 EOR 按位邏輯操作符 A : AND :B 將數(shù)字表達(dá)式 A 和 B

16、按位作邏輯 與操作 3、基于寄存器和基于 PC 的表達(dá)式基于寄存器的表達(dá)式表示了某個寄存器 的值加上(或者減去)一個數(shù)字表達(dá)式 基于 PC 的表達(dá)式表示了 PC 寄存器的值加 上(或減去)一個數(shù)字表達(dá)式?;?PC 的表達(dá)式通常由程序中的標(biāo)號與一個數(shù)字 表達(dá)式組成。相關(guān)的操作符:(1) BASE :返回基于寄存器的表達(dá)式中的寄存器編號。:BASE : A A 為基于寄存器的表達(dá)式 (2) INDEX :返回基于寄存器的表 達(dá)式相對于其基址寄存器的偏移量。:INDEX : A A 為基于寄存器的表達(dá)式(3)+、-:正負(fù)號,可以放在數(shù)字表達(dá)式或者基于PC 的表達(dá)式前面。+A (-A) A 為基于 PC 的表達(dá)式或者數(shù)字表達(dá)式 4、邏輯表達(dá)式 由邏輯量、邏輯操作 符、關(guān)系操作符以及括號組成,取值范圍為FLASE和TRUE關(guān)系操作符:用于表示兩個同類表達(dá)式之間的關(guān)系。關(guān)系操作符和它的兩個操 作數(shù)組成一個邏輯表達(dá)式,其取值為FALSE或TRUE如 A=B 表示 A 等于 B A/=B,AB 表示 A 不等于 B 邏輯操作符:進(jìn)行兩個邏輯表達(dá)式之間的基本邏輯 操作。操作的結(jié)果為FLASE或TRUE : LNOT : A 邏輯表達(dá)式 A 的值取反 A : LAND : B 邏輯表達(dá)式 A 和 B 邏輯與 5、其他的一些操作符 (1)?:返回定義符 號 A 的代碼行所生成的可執(zhí)行代碼的

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論