ARM偽指令之地址讀?。篈DR/ADRL/LDR
ADR偽指令將基于PC相對偏移的地址值或基于寄存器相對偏移的地址值讀取到寄存器中。
本文引用地址:http://2s4d.com/article/201611/317541.htm在匯編編譯器編譯源程序時(shí),ADR偽指令被編譯器替換成一條合適的指令。通常,編譯器
用一條ADD指令或SUB指令來實(shí)現(xiàn)該ADR偽指令的功能,若不能用一條指令實(shí)現(xiàn),
則產(chǎn)生錯(cuò)誤,編譯失敗。
ADR偽指令格式 :ADR{cond}register, expr
地址表達(dá)式expr的取值范圍:
當(dāng)?shù)刂分凳亲止?jié)對齊時(shí),其取指范圍為: +255 ~ 255B;
當(dāng)?shù)刂分凳亲謱R時(shí),其取指范圍為: -1020 ~ 1020B;
2、ADRL偽指令----中等范圍的地址讀取
ADRL偽指令將基于PC相對偏移的地址值或基于寄存器相對偏移的地址值讀取到寄存器中,
比ADR偽指令可以讀取更大范圍的地址。在匯編編譯器編譯源程序時(shí),ADRL偽指令
被編譯器替換成兩條合適的指令。若不能用兩條指令實(shí)現(xiàn),則產(chǎn)生錯(cuò)誤,編譯失敗。
ADRL偽指令格式:ADRL{cond}register, expr
地址表達(dá)式expr的取值范圍:
當(dāng)?shù)刂分凳亲止?jié)對齊時(shí),其取指范圍為: -64K~64K;
當(dāng)?shù)刂分凳亲謱R時(shí),其取指范圍為: -256K~256K;
3、LDR偽指令-----大范圍的地址讀取
LDR偽指令用于加載32位的立即數(shù)或一個(gè)地址值到指定寄存器。在匯編編譯源程序時(shí),
LDR偽指令被編譯器替換成一條合適的指令。若加載的常數(shù)未超出MOV或MVN的范圍,
則使用MOV或MVN指令代替該LDR偽指令,否則匯編器將常量放入文字池,
并使用一條程序相對偏移的LDR指令從文字池讀出常量。
評論