新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > ARM偽指令之地址讀取:ADR/ADRL/LDR

ARM偽指令之地址讀?。篈DR/ADRL/LDR

作者: 時間:2016-11-10 來源:網(wǎng)絡(luò) 收藏
1、ADR偽指令--- 小范圍的地址讀取

ADR偽指令將基于PC相對偏移的地址值或基于寄存器相對偏移的地址值讀取到寄存器中。

本文引用地址:http://m.butianyuan.cn/article/201611/317541.htm

在匯編編譯器編譯源程序時,ADR偽指令被編譯器替換成一條合適的指令。通常,編譯器

用一條ADD指令或SUB指令來實現(xiàn)該ADR偽指令的功能,若不能用一條指令實現(xiàn),

則產(chǎn)生錯誤,編譯失敗。

ADR偽指令格式 :ADR{cond}register, expr


地址表達式expr的取值范圍:


當(dāng)?shù)刂分凳亲止?jié)對齊時,其取指范圍為: +255 ~ 255B;


當(dāng)?shù)刂分凳亲謱R時,其取指范圍為: -1020 ~ 1020B;

2、ADRL偽指令----中等范圍的地址讀取

ADRL偽指令將基于PC相對偏移的地址值或基于寄存器相對偏移的地址值讀取到寄存器中,

比ADR偽指令可以讀取更大范圍的地址。在匯編編譯器編譯源程序時,ADRL偽指令

被編譯器替換成兩條合適的指令。若不能用兩條指令實現(xiàn),則產(chǎn)生錯誤,編譯失敗。

ADRL偽指令格式:ADRL{cond}register, expr


地址表達式expr的取值范圍:


當(dāng)?shù)刂分凳亲止?jié)對齊時,其取指范圍為: -64K~64K;


當(dāng)?shù)刂分凳亲謱R時,其取指范圍為: -256K~256K;

3、LDR偽指令-----大范圍的地址讀取

LDR偽指令用于加載32位的立即數(shù)或一個地址值到指定寄存器。在匯編編譯源程序時,

LDR偽指令被編譯器替換成一條合適的指令。若加載的常數(shù)未超出MOV或MVN的范圍,

則使用MOV或MVN指令代替該LDR偽指令,否則匯編器將常量放入文字池,

并使用一條程序相對偏移的LDR指令從文字池讀出常量。



評論


技術(shù)專區(qū)

關(guān)閉