當(dāng)前位置:首頁(yè) > 芯聞號(hào) > 充電吧
[導(dǎo)讀]1、問題一個(gè)工程包含眾多源文件,需要指定一個(gè)入口地址,如IAR IDE中默認(rèn)的入口地址(符號(hào)或者標(biāo)號(hào))"__iar_program_start"(在$TOOLS_DIR$\arm\lib目錄下的cst

1、問題

一個(gè)工程包含眾多源文件,需要指定一個(gè)入口地址,如IAR IDE中默認(rèn)的入口地址(符號(hào)或者標(biāo)號(hào))"__iar_program_start"(在$TOOLS_DIR$armlib目錄下的cstart.s文件中定義)。對(duì)于一般程序而言,入口地址就是程序首先被執(zhí)行的指令(函數(shù))。然后,在嵌入式系統(tǒng)中,必須考慮芯片復(fù)位時(shí)的異常向量表,在異常向量表中的復(fù)位異常跳轉(zhuǎn)的地址,也是程序首先執(zhí)行的地址。那么此時(shí)的program entry和復(fù)位異常跳轉(zhuǎn)地址的孰是孰非?哪個(gè)才是真正的入口執(zhí)行?

毫無(wú)疑問,肯定是復(fù)位異常首先被執(zhí)行,那為什么需要配置"program entry"?

?

2、這得從系統(tǒng)的角度去尋找答案。在main函數(shù)運(yùn)行之前,必須要有硬件初始化、軟件初始化,其中軟件初始化一般包含全局變量、0初始化變量、堆棧等等,這部分的初始化稱為系統(tǒng)初始化,一般由啟動(dòng)代碼完成。IAR IDE工具在默認(rèn)的情況下會(huì)根據(jù)工程配置,在最終可執(zhí)行的鏡像中加入合適的啟動(dòng)代碼。注意這里的【默認(rèn)情況】是如何實(shí)現(xiàn)的:通常而言構(gòu)建構(gòu)成包括編譯、鏈接,編譯工程源代碼得到目標(biāo)文件,將目標(biāo)文件和庫(kù)文件作為輸入,送給鏈接器鏈接得到可執(zhí)行文件(鏡像)。鏈接器鏈接時(shí),解決了外部引用符號(hào)的重定位、地址安排等,但是,對(duì)于鏈接器而言,程序從哪里開始執(zhí)行呢?

1)默認(rèn)的main?非也,

2)鏈接器不需要知道程序從哪里開始執(zhí)行,只需要強(qiáng)制低把啟動(dòng)代碼加入,就可以實(shí)現(xiàn)從復(fù)位異常-》系統(tǒng)初始化-》main完成。但是,這樣的鏈接器動(dòng)作太過死板,如果用戶需要另外的啟動(dòng)方式,則使用此鏈接器不能達(dá)到目標(biāo)。

故,鏈接器必須知道程序的入口地址,當(dāng)鏈接器得到程序的入口地址之后,才會(huì)鏈接包含入口地址的模塊(庫(kù)文件或者目標(biāo)文件),并且依據(jù)此入口地址構(gòu)建函數(shù)調(diào)用棧,在函數(shù)調(diào)用棧中的每一個(gè)函數(shù)都需要找到定義的模塊,鏈接器由此得到所有需要鏈接的模塊(庫(kù)、目標(biāo)文件),最后才是所有模塊的鏈接形成可執(zhí)行文件。

因此,“program entry”是為了給鏈接器指示用的。

?

3、異常向量表的復(fù)位異常跳轉(zhuǎn)地址和“program entry”看來(lái)沒有直接的關(guān)系,因?yàn)?/p>

1)芯片復(fù)位后,經(jīng)復(fù)位異常跳轉(zhuǎn),不一定調(diào)到“program entry”處執(zhí)行;

2)異常向量表需要配合目標(biāo)系統(tǒng)硬件的啟動(dòng)方式、內(nèi)存地址等眾多因素,其最主要的作用是,芯片復(fù)位后調(diào)到啟動(dòng)代碼處執(zhí)行,以及發(fā)生中斷、其他異常時(shí),跳轉(zhuǎn)到相應(yīng)的處理代碼處。

?

4、如果用戶自行編寫啟動(dòng)代碼,只需要將該啟動(dòng)代碼添加入工程,重新指定“program entry”則可以完成用戶自定義的啟動(dòng)方式,重寫了IAR IDE默認(rèn)提供的cstartup.s啟動(dòng)文件。

?

5、為了驗(yàn)證上述猜想,做一個(gè)測(cè)試。新建一個(gè)簡(jiǎn)單的main工程,工程只有一個(gè)main.c源文件:

int?main()
{
??return?0;
}

1)在默認(rèn)情況下,工程選項(xiàng)配置成“__iar_program_entry”,如下圖

