GNU ARM匯編--(十二)arm匯編指令的B真的那么簡(jiǎn)單嗎?
在前面對(duì)具體芯片的各個(gè)基本模塊做完了學(xué)習(xí)后,在上一篇小結(jié)中自以為已經(jīng)具備了自己寫個(gè)bootloader的條件,但其實(shí)錯(cuò)了,我還有很多基本的知識(shí)不了解.比如編譯鏈接gnu的linker script等等.也有很多地方只懂表面,沒(méi)有做深入的理解.
本文引用地址:http://cafeforensic.com/article/201611/321719.htm在《GNU ARM匯編--(二)匯編編譯鏈接與運(yùn)行》中,仿照網(wǎng)上的例子做了makefile和linker script,在那篇blog的末尾我寫道“根據(jù)google,做了上面的總結(jié),對(duì)GNU ARM匯編有了認(rèn)識(shí),并且對(duì)系統(tǒng)調(diào)用軟中斷,中斷處理,uboot異常向量表等等有了探究的欲望,也對(duì)elf格式和編譯鏈接有了興趣,根據(jù)自己的方向和精力,后續(xù)對(duì)這些內(nèi)容做一個(gè)或深或淺的學(xué)習(xí).”
當(dāng)時(shí)看到了《linker and loader》,只是保存了,當(dāng)時(shí)并沒(méi)有細(xì)看,作為一個(gè)程序員,其實(shí)很多時(shí)候我們并不懂程序的細(xì)節(jié).就像臺(tái)灣有個(gè)黑客關(guān)于“hello world”的分析,當(dāng)初看了他的"hello world"系列ppt,就發(fā)現(xiàn)原來(lái)簡(jiǎn)單的hello world里面有這么多不為人知的細(xì)節(jié).
這些天翻看了《linker and loader》的前面幾節(jié),也翻了《程序員的自我修養(yǎng)--鏈接裝載和庫(kù)》,通讀了gnu.org的ld相關(guān)文檔linker script.自己還對(duì)gnu的這個(gè)文檔的大部分做了翻譯,在自己的筆記本上寫了好多頁(yè),一根筆芯也用了大半,而且讓我有了久違寫字寫到手酸的感覺(jué).覺(jué)得收獲不少.推薦去看看,值得的.
廢話了這么多,這篇blog我倒不想寫linker script或者ELF的一些細(xì)節(jié).我想深究一下arm匯編指令中的B指令.
很多網(wǎng)上的帖子都討論過(guò)arm匯編指令的B和LDR,這里我按照我的思路來(lái):
首先翻一下《ARM ArchitectureReference Manual》這份絕對(duì)權(quán)威的手冊(cè):
看完上面的英文,再結(jié)合下面的實(shí)際例子做個(gè)呼應(yīng):
代碼如下:
- _start:breset
- ......
- reset:
- ......
反匯編如下:
- 10000000<_start>:
- 10000000:ea00000eb10000040
- ......
- 10000040
:
評(píng)論