從0學(xué)ARM——什么是位置無(wú)關(guān)碼?
如果我們將生成的bin文件拷貝到內(nèi)存0x40008000位置運(yùn)行必然沒(méi)有問(wèn)題,
bl func 和 ldr pc,=func 都能跳轉(zhuǎn)到func函數(shù),
而19行代碼,也能訪問(wèn)到全局變量aaaa。
如果我們將該程序拷貝到其他地址是否能正常運(yùn)行呢?
假定我們拷貝到0地址運(yùn)行,那么程序的執(zhí)行地址需要從0開(kāi)始重新編排,即_start對(duì)應(yīng)0地址,main對(duì)應(yīng)0x18。
拷貝到0地址后內(nèi)存布局:
拷貝到0地址運(yùn)行后,**內(nèi)存中指令(機(jī)器碼)**的內(nèi)容還和以前一樣,pc的值會(huì)根據(jù)實(shí)際運(yùn)行地址重新修正。
首先看bl func
對(duì)應(yīng)的匯編代碼是 第9行;該指令的機(jī)器碼是0xeb000001,我們?cè)凇?. 從0開(kāi)始學(xué)ARM-ARM指令,移位、數(shù)據(jù)處理、BL、機(jī)器碼》講過(guò)該機(jī)器碼格式是從pc的位置向前偏移1條指令因?yàn)槿?jí)流水線,所以應(yīng)該往下偏移3條指令,即func的位置,所以bl仍然可以正確找到func這個(gè)函數(shù)。
bl funcldr pc,=func對(duì)應(yīng)的匯編代碼是 第10行;
我們可以看到是從pc值+4位置取出對(duì)應(yīng)的內(nèi)存的值,pc值+4是14,該位置對(duì)應(yīng)15行,即將40008010寫(xiě)入到pc,
而我們的bin文件只有44個(gè)字節(jié)大小,所以此時(shí)內(nèi)存40008010并沒(méi)有我們編寫(xiě)的任何代碼。所以ldr pc,=func 無(wú)法跳轉(zhuǎn)到func。
c訪問(wèn)全局變量aaaa
對(duì)應(yīng)的匯編代碼是 第19行;
c訪問(wèn)全局變量aaaa
我們可以看到是從pc值+4位置取出對(duì)應(yīng)的內(nèi)存的值,pc值+4是28,該位置對(duì)應(yīng)22行,即將4000802c寫(xiě)入到r3,然后20行會(huì)將r2中值寫(xiě)入到0x4000802c這個(gè)地址,而此時(shí)該地址并不是全局變量aaaa,所以此指令是無(wú)法找到bss段的aaaa變量的內(nèi)存。
三、總結(jié)
1. 位置無(wú)關(guān)碼:
CPU取指時(shí)用相對(duì)地址取指令(比如pc +4),只要其相對(duì)地址沒(méi)有變,都能夠取指并運(yùn)行。即該段代碼無(wú)論放在內(nèi)存的哪個(gè)地址,都能正確運(yùn)行。究其原因,是因?yàn)榇a里沒(méi)有使用絕對(duì)地址,都是相對(duì)地址。
2. 位置相關(guān)碼:
利用絕對(duì)地址取指并運(yùn)行,這就需要你存放程序(鏈接過(guò)程中)需要按照連接腳本的要求那樣執(zhí)行(Makefile里面有 -Ttext xxx指定或連接腳本)。即它的地址與代碼處于的位置相關(guān),是絕對(duì)地址,如:mov PC ,#0xff;ldr pc,=0xffff等。
3. 位置無(wú)關(guān)碼的應(yīng)用:
1). 程序在運(yùn)行期間動(dòng)態(tài)加載到內(nèi)存;
2). 程序在不同場(chǎng)合與不同程序組合后加載到內(nèi)存(共享的動(dòng)態(tài)鏈接庫(kù));
3). 在運(yùn)行期間不同地址相互之間的映射(如bootloader)
4. 結(jié)論使用「mov pc ,xxx ; ldr pc ,xxx」等就是位置相關(guān)碼。這些使用絕對(duì)指令尋址。而使用「bl ,b ,adr,ldr」一般為位置無(wú)關(guān)碼。在使用「b, bl」調(diào)用C語(yǔ)言中的函數(shù)里「不要使用全局變量」,因?yàn)镃中全局變量的地址「也是根據(jù)鏈接地址生成」的。使用=和不使用=號(hào)是有很大區(qū)別的!笩o(wú)=號(hào):取該標(biāo)號(hào)處的值,位置無(wú)關(guān)有=號(hào):取該標(biāo)號(hào)的地址,位置相關(guān)」
【考一考】考一考大家為什么uboot的異常向量表的reset異常,指令是b reset,而其他異常卻是我們本文所說(shuō)的位置相關(guān)碼,ldr pc,XXXXXX?
arm對(duì)應(yīng)的uboot異常向量表如下:
arch/arm/cpu/armv7/start.S
發(fā)表評(píng)論
請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字
最新活動(dòng)更多
-
即日-10.29立即報(bào)名>> 2024德州儀器嵌入式技術(shù)創(chuàng)新發(fā)展研討會(huì)
-
10月31日立即下載>> 【限時(shí)免費(fèi)下載】TE暖通空調(diào)系統(tǒng)高效可靠的組件解決方案
-
即日-11.13立即報(bào)名>>> 【在線會(huì)議】多物理場(chǎng)仿真助跑新能源汽車
-
11月14日立即報(bào)名>> 2024工程師系列—工業(yè)電子技術(shù)在線會(huì)議
-
12月19日立即報(bào)名>> 【線下會(huì)議】OFweek 2024(第九屆)物聯(lián)網(wǎng)產(chǎn)業(yè)大會(huì)
-
即日-12.26火熱報(bào)名中>> OFweek2024中國(guó)智造CIO在線峰會(huì)
推薦專題
- 1 Intel宣布40年來(lái)最重大轉(zhuǎn)型:年底前裁員15000人、拋掉2/3房產(chǎn)
- 2 因美封殺TikTok,字節(jié)股價(jià)骨折!估值僅Meta1/5
- 3 宏山激光重磅發(fā)布行業(yè)解決方案,助力智能制造產(chǎn)業(yè)新飛躍
- 4 國(guó)產(chǎn)AI芯片公司破產(chǎn)!白菜價(jià)拍賣
- 5 具身智能火了,但規(guī)模落地還需時(shí)間
- 6 國(guó)產(chǎn)英偉達(dá)們,抓緊沖刺A股
- 7 三次錯(cuò)失風(fēng)口!OpenAI前員工殺回AI編程賽道,老東家捧金相助
- 8 英特爾賦能智慧醫(yī)療,共創(chuàng)數(shù)字化未來(lái)
- 9 英偉達(dá)的麻煩在后頭?
- 10 將“網(wǎng)紅”變成“商品”,AI“爆改”實(shí)力拉滿
- 高級(jí)軟件工程師 廣東省/深圳市
- 自動(dòng)化高級(jí)工程師 廣東省/深圳市
- 光器件研發(fā)工程師 福建省/福州市
- 銷售總監(jiān)(光器件) 北京市/海淀區(qū)
- 激光器高級(jí)銷售經(jīng)理 上海市/虹口區(qū)
- 光器件物理工程師 北京市/海淀區(qū)
- 激光研發(fā)工程師 北京市/昌平區(qū)
- 技術(shù)專家 廣東省/江門市
- 封裝工程師 北京市/海淀區(qū)
- 結(jié)構(gòu)工程師 廣東省/深圳市