編譯后,查看生成的map文件:

*******************************************************************************
***?ENTRY?LIST
***

Entry????????????????????Address??Size??Type??????Object
-----????????????????????-------??----??----??????------
?main?????????????????0x00000100????????Code??Gb??cmain.o?[5]
Abort_Handler?????????0x0000015c????????Code??Wk??vectortrap.o?[5]
CSTACK$$Base??????????0x00100000?????????--???Gb??-?Linker?created?-
CSTACK$$Limit?????????0x00102000?????????--???Gb??-?Linker?created?-
FIQ_Handler???????????0x0000015c????????Code??Wk??vectortrap.o?[5]
FIQ_STACK$$Base???????0x00102100?????????--???Gb??-?Linker?created?-
FIQ_STACK$$Limit??????0x00102200?????????--???Gb??-?Linker?created?-
IRQ_Handler???????????0x0000015c????????Code??Wk??vectortrap.o?[5]
IRQ_STACK$$Base???????0x00102000?????????--???Gb??-?Linker?created?-
IRQ_STACK$$Limit??????0x00102100?????????--???Gb??-?Linker?created?-
Prefetch_Handler??????0x0000015c????????Code??Wk??vectortrap.o?[5]
Region$$Table$$Base???0x00000000?????????--???Gb??-?Linker?created?-
Region$$Table$$Limit??0x00000000?????????--???Gb??-?Linker?created?-
SWI_Handler???????????0x0000015c????????Code??Wk??vectortrap.o?[5]
Undefined_Handler?????0x0000015c????????Code??Wk??vectortrap.o?[5]
__cmain???????????????0x00000100????????Code??Gb??cmain.o?[5]
__exit????????????????0x00000138????????Code??Gb??XXexit.o?[5]
__iar_init_vfp????????0x000000ec????????Code??Gb??fpinit.o?[4]
__iar_init_vfp_v6?????0x000000d8????????Code??Gb??fpinit.o?[4]
__iar_program_start???0x00000080????????Code??Gb??cstartup.o?[5]
__low_level_init??????0x00000124???0x8??Code??Gb??low_level_init.o?[3]
__vector??????????????0x00000000????????Data??Gb??cstartup.o?[5]
_call_main????????????0x00000110????????Code??Gb??cmain.o?[5]
_exit?????????????????0x0000014c????????Code??Gb??cexit.o?[5]
_main?????????????????0x00000118????????Code??Gb??cmain.o?[5]
exit??????????????????0x00000134???0x4??Code??Gb??exit.o?[3]
main??????????????????0x0000012c???0x8??Code??Gb??main.o?[1]

entry欄是函數(shù)名稱,也是函數(shù)的入口地址;object欄是來(lái)源的目標(biāo)文件??梢钥吹剑癬_iar_program_start“位于cstartup.o文件中,也就是IAR默認(rèn)提供的啟動(dòng)文件。從__iar_program_start開始執(zhí)行,還調(diào)用了其他的函數(shù),所以在可執(zhí)行文件中,還可以看到其他的entry,比如_main,?main,SWI_Handler等等(這些entry都在IAR安裝目錄下的armsrclibarm目錄下的文件中定義)。這些都是因?yàn)閺?__iar_program_entry"開始執(zhí)行時(shí)的函數(shù)調(diào)用棧中的函數(shù)。

2)更改程序的入口為main,如下圖:

?編譯后,查看生成的map文件

*******************************************************************************
***?ENTRY?LIST
***

Entry????????????????????Address??Size??Type??????Object
-----????????????????????-------??----??----??????------
Region$$Table$$Base???0x00000000?????????--???Gb??-?Linker?created?-
Region$$Table$$Limit??0x00000000?????????--???Gb??-?Linker?created?-
__iar_init_vfp????????0x00000094????????Code??Gb??fpinit.o?[4]
__iar_init_vfp_v6?????0x00000080????????Code??Gb??fpinit.o?[4]
main??????????????????0x000000a8???0x8??Code??Gb??main.o?[1]

對(duì)比可以發(fā)現(xiàn),在最終可執(zhí)行文件中,僅包括了main目標(biāo)文件的main entry。鏈接器鏈接時(shí),直接從mian entry開始執(zhí)行,不再調(diào)用其他的函數(shù),故不用鏈接到IAR系統(tǒng)提供的庫(kù),也不用自動(dòng)加入啟動(dòng)代碼。

總結(jié):program entry是為了鏈接器服務(wù)的,它給出了鏈接器在鏈接時(shí)需要鏈接的模塊,從而為用戶提供重寫啟動(dòng)代碼的方法。

關(guān)于異常向量表如何配合目標(biāo)硬件系統(tǒng),將在后面的文件補(bǔ)充。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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