當前位置:首頁 > 嵌入式 > 嵌入式教程
[導讀]ARM處理器的位置無關(guān)程序設(shè)計

ARM處理器支持位置無關(guān)的程序設(shè)計,這種程序加載到存儲器的任意地址空間都可以正常運行,其設(shè)計方法在嵌入式應用系統(tǒng)開發(fā)中具有重要的作用。尤其在裸機狀態(tài)下開發(fā)Bootloader程序及進行內(nèi)核初始化設(shè)計;利用位置無關(guān)的程序設(shè)計方法還可以在具體應用中用于構(gòu)建高效率動態(tài)鏈接庫,因而了解位置無關(guān)的程序設(shè)計方法,有助于開發(fā)人員設(shè)計出結(jié)構(gòu)簡單、清晰的應用程序。

  應用程序必須經(jīng)過編譯、匯編和鏈接后才變成可執(zhí)行文件,在鏈接時,要對所有目標文件進行重定位(relocatiON),建立符號引用規(guī)則,同時為變量、函數(shù)等分配運行地址。當程序執(zhí)行時,系統(tǒng)必須把代碼加載到鏈接時所指定的地址空間,以保證程序在執(zhí)行過程中對變量、函數(shù)等符號的正確引用,使程序正常運行。在具有操作系統(tǒng)的系統(tǒng)中,重定位過程由操作系統(tǒng)自動完成。

  在設(shè)計Bootloader程序時,必須在裸機環(huán)境中進行,這時Bootloader映像文件的運行地址必須由程序員設(shè)定。通常情況下,將Bootloader程序下載到ROM的0x0地址進行啟動,而在大多數(shù)應用系統(tǒng)中,為了快速啟動,首先將Bootloader程序拷貝到SDRAM中再運行。一般情況下,這兩者的地址并不相同,程序在SDRAM中的地址重定位過程必須由程序員完成。實際上,由于Bootloader是系統(tǒng)上電后要執(zhí)行的第一段程序,Bootloader程序的拷貝和在這之前的所有工作都必須由其自身來完成,而這些指令都是在ROM中執(zhí)行的。也就是說,這些代碼即使不在鏈接時所指定的運行時地址空間,也可以正確執(zhí)行。這就是位置無關(guān)代碼,它是一段加載到任意地址空間都能正常執(zhí)行的特殊代碼。

  位置無關(guān)代碼常用于以下場合:

  程序在運行期間動態(tài)加載到內(nèi)存;

  程序在不同場合與不同程序組合后加載到內(nèi)存(如共享的動態(tài)鏈接庫);

  在運行期間不同地址相互之間的映射(如Bootloader程序)。

  雖然在用GCC編譯時,使用-fPIC選項可為C語言產(chǎn)生位置無關(guān)代碼,但這并不能修正程序設(shè)計中固有的位置相關(guān)性缺陷。特別是匯編語言代碼,必須由程序員遵循一定的程序設(shè)計準則,才能保證程序的位置無關(guān)性。

  ARM程序的位置無關(guān)可執(zhí)行文件PIE(PositionIndependent Executable)包括位置無關(guān)代碼PIC和位置無關(guān)數(shù)據(jù)PID(PositionIndependent Data)兩部分。

  PID主要針對可讀寫數(shù)據(jù)段(.data段),其中保存已賦初值的全局變量。為實現(xiàn)其位置無關(guān)性,通常使用寄存器R9作為靜態(tài)基址寄存器,使其指向該可讀寫段的首地址,并使用相對于基址寄存器的偏移量來對該段的變量進行尋址。這種方法常用于為可重入程序的多個實例產(chǎn)生多個獨立的數(shù)據(jù)段。在程序設(shè)計中,一般不必考慮可讀寫段的位置無關(guān)性,這主要是因為可讀寫數(shù)據(jù)主要分配在SDRAM中。

  PIC包括程序中的代碼和只讀數(shù)據(jù)(.text段),為保證程序能在ROM和SDRAM空間都能正確運行(如裸機狀態(tài)下的Bootloader程序),必須采用位置無關(guān)代碼程序設(shè)計。

  PIC遵循只讀段位置無關(guān)ROPI(ReadOnly Position Independence)的ATPCS(ARMThumb Procedure Call STandard)的程序設(shè)計規(guī)范:

程序設(shè)計規(guī)范 #e#

 

 ?。?) 程序設(shè)計規(guī)范1

  引用同一ROPI段或相對位置固定的另一ROPI段中的符號時,必須是基于PC的符號引用,即使用相對于當前PC的偏移量來實現(xiàn)跳轉(zhuǎn)或進行常量訪問。

 ?、?位置無關(guān)的程序跳轉(zhuǎn)。在ARM匯編程序中,使用相對跳轉(zhuǎn)指令B/BL實現(xiàn)程序跳轉(zhuǎn)。指令中所跳轉(zhuǎn)的目標地址用基于當前PC的偏移量來表示,與鏈接時分配給地址標號的絕對地址值無關(guān),因而代碼可以在任何位置進行跳轉(zhuǎn),實現(xiàn)位置無關(guān)性。

  另外,還可使用ADR或ADRL偽指令將地址標號值讀取到PC中實現(xiàn)程序跳轉(zhuǎn)。這是因為ADR或ADRL等偽指令會被編譯器替換為對基于PC的地址值進行操作,但這種方式所能讀取的地址范圍較小,并且會因地址值是否為字對齊而異。

  但在ARM程序中,使用LDR等指令直接將地址標號值讀取到PC中實現(xiàn)程序跳轉(zhuǎn)不是位置無關(guān)的。例如:  LDR PC, =main

  上面的偽指令編譯后的結(jié)果為:  LDR PC, [PC, OFFSET_TO_LPOOL]

  ?                                                              LPOOL

  DCD main

  可見,雖然LDR是把基于PC的一個存儲單元LPOOL的內(nèi)容加載到PC中,但該存儲單元中保存的卻是鏈接時所決定的main函數(shù)入口的絕對地址,所以main函數(shù)實際所在的段不是位置無關(guān)。

  ② 位置無關(guān)的常量訪問。在應用程序中,經(jīng)常要讀寫相關(guān)寄存器以完成必要的硬件初始化。為增強程序的可讀性,利用EQU偽指令對一些常量進行賦值,但在訪問過程中,必須實現(xiàn)位置無關(guān)性。下面以PXA270的GPIO初始化介紹位置無關(guān)的常量訪問方法。

  GPIO_BASE EQU 0x40e00000; GPIO基址寄存器地址

  GPDR0 EQU 0x00c; 相對于GPIO基址寄存器的偏移量

  init_GPDR0 EQU 0xfffbfe00; 寄存器GPDR0初值

  LDR R1, =GPIO_BASE

  LDR R0, =init_GPDR0

  STR R0, [R1, #GPDR0][!--empirenews.page--]

  上述匯編代碼段經(jīng)編譯后的結(jié)果為:

  LDR R1, [PC, OFFSET_TO_GPIO_BASE]

  LDR R0, [PC, OFFSET_TO_init_GPDR0]

  STR R0, [R1, #0xc]?

  GPIO_BASE

  DCD 0x40e00000

  GPDR0

  DCD 0x00c

  init_GPDR0

  DCD 0xfffbfe00

  可見,LDR偽指令實際上使用基于PC的偏移量來對符號常量GPIO_BASE和init_GPDR0進行引用,因而是位置無關(guān)的。由此可以得出如下結(jié)論:使用LDR偽指令將一個常量讀取到非PC的其他通用寄存器中可實現(xiàn)位置無關(guān)的常量訪問;但將一個地址值讀取到PC中進行程序跳轉(zhuǎn)時,跳轉(zhuǎn)目標則是位置相關(guān)的。

 ?。?) 程序設(shè)計規(guī)范2

  其他被ROPI段中的代碼引用的必須是絕對地址,或者是基于可讀寫位置無關(guān)(RWPI)段的靜態(tài)基址寄存器的可寫數(shù)據(jù)。

  使用絕對地址只能引用被重定位到特定位置的代碼段中的符號,通過在位置無關(guān)代碼中引入絕對地址,可以讓程序跳轉(zhuǎn)到指定位置。例如,假設(shè)Bootloader的階段1將其自身代碼拷貝到鏈接時所指定的SDRAM地址空間后,當要跳轉(zhuǎn)到階段2的C程序入口時,可以使用指令“LDR PC, =main”跳轉(zhuǎn)到程序在SDRAM中的main函數(shù)入口地址開始執(zhí)行。這是因為程序在編譯鏈接時給main函數(shù)分派絕對地址,系統(tǒng)通過將main函數(shù)的絕對地址直接賦給PC實現(xiàn)程序跳轉(zhuǎn)。如果使用相對跳轉(zhuǎn)指令“B main”,那么只會跳轉(zhuǎn)到啟動ROM內(nèi)部的main函數(shù)入口。


 

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