版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、ARM 匯編語(yǔ)言偽指令A(yù)RM 匯編語(yǔ)言偽指令A(yù)RM 中偽指令不是真正的 ARM 指令或者 Thumb 指令,這些偽指令在匯編編譯 時(shí)對(duì)源程序進(jìn)行匯編處理時(shí)被替換成對(duì)應(yīng)的ARM 或 Thumb 指令(序列。ARM 偽指令包括 ADR、ADRL、LDR 和 NOP 等。1、ADR(小范圍的地址讀取偽指令該指令將基于 PC 的地址值或基于寄存器的地址值讀取到寄存器中。語(yǔ)法格式ADRc ond register, expr其中,cond 為可選的指令執(zhí)行的條件register 為目標(biāo)寄存器expr 為基于 PC 或者基于寄存器的地址表達(dá)式,其取值范圍如下:當(dāng)?shù)刂分挡皇亲謱?duì)齊時(shí),其取值范圍為-25525
2、5.當(dāng)?shù)刂分凳亲謱?duì)齊時(shí),其取值范圍為-10201020當(dāng)?shù)刂分凳?16 字節(jié)對(duì)齊時(shí),其取值范圍將更大在匯編編譯器處理源程序時(shí),ADR 偽指令被編譯器替換成一條合適的指令。通 常,編譯器用一條 ADD 指令或 SUB 指令來(lái)實(shí)現(xiàn)該 ADR 偽指令的功能。因?yàn)?ADR 偽指令中的地址是基于 PC 或者基于寄存器的,所以 ADR 讀取到的 地址為位置無(wú)關(guān)的地址。當(dāng) ADR 偽指令中的地址是基于 PC 時(shí),該地址與 ADR 偽 指令必須在同一個(gè)代碼段中。示例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 偽指令在匯編時(shí)被編譯器替換成兩 條指令,即使一條指令可以完成該偽指令的功能。語(yǔ)法格式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 偽指令將一個(gè) 32 位的常數(shù)或者一個(gè)地址值讀取到寄存器中語(yǔ)法格式LDRc ond register, =expr|label-expr其中,expr 為 32 位的常量。編譯器將根據(jù) expr 的取值情況,如下處理 LDR 偽指當(dāng) expr 表示的地址值沒(méi)有超過(guò) MOV 或 MVN 指令中地址的取值范圍時(shí),編譯 器用合適的 MOV 或 MVN 指令代替該 LDR 偽指令當(dāng) expr 表示的地址值超過(guò)了 MOV 或者 MVN 指令中地址的取值范圍時(shí),編譯 器將該常數(shù)放在數(shù)據(jù)緩沖區(qū)中,同時(shí)用一條基于 PC 的 LDR 指令讀取該常數(shù)。label-expr 為基于 PC 的地址表達(dá)式或者是外部
5、表達(dá)式。當(dāng) label-expr 為基于 PC 的地址表達(dá)式時(shí),編譯器將 label-expr 表示的數(shù)值放在數(shù)據(jù)緩沖區(qū)(literal pool 中,然后 將該 LDR 偽指令處理成一條基于 PC 到該數(shù)據(jù)緩沖區(qū)單元的 LDR 指令,從而將該地 址值讀取到寄存器中。這時(shí),要求該數(shù)據(jù)緩沖區(qū)單元到 PC 的距離小于 4KB。當(dāng) label-expr為外部表達(dá)式,或者非當(dāng)前段的表達(dá)式時(shí),匯編編譯器將在目標(biāo)文件中插入 一個(gè)地址重定位偽操作,這樣連接器將在連接時(shí)生成該地址。LDR 偽指令主要有以下兩種用途:當(dāng)需要讀取到寄存器中的數(shù)據(jù)超過(guò)了MOV 及 MVN 指令可以操作的范圍時(shí),可以使用 LDR 偽指
6、令將該數(shù)據(jù)讀取到寄存器中。將一個(gè)基于 PC 的地址值或者外部的地址值讀取到寄存器中。由于這種地址值 是在連接時(shí)確定的,所以這種代碼不是位置無(wú)關(guān)的。同時(shí) 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 空操作偽指令在匯編時(shí)將被替換成 ARM 中的空操作如 MOV R0,R0NOP 偽指令不影響 CPSR 中的條件標(biāo)志位ARM 匯編程序中的符號(hào)在 ARM 匯編語(yǔ)言中,符號(hào)(symbols 可以代表地址(addresse 變量(variables 和數(shù) 字常量(numeric constants 當(dāng)符號(hào)代表地址時(shí),又稱為標(biāo)號(hào)(lable。當(dāng)標(biāo)號(hào)以數(shù)字開(kāi)頭時(shí),其作用范圍為當(dāng)前段(當(dāng)前段沒(méi)有使用 ROUT 偽操作時(shí),這種標(biāo)號(hào)又稱為局部 標(biāo)號(hào)(lacal lable。符號(hào)變量包括變量、數(shù)字常量、標(biāo)號(hào)和局部標(biāo)號(hào)。1、變量在程序中,變量的
8、值在匯編處理過(guò)程中可能會(huì)發(fā)生改變。在 ARM 匯編中變量有 數(shù)字變量、邏輯變量和串變量 3 種類型。變量的類型在程序中是不可以改變的。數(shù)字變量的取值范圍為數(shù)字常量和數(shù)字表達(dá)式所能表示的數(shù)值;邏輯變量的取 值范圍為true和flash;串變量的取值范圍為串表達(dá)式可以表達(dá)的范圍。在 ARM 匯編語(yǔ)言中,使用 GBLA、 GBLL 及 GBLS 聲明全局變量;使用 LCLA、LCLL及 LCLS 聲明局部變量;使用 SETA、SETL 及 SETS 為這些變量賦值。2、數(shù)字常量數(shù)字常量是 32 位的整數(shù)。在 ARM 匯編語(yǔ)言中,使用 EQU 來(lái)定義數(shù)字常量。數(shù) 字常量一經(jīng)定義就不可修改。進(jìn)行大小比較
9、時(shí),認(rèn)為數(shù)字常量都是無(wú)符號(hào)數(shù)。3、匯編時(shí)變量的替換如果在串變量前有一個(gè)$字符,在匯編時(shí)編譯器將用改串的數(shù)值來(lái)取代該串變 量。對(duì)于數(shù)字變量來(lái)說(shuō),如果該變量前面有一個(gè)$字符,在匯編時(shí)編譯器將該數(shù)字變量 的數(shù)值轉(zhuǎn)換成十六進(jìn)制的串,然后用該十六進(jìn)制的串取代$字符后的數(shù)字變量。對(duì)于邏輯變量來(lái)說(shuō),如果該邏輯變量前面有一個(gè)$字符,在匯編時(shí)編譯器將該邏輯 變量替換成它的取值(T 或者 F如果程序中需要字符$,則用$來(lái)表示,編譯器將不進(jìn)行變量替換,而是將$當(dāng)作$.通常情況下,包含在兩個(gè)豎線(|之間的$并不表示進(jìn)行變量替換。 但是如果豎線 (| 是在雙引號(hào)內(nèi),則將進(jìn)行變量替換。使用“來(lái)表示變量名稱的結(jié)束。4、標(biāo)號(hào)
10、標(biāo)號(hào)是表示程序中的指令或者數(shù)據(jù)地址的符號(hào)。根據(jù)標(biāo)號(hào)的生成方式可分為3種:基于 PC 的標(biāo)號(hào)?;?PC 的標(biāo)號(hào)是位于目標(biāo)指令前或者程序中數(shù)據(jù)定義偽操 作前的標(biāo)號(hào)。這種標(biāo)號(hào)在匯編時(shí)將被處理成 PC 值加上(或減去一個(gè)數(shù)字常量。常 用于表示跳轉(zhuǎn)指令的目標(biāo)地址,或者代碼段中所嵌入的少量數(shù)據(jù)?;诩拇嫫鞯臉?biāo)號(hào)?;诩拇嫫鞯臉?biāo)號(hào)常用 MAP 和 FIELD 未定義操作,也可 以該用 EQU 偽定義。這種標(biāo)號(hào)在匯編時(shí)將被處理成寄存器的值加上(或減去一個(gè)數(shù) 據(jù)常量。常用于訪問(wèn)數(shù)據(jù)段中的數(shù)據(jù)。絕對(duì)地址。絕對(duì)地址是一個(gè) 32 位數(shù)據(jù)。它可以尋址 232 -1 即直接可以尋址整 個(gè)內(nèi)存空間。5、局部標(biāo)號(hào)局部標(biāo)號(hào)主
11、要在局部范圍內(nèi)使用。它由兩部組成:開(kāi)頭是一個(gè) 0-99 直接的數(shù)字, 后面緊接一個(gè)通常表示該局部變量作用范圍的符號(hào)。局部變量的作用范圍通常為當(dāng)前段,也可以用偽操作 ROUT 來(lái)定義局部變量的 作用范圍。局部變量定義的語(yǔ)法格式如下:Nrout name,其中,N 為 099 之間的數(shù)字。 rout name 為符號(hào),通常為該變量作用 范圍的名稱(用 ROUT 偽操作定義的。局部變量引用的語(yǔ)法格式如下:%F|BA|TNrout name其中,N 為局部變量的數(shù)字號(hào)rout name 為當(dāng)前作用范圍的名稱(用 ROUT 偽操作定義的%表示引用操作F 指示編譯器只向前搜索B 指示編譯器只向后搜索A 指
12、示編譯器搜索宏的所有嵌套層次T 指示編譯器搜索宏的當(dāng)前層次如果 F 和 B 都沒(méi)有指定,編譯器先向前搜索,再向后搜索如果 A 和 T 都沒(méi)有指定,編譯器搜索所有從當(dāng)前層次到宏的最高層次,比當(dāng)前層 次低的層次不再搜索。如果指定了 rout name 編譯器向前搜索最近的 ROUT 偽操作若 rout name 與該ROUT 偽操作定義的名稱不匹配,編譯器報(bào)告錯(cuò)誤,匯編失敗。ARM 匯編語(yǔ)言中的表達(dá)式表達(dá)式是由符號(hào)、數(shù)值、單目或多目操作符以及括號(hào)組成的。1、字符串表達(dá)式字符串表達(dá)式由字符串、字符串變量、操作符以及括號(hào)組成。字符串的最大長(zhǎng) 度為512 字節(jié),最小長(zhǎng)度為 0.下面介紹字符串表達(dá)式的組成
13、元素。字符串:由包含在雙引號(hào)內(nèi)的一系列的字符組成。字符串的長(zhǎng)度受到ARM 匯編語(yǔ)言語(yǔ)句長(zhǎng)度的限制。當(dāng)在字符串中包含美元符號(hào) $或者引號(hào)時(shí),用$表示一個(gè)$, 用表示一個(gè)。字符串變量:用偽操作 GBLS 或者 LCLS 聲明,用 SETS 賦值。操作符:(1LEN:返回字符串的長(zhǎng)度:LEN:A其中,A 為字符串變量(2CHR:可以將 0255 之間的整數(shù)作為含一個(gè) ASCII 字符的字符串。當(dāng)有些 ASCII字符不方便放在字符串中時(shí),可以使用 CHR 將其放在字符串表達(dá)式中。:CHR:A其中,A 為某一字符的 ASCII 值(3STR:將一個(gè)數(shù)字量或者邏輯表達(dá)式轉(zhuǎn)換成串。對(duì)于32 位的數(shù)字量而言,
14、STR將其轉(zhuǎn)換成 8 個(gè)十六進(jìn)制數(shù)組成的串;對(duì)于邏輯表達(dá)式而言,STR 將其轉(zhuǎn)換成字符串 T或者 F:STR:A其中,A 為數(shù)字量或者邏輯表達(dá)式(4LEFT:返回一個(gè)字符串最左端一定長(zhǎng)度的子串A:LEFT:B其中,A 為源字符串,B 為數(shù)字量,表示 LEFT 將返回的字符個(gè)數(shù)(5RIGHT:返回一個(gè)字符串最右端一定長(zhǎng)度的子串A:RIGHT:B其中,A 為源字符串,B 為數(shù)字量,表示 RIGHT 將返回的字符個(gè)數(shù)(6CC:用于連接兩個(gè)字符串A: CC: B 其中,A 為第 1 個(gè)源字符串。B 為第 2 個(gè)源字符串。CC 操作符將 字符串 B 連接在字符串 A 的后面。2、數(shù)字表達(dá)式 數(shù)字表達(dá)式由
15、數(shù)字常量、數(shù)字 變量、操作符和括號(hào)組成數(shù)字變量用偽操作 GBLA 或者 LCLA 聲明,用 SETA 賦 值,它代表一個(gè)32 位的數(shù)字量。操作符:(1)NOT:按位取反:NOT: A 其 中,A 為一個(gè) 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á)式表示了某個(gè)寄存器 的值加上(或者減去)一個(gè)數(shù)字表達(dá)式 基于 PC 的表達(dá)式表示了 PC 寄存器的值加 上(或減去)一個(gè)數(shù)字表達(dá)式。基于 PC 的表達(dá)式通常由程序中的標(biāo)號(hào)與一個(gè)數(shù)字 表達(dá)式組成。相關(guān)的操作符:(1) BASE :返回基于寄存器的表達(dá)式中的寄存器編號(hào)。:BASE : A A 為基于寄存器的表達(dá)式 (2) INDEX :返回基于寄存器的表 達(dá)式相對(duì)于其基址寄存器的偏移量。:INDEX : A A 為基于寄存器的表達(dá)式(3)+、-:正負(fù)號(hào),可以放在數(shù)字表達(dá)式或者基于PC 的表達(dá)式前面。+A (-A) A 為基于 PC 的表達(dá)式或者數(shù)字表達(dá)式 4、邏輯表達(dá)式 由邏輯量、邏輯操作 符、關(guān)系操作符以及括號(hào)組成,取值范圍為FLASE和TRUE關(guān)系操作符:用于表示兩個(gè)同類表達(dá)式之間的關(guān)系。關(guān)系操作符和它的兩個(gè)操 作數(shù)組成一個(gè)邏輯表達(dá)式,其取值為FALSE或TRUE如 A=B 表示 A 等于 B A/=B,AB 表示 A 不等于 B 邏輯操作符:進(jìn)行兩個(gè)邏輯表達(dá)式之間的基本邏輯 操作。操作的結(jié)果為FLASE或TRUE : LNOT : A 邏輯表達(dá)式 A 的值取反 A : LAND : B 邏輯表達(dá)式 A 和 B 邏輯與 5、其他的一些操作符 (1)?:返回定義符 號(hào) A 的代碼行所生成的可執(zhí)行代碼的
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 湘教版地理七年級(jí)上冊(cè)《第三節(jié) 影響氣候的主要因素》聽(tīng)課評(píng)課記錄2
- 蘇科版數(shù)學(xué)七年級(jí)上冊(cè)《有理數(shù)的減法法則》聽(tīng)評(píng)課記錄2
- 現(xiàn)場(chǎng)管理承包協(xié)議書(shū)
- 生活指南版權(quán)使用合同(2篇)
- 魯人版道德與法治九年級(jí)上冊(cè)2.2 做大蛋糕 分好蛋糕 聽(tīng)課評(píng)課記錄
- 聽(tīng)評(píng)課一年級(jí)記錄怎么寫(xiě)
- 吉林省八年級(jí)數(shù)學(xué)下冊(cè)17函數(shù)及其圖象17.4反比例函數(shù)17.4.1反比例函數(shù)聽(tīng)評(píng)課記錄新版華東師大版
- 蘇科版九年級(jí)數(shù)學(xué)聽(tīng)評(píng)課記錄:第52講 用待定系數(shù)法求二次函數(shù)的解析式
- 五年級(jí)數(shù)學(xué)上冊(cè)聽(tīng)評(píng)課記錄
- 滬科版數(shù)學(xué)七年級(jí)下冊(cè)10.2《平行線的判定》聽(tīng)評(píng)課記錄3
- 小學(xué)六年級(jí)數(shù)學(xué)上冊(cè)《簡(jiǎn)便計(jì)算》練習(xí)題(310題-附答案)
- 2024年河南省《輔警招聘考試必刷500題》考試題庫(kù)及答案【全優(yōu)】
- -情景交際-中考英語(yǔ)復(fù)習(xí)考點(diǎn)
- 安全隱患報(bào)告和舉報(bào)獎(jiǎng)勵(lì)制度
- 地理標(biāo)志培訓(xùn)課件
- 2023行政主管年終工作報(bào)告五篇
- 2024年中國(guó)養(yǎng)老產(chǎn)業(yè)商學(xué)研究報(bào)告-銀發(fā)經(jīng)濟(jì)專題
- 公園衛(wèi)生保潔考核表
- 培訓(xùn)如何上好一堂課
- 高教版2023年中職教科書(shū)《語(yǔ)文》(基礎(chǔ)模塊)下冊(cè)教案全冊(cè)
- 2024醫(yī)療銷售年度計(jì)劃
評(píng)論
0/150
提交評(píng)論