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