ARM9學習筆記之——匯編
在寫ARM匯編程序時,發(fā)現(xiàn)ARM的指令非常的靈活,同樣一個功能可以使用多種方式實現(xiàn)。給開發(fā)者更多DIY的地方。以下是一些小總結,如有不正確的地方歡迎指正。
本文引用地址:http://www.ex-cimer.com/article/201611/318807.htm1. 關于函數(shù)調用方法
在ARM匯編中,函數(shù)調用非常靈活。
(1)BL指令
- blinitmem;調用
- mem
- ....
- movpc,lr;返回
BL指令在編譯時,是以當前指令地址為基準相對跳轉。由于指令中地址區(qū)域為16位,其中1位作前后標志,剩下15位作為跳轉范圍。所以跳轉地址范圍為當前地址前后32MB地址。
(2)LDR PC, = xmain
- ldrlr,=endmain;保存絕對返回地址
- ldrpc,=xmain;絕對地址跳轉
- endmain
- bendmain
當編譯器在對LDR宏進行編譯時,xmain作為絕對地址賦給PC。
(3)BX
- ldrr0,=xmain
- bxr0
也是絕對地址跳轉。在跳轉中,可以進行ARM與thumb指令集轉換。
2.關于LDR與ADR宏
在做“2.6.8內存驅動實驗”時,我關注了initmemloop前一個指令"adr r2, memdata"。嘗試著將它換成 ldr 進行實驗。
經過反匯編與寄存器跟蹤,我看到它們的區(qū)別:
- ldrr2,=memdata;r2=運行地址
- adrr2,memdata;r2=加載地址
- ldrr2,memdata;r2=0x22000000
- adrr2,=memdata;編譯錯誤
評論