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