S3C2440的匯編中常用的位置無(wú)關(guān)和位置相關(guān)指令
掃描二維碼
隨時(shí)隨地手機(jī)看文章
看了一段時(shí)間的S3C2440的bootloader后,感覺(jué)
在bootloder程序中經(jīng)常會(huì)用到B,BL指令。他們是位置無(wú)關(guān)的代碼,指令中所跳轉(zhuǎn)的目標(biāo)地址用基于當(dāng)前PC的偏移量來(lái)表示,與鏈接時(shí)分配給地址標(biāo)號(hào)的絕對(duì)地址值無(wú)關(guān),因而代碼可以在任何位置進(jìn)行跳轉(zhuǎn),實(shí)現(xiàn)位置無(wú)關(guān)性。
在bootloder也用到了位置無(wú)關(guān)的指令LDR(只對(duì)PC操作時(shí)才位置無(wú)關(guān)),例如LDRPC,=Main(程序跳轉(zhuǎn)到SDRAM處執(zhí)行);
S3c2440從NandFlash啟動(dòng)時(shí),會(huì)將nandflash的前4KB的數(shù)據(jù)復(fù)制到s3c2440中的一個(gè)stepstoning中,而stepstoning在NandFlash啟動(dòng)時(shí)被映射到0地址處,所以s3c2440就能執(zhí)行NandFlash的前4KB的程序了。在這4KB中執(zhí)行的對(duì)應(yīng)B和BL指令處的代碼都會(huì)跳轉(zhuǎn)到相對(duì)PC偏移量的地址。當(dāng)然跳轉(zhuǎn)的位置在這4KB內(nèi)。
LDRPC,=Main,是絕對(duì)跳轉(zhuǎn)。直接將Main標(biāo)號(hào)所代表的地址直接復(fù)制給PC,那么程序就會(huì)跳到Main函數(shù)的入口地址處執(zhí)行。Main標(biāo)號(hào)的是基于鏈接器的值,換句話說(shuō)就是基于ro-base或者所用的鏈接腳本文件(或者可以說(shuō)是相對(duì)于ro-base的值,而相對(duì)跳轉(zhuǎn)是相對(duì)于入口地址的值)。
使用絕對(duì)地址只能引用被重定位到特定位置的代碼段中的符號(hào),通過(guò)在位置無(wú)關(guān)代碼中引入絕對(duì)地址,可以讓程序跳轉(zhuǎn)到指定位置。例如,假設(shè)Bootloader的階段1將其自身代碼拷貝到鏈接時(shí)所指定的SDRAM地址空間后,當(dāng)要跳轉(zhuǎn)到階段2的C程序入口時(shí),可以使用指令“LDRPC,=main”跳轉(zhuǎn)到程序在SDRAM中的main函數(shù)入口地址開(kāi)始執(zhí)行。這是因?yàn)槌绦蛟诰幾g鏈接時(shí)給main函數(shù)分派絕對(duì)地址,系統(tǒng)通過(guò)將main函數(shù)的絕對(duì)地址直接賦給PC實(shí)現(xiàn)程序跳轉(zhuǎn)。如果使用相對(duì)跳轉(zhuǎn)指令“Bmain”,那么只會(huì)跳轉(zhuǎn)到啟動(dòng)ROM內(nèi)部的main函數(shù)入口。