當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀] 由于嵌入式系統(tǒng)引導(dǎo)裝載程序(BootLoader)的網(wǎng)絡(luò)加載方式在產(chǎn)品開發(fā)初期階段的廣泛應(yīng)用,因此基于網(wǎng)絡(luò)的BootLoader設(shè)計(jì)與實(shí)現(xiàn)具有較強(qiáng)的實(shí)際意義。提出了基于網(wǎng)絡(luò)加載的BootLoader整套設(shè)計(jì)與解決方案,

由于嵌入式系統(tǒng)引導(dǎo)裝載程序(BootLoader)的網(wǎng)絡(luò)加載方式在產(chǎn)品開發(fā)初期階段的廣泛應(yīng)用,因此基于網(wǎng)絡(luò)的BootLoader設(shè)計(jì)與實(shí)現(xiàn)具有較強(qiáng)的實(shí)際意義。提出了基于網(wǎng)絡(luò)加載的BootLoader整套設(shè)計(jì)與解決方案,并將該方案應(yīng)用到實(shí)際產(chǎn)品DVB—C中。最后,通過BootLoad er引導(dǎo)裝載過程的測試與分析,驗(yàn)證該方案的可行性與高效性。


嵌入式系統(tǒng)從軟件結(jié)構(gòu)層次的角度來看,一般由引導(dǎo)裝載程序(BootLoader,BSP)、操作系統(tǒng)和應(yīng)用程序幾部分組成。然而在有的嵌入式系統(tǒng)中,操作系統(tǒng)和應(yīng)用程序存放在系統(tǒng)以外的設(shè)備中,如網(wǎng)絡(luò)、硬盤等,整個(gè)系統(tǒng)只有引導(dǎo)裝載程序。因此BootLoader是嵌入式系統(tǒng)設(shè)計(jì)中比較重要的一部分。

在嵌入式系統(tǒng)的引導(dǎo)中,按照應(yīng)用程序存放位置,可以有3種不同的加載方式:固態(tài)存儲(chǔ)媒體、磁盤以及網(wǎng)絡(luò),每種方式都會(huì)有自己特有的配置和用法。3種設(shè)置方式各有其優(yōu)缺點(diǎn),固態(tài)儲(chǔ)存媒體啟動(dòng)方式一般適用于帶有ROM/FLASH的嵌入式系統(tǒng)中,是大多數(shù)嵌入式設(shè)備的首選方案如手機(jī),MP3等,但當(dāng)應(yīng)用程序較大的情況下,為了降低嵌入式設(shè)備的單價(jià),磁盤啟動(dòng)方式也被大量使用,典型應(yīng)用如SDH電信傳輸網(wǎng)絡(luò)設(shè)備測試儀ANT-20等,而基于網(wǎng)絡(luò)加載方式則是最便宜的嵌入式設(shè)備的應(yīng)用方案,應(yīng)用程序存放在網(wǎng)絡(luò)服務(wù)器端,嵌入式設(shè)備啟動(dòng)時(shí),只需要將它通過網(wǎng)絡(luò)當(dāng)?shù)絻?nèi)存并運(yùn)行,一方面可以快速解決應(yīng)用程序升級(jí)問題,另一方面也可以降低嵌入設(shè)備的整體成本,且在開發(fā)初期這種方式也能大幅提高調(diào)試速度,典型的應(yīng)用如嵌入式設(shè)備的瘦客戶端。

1 基于網(wǎng)絡(luò)加載的BootLoader方案設(shè)計(jì)

這種方案重點(diǎn)解決兩個(gè)問題,一是嵌入式設(shè)備加電后啟動(dòng)前與服務(wù)器端之間的通信與聯(lián)系,二是嵌入設(shè)備在啟動(dòng)過程中應(yīng)用程序下載方式的實(shí)現(xiàn)。前者需要將嵌入式設(shè)備驅(qū)動(dòng)起來,實(shí)現(xiàn)通信能力,網(wǎng)卡驅(qū)動(dòng)是必須實(shí)現(xiàn)的步驟,后者需要通過相關(guān)的協(xié)議棧將應(yīng)用程序下載到系統(tǒng)內(nèi)存,運(yùn)行起來。本文重點(diǎn)介始基于UDP/IP協(xié)議棧的(DHCP、TFIP、NFS)加載方案設(shè)計(jì)。

1.1 BooiLoader中網(wǎng)卡驅(qū)動(dòng)的設(shè)計(jì)

網(wǎng)絡(luò)適配器(網(wǎng)卡)一般由可編程數(shù)據(jù)鏈路控制器、曼徹斯特編碼/譯碼器、收發(fā)器接口和控制電路等幾部分組成,其中可編程數(shù)據(jù)鏈路控制器由微處理器和網(wǎng)絡(luò)管理部分等組成,如圖1所示。

在BootLoader網(wǎng)卡驅(qū)動(dòng)設(shè)計(jì)中,主要包括3種基本的操作(文中以ReaLTEk8139網(wǎng)卡作為實(shí)例進(jìn)行具體分析):

1)網(wǎng)卡的初始化

應(yīng)完成的工作是初始化網(wǎng)卡中的相關(guān)硬件,包括網(wǎng)卡中斷向量的設(shè)置、網(wǎng)卡接收與發(fā)送緩沖區(qū)在內(nèi)存中的映射、網(wǎng)卡數(shù)據(jù)結(jié)構(gòu)的初始化等。

2)數(shù)據(jù)包發(fā)送

發(fā)送和發(fā)送控制部分負(fù)責(zé)幀的發(fā)送。發(fā)送部分接受來自“NBZ曼徹斯特轉(zhuǎn)換器”的曼徹斯特碼的數(shù)據(jù),并在發(fā)送控制部分允許的條件下將數(shù)據(jù)發(fā)送到媒體,發(fā)送的數(shù)據(jù)稱為TxD。發(fā)送控制部分判定是否進(jìn)行發(fā)送,這種判定基于LAN管理部分和TxD來進(jìn)行。

3)數(shù)據(jù)包的接收

接收和接收控制部分負(fù)責(zé)幀的接收。這一部分產(chǎn)生網(wǎng)絡(luò)是否有載波存在的信號(hào),產(chǎn)生的依據(jù)是從RxD中獲得。因此,網(wǎng)絡(luò)上來的信號(hào)一方面饋送給接收器,另一方面要饋送給接收控制部分。接收控制部分根據(jù)LAN管理部分和媒體上接收的信號(hào)判定是否使接收器工作。

1.2 網(wǎng)絡(luò)服務(wù)器端應(yīng)用方案的設(shè)計(jì)

在網(wǎng)絡(luò)加載BootLoader中,使用到的應(yīng)用層協(xié)議有DHCP、TFTP和NFS。目標(biāo)平臺(tái)在工作中,需要服務(wù)器端提供以上協(xié)議的服務(wù):

1)建立服務(wù)器端的DHCP服務(wù)

該服務(wù)完成的功能是為目標(biāo)平臺(tái)提供有效的IP地址分配,保證目標(biāo)平臺(tái)與服務(wù)器之間正常通信時(shí)地址唯一。其配置過程如下:

在確信DHCP協(xié)議已經(jīng)被正確安裝后,需修改/etc/dhcpd.conf文件,例如:

其中subnet是目標(biāo)機(jī)與主機(jī)共同的子網(wǎng),netmask是它們的子網(wǎng)掩碼。Hardware ethernet是目標(biāo)機(jī)的網(wǎng)絡(luò)硬件地址,可以通過fixed-address給目標(biāo)分配一個(gè)固定的IP地址,當(dāng)目標(biāo)機(jī)啟動(dòng)時(shí),就會(huì)自己獲得這個(gè)IP地址。Option host-name是目標(biāo)機(jī)的機(jī)器名。當(dāng)主機(jī)與目標(biāo)機(jī)直接連接時(shí),option routers指向主機(jī)的地址,當(dāng)它們不是直接連接,而是通過路由時(shí),option routers的值為真正的routers地址值,同理optionsubnet-mask為option routers網(wǎng)絡(luò)的子網(wǎng)掩碼。Filename為目標(biāo)機(jī)從TFTP服務(wù)端下載的文件名,next-server為提供TFTP服務(wù)的位置。


最后請(qǐng)檢查/var/state/dhcp/dhcpd.leases文件是否存在,當(dāng)一切準(zhǔn)備好后,就可以運(yùn)行DHCP服務(wù)了:

#/etc/init.d/dhcpd start

2)建立服務(wù)器端的TFTP服務(wù)

該服務(wù)在基于網(wǎng)絡(luò)的BootLoader下載應(yīng)用程序時(shí)使用,它類似于FTP服務(wù),但它不需要向服務(wù)器提供用戶名與密碼,且其下載速度比FTP要快。其配置過程如下:

在確信TFTP協(xié)議已經(jīng)被正確安裝后,

①修改文件/etc/xinetd.conf,打開tftp的支持;

②修改文件/etc/xinetd.d/tftp,例如:

參數(shù)server_args為tftp服務(wù)指定的目錄,其余參數(shù)理解比較容易。

設(shè)置完畢后,請(qǐng)重新啟xinetd,運(yùn)行tap服務(wù)。

3)建立服務(wù)器端的NFS服務(wù)

目標(biāo)平臺(tái)在Linux運(yùn)行初始化時(shí),需要借助該服務(wù)來掛載根文件系統(tǒng)。其配置過程如下:

在確定NFS已經(jīng)正確安裝后,請(qǐng)修改文件/etc/exports,例如:

/home/karim/CTRl—rooffs 192.168.172.10 (rw,no_root_squash)

其中目錄/home/karim/ctrl-rooffs可以修改為服務(wù)器端的根文件系統(tǒng)存放的目錄。192.168.172.10為服務(wù)器端的IP地址。

修改完成后只需要重新啟動(dòng)NFS服務(wù)即可,NFS服務(wù)提供網(wǎng)絡(luò)文件系統(tǒng)功能,便于應(yīng)用程序的管理與使用。

1. 3 客戶端嵌入式BootLoader的設(shè)計(jì)

在基于網(wǎng)絡(luò)加載的BootLoader系統(tǒng)中,應(yīng)用程序文件一般被存放在網(wǎng)絡(luò)服務(wù)器。系統(tǒng)啟動(dòng)后,BootLoader需要先驅(qū)動(dòng)網(wǎng)絡(luò)適配器,并通過UDP/IP協(xié)議棧(BOOTP/DHCP、TFTP協(xié)議等),將映像文件下載到目標(biāo)機(jī)端的SDRAM運(yùn)行,當(dāng)嵌入式linux操作系統(tǒng)初始化時(shí),它借助NFS協(xié)議將根文件系統(tǒng)掛載到服務(wù)器端。

在該方案中,BootLoader程序的主要工作步驟如下:

1)基本硬件的初始化:包括屏蔽所有的中斷、初始化所有的硬件、設(shè)置/裝載系統(tǒng)setup值、設(shè)置CPU的時(shí)鐘和頻率、RAM的初始化等;

2)讀取網(wǎng)絡(luò)參數(shù)配置文件:

該配置文件主要存放系統(tǒng)使用網(wǎng)絡(luò)過程中需要的一些參數(shù),包括MAC地址、tftp服務(wù)器的IP地址、Kernel文件名、應(yīng)用程序文件名等。

3)初始化PCI接口,并驅(qū)動(dòng)網(wǎng)卡;

4)通過DHCP協(xié)議獲取目標(biāo)平臺(tái)的IP地址;

目標(biāo)平臺(tái)先廣播發(fā)送ARP包,當(dāng)DHCP服務(wù)器接收到該ARP包后,就會(huì)根據(jù)ARP包中的硬件地址從地址表中分配一個(gè)有效的IP地址,并發(fā)送應(yīng)答報(bào)文給目標(biāo)平臺(tái)。

5)通過tftp協(xié)議下載kernel代碼至內(nèi)存SDRAM;

6)運(yùn)行Linux內(nèi)核和系統(tǒng)應(yīng)用程序。

該方案的執(zhí)行邏輯可以用圖2所示。


2 基于網(wǎng)絡(luò)加載的BootLoader的應(yīng)用實(shí)現(xiàn)
本文設(shè)計(jì)的基于網(wǎng)絡(luò)加載的嵌入式BootLoader應(yīng)用于DVB-C電視機(jī)頂盒產(chǎn)品中,在DVB-C機(jī)頂盒中,一般有網(wǎng)口用于與內(nèi)容服務(wù)器進(jìn)行交互,如VOD及網(wǎng)頁瀏覽器等功能。其硬件框圖組成如圖3所示。

該DVB-C電視機(jī)頂盒中,CPU是Sunplus公司生產(chǎn)的32位雙核RISC微控制器SPH1003。此外,系統(tǒng)還集成有SEMSung公司的Tuner,其功能是從cable中調(diào)制出TS流,其內(nèi)容為電視節(jié)目流及電視節(jié)目輔助信息(如EPG,電視圖文信息)等。通過電視機(jī)頂盒的集成網(wǎng)口可以實(shí)現(xiàn)電視機(jī)頂盒軟件(主要是嵌入式Linux內(nèi)核,根文件系統(tǒng)及應(yīng)用程序三個(gè)部分)的下載與啟動(dòng)。

在該DVB—C機(jī)頂盒中,BootLoader的裝載程序主要是實(shí)現(xiàn)從網(wǎng)絡(luò)下載嵌入式Linux內(nèi)核并且啟動(dòng)系統(tǒng)。在由BootLoader完成系統(tǒng)的硬件初始化后,程序?qū)?huì)跳轉(zhuǎn)到網(wǎng)絡(luò)Loader程序中,由它驅(qū)動(dòng)網(wǎng)卡,并啟動(dòng)tftp請(qǐng)求,從網(wǎng)絡(luò)服務(wù)器端通過tftp協(xié)議下載指定文件,并運(yùn)行起來,其軟件運(yùn)行如1.3部分。這種應(yīng)用可以有效在利用機(jī)盒中的網(wǎng)卡網(wǎng)絡(luò)結(jié)構(gòu),從而降低機(jī)頂盒的整體成本(少去flash/ROM芯片及其周邊控制硬件等),同時(shí)也有利于及時(shí)更新應(yīng)用程序及嵌入式內(nèi)核等,實(shí)現(xiàn)機(jī)頂盒瘦客戶端目的和及時(shí)維護(hù)功能。

3 BootLoader引導(dǎo)裝載過程的測試與分析

3.1 測試用例設(shè)計(jì)

在DVB-C機(jī)頂盒引導(dǎo)裝載過程的測試中,主要包括單元測試與集成測試兩個(gè)方面。因此在設(shè)計(jì)測試用倒時(shí),主要有單元測試用例及集成測試用例。其測試用例設(shè)計(jì)如表1、表2所示。

3.2 測試結(jié)果分析

根據(jù)上表測試用例的設(shè)計(jì),分析結(jié)果如下:

1)在單元測試中,根據(jù)每個(gè)函數(shù)的功

本站聲明: 本文章由作者或相關(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日 /美通社/ -- 英國汽車技術(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日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(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ì)日本游戲市場的投資。

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

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

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

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

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

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

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

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(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)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

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