當前位置:首頁 > 嵌入式 > 嵌入式教程
[導讀]一種嵌入式Linux平臺的軟硬件設(shè)計

摘要:介紹了一種嵌入式Linux操作系統(tǒng)--uClinux,給出了一種MCF5272硬件平臺的設(shè)計,并實現(xiàn)了uClinux在該目標板上的移植,講述了MCF5272處理器平臺硬件設(shè)計和uClinux板移植的一般性方法。

關(guān)鍵詞:uClinux MCF5272 移植

1 操作系統(tǒng)uClinux

Linux是一種很受歡迎的類UNIX操作系統(tǒng),它免費并開放源代碼,在個人計算機、服務器領(lǐng)域應用廣泛。更重要的是,Linux采用模塊化設(shè)計,實際應用中可以定制,因此Linux也適用于嵌入式領(lǐng)域。uClinux正是Linux的一個嵌入式版本,其內(nèi)核的二進制映像文件可以做到小于512KB。

uClinux針對無內(nèi)存管理單元MMU(Memory Management Unit)的處理器設(shè)計,支持多任務,具有完備的TCP/IP協(xié)議棧并支持多種網(wǎng)絡(luò)協(xié)議。uClinux還支持多種文件系統(tǒng),如ROMFS、NFS、FAT16/32。實際上,uClinux已經(jīng)成功應用于路由器、網(wǎng)絡(luò)攝像機、機頂盒、PDA等諸多領(lǐng)域。

另外,uClinux可移植性很強,用戶通過重新配置、編譯內(nèi)核,很方便將其移植到68K、Dragon Ball、ColdFire、Power PC、ARM等多種處理器計算平臺。當前uClinux提供2.0和2.4兩個內(nèi)核版本。從內(nèi)核版本2.2開始,Linux被設(shè)計成與IEEE POSIX標準兼容的系統(tǒng),這意味著大部分已有的UNIX程序,源代碼不經(jīng)修改就可以進行編譯并移植到新的目標平臺。筆者選擇了2.4內(nèi)核的uClinux作為平臺操作系統(tǒng)。

2 硬件平臺設(shè)計

2.1 處理器

目標平臺CPU采用Motorola公司生產(chǎn)的ColdFire嵌入式處理器MCF5272。MCF5272采用ColdFfireV2可變長RISC處理器核和DigitalDNA技術(shù),在66MHz時鐘下能夠達到63MIPS@Dhrystone2.1的優(yōu)良處理能力。其內(nèi)部SIM(System Integrated Module)單元集成了豐富的通用模塊,如10/100Mbps快速以太網(wǎng)控制器、USB1.1接口等,并且能夠與常用的外圍設(shè)備(如SDRAM、ISDN收發(fā)器)實現(xiàn)無縫連接,從而簡化了外圍電路設(shè)計,降低了產(chǎn)品成本、體積和功耗。

2.2 系統(tǒng)內(nèi)存

系統(tǒng)內(nèi)存由三部分組成。MCF5272內(nèi)部集成了4K字節(jié)的SRAM(靜態(tài)RAM)以及片外擴展的FLASH(閃爍存儲器)和SDRAM(同步動態(tài)RAM)。FLASH容量為1M×16Bit,AMD29LV系列,片選信號為CS0,用于存放矢量表、uClinux內(nèi)核映像及ROMFS文件系統(tǒng)。SDRAM采用兩片HY系列4M×16Bit的SDRAM,共同組成16M、32位寬的系統(tǒng)主存儲器。SDRAM片選信號為CS7。

2.3 通用外設(shè)

MCF5272內(nèi)部集成了UART、USB控制器,只需很少的外圍芯片就可以實現(xiàn)兩個RS232串口和一個USB Slave接口。MCF5272還內(nèi)嵌一個FEC(快速以太網(wǎng)控制器),片外擴展一片LXT971,可方便地實現(xiàn)了一個100/10 Base T的以太網(wǎng)接口。

2.4 調(diào)試接口

ColdFire系列處理器支持背景調(diào)試模式(BDM),它提供了對底層硬件的調(diào)試手段。在背景調(diào)試模式下,通過向CPU發(fā)送命令,可以實現(xiàn)對CPU寄存器、系統(tǒng)存儲器的訪問。使用Motorola推薦的26針插座接到BDM仿真頭,實現(xiàn)代碼的下載和調(diào)試。

3 移植uClinux到目標平臺

3.1 uClinux的啟動過程

uClinux的啟動通常經(jīng)歷三個階段。首先,它必須完成CPU和存儲器的硬件初始化。在系統(tǒng)RAM中建立程序堆棧和數(shù)據(jù)段(包括DATA和BSS數(shù)據(jù)段),建立程序的運行時環(huán)境。如果ROMFS是RAM駐留的,也必須對其進行初始化。

最初的初始化完成后,uClinux內(nèi)核就取得了CPU的控制權(quán),開始操作系統(tǒng)自身的初始化。這包括建立RAM中斷矢量表、加載設(shè)備驅(qū)動程序、內(nèi)存管理模塊等。這一切完成后,uClinux啟動一個最初的init線程,進入到第三階段。這時候內(nèi)核已經(jīng)正常運行,外圍模塊也都就緒,開始執(zhí)行一些腳本文件(如/etc/rc腳本文件)。這通常是嵌入式開發(fā)者最感興趣的一個切入點。

3.2 編寫硬件相關(guān)代碼

作為源代碼公開的免費操作系統(tǒng),uClinux源代碼可以從www.uclinux.org得到。這個源代碼也在不斷更新。筆者使用的是于2002年5月發(fā)布的Greg Ungerer(gerg@snapgear.com)版本。該版本的uClinux包含了對Motorola公司M5272C3和其他幾款MCF5272評估板的支持。但與筆者的目標平臺相比,硬件資源并不完全相同,且為RAM版本,并不能直接固化到ROM中。于是決定直接在M5272C3的基礎(chǔ)上進行修改,以減少工作量。

需要添加三個文件:crt0_rom.S、sysinit.c和rom.ld。crt0_rom.S可以由crt0_ram.S修改得到,它提供一個ROM矢量表以供CPU上電時讀取,并初始化CPU寄存器,設(shè)置程序堆棧,并最終跳轉(zhuǎn)到uClinux內(nèi)核。MEM_SIZE也必須修改為實際容量。

……

#define MEM_SIZE 0x01000000 //實際的SDRAM為16M

……

_vectors: //矢量表起始地址

.long 0x0, _start, _fault, _fault,… //初始化1K字節(jié)矢量表

……

_start: nop

move.w #0x2700, %sr //關(guān)中斷

move.l #_vectors, %d0

move.c %d0, %VBR //VBR指向FLASH

move.l #0x10000001, %d0

move.c %d0, %MBAR //SIM單元基地址

0x10000000

move.l #0x20000001, %a0

//SRAM起始地址0x20000000

move.c %a0, %RAMBAR0

//初始化SRAM作為堆棧

move.l #0x20001001, %a7 //設(shè)置堆棧指針

……

下面對MCF5272的UART、GPIO以及SIM單元進行初始化。Motorola網(wǎng)站提供了這樣的例程(sysinit.c)。需要針對實際情況做必要的修改,主要就實際占用的片選資源CS0~CS7、SDRAM控制寄存器SDCR、SDTR作一些修改以適應目標板。以下的程序片段描述了對SDRAM的初始化。

……

/*初始化CS7 16MB SDRAM */

MCF5272_WR_CS_CSBR7(imm, 0

|MCF5272_CS_BR_BASE(SDRAM_ADDRESS)

|MCF5272_CS_BR_SDRAM

|MCF5272_CS_BR_PS_LINE

|MCF5272_CS_BR_EN);

MCF5272_WR_CS_CSOR7(imm, 0

|MCF5272_CS_OR_MASK_16M

|MCF5272_CS_OR_WS(0x1F));

……

/*初始化SDRAM控制寄存器SDCTR、SDCCR*/

MCF5272_WR_SDRAMC_SDCTR(imm, 0xF539);

MCF5272_WR_SDRAMC_SDCCR(imm, 0x4311);

由于代碼在SDRAM中運行的速度比在FLASH中更快,而且在該目標平臺中,SDRAM是32位數(shù)據(jù)總線,而FLASH是16位總線,因此代碼在ROM中運行和在RAM中運行的速度有著顯著差異??紤]到這些因素,采取將uClinux內(nèi)核和ROMFS文件系統(tǒng)復制到SDRAM中運行的模式。這雖然會犧牲一些系統(tǒng)的啟動速度,并導致一些額外的系統(tǒng)內(nèi)存開銷,但是換來的是系統(tǒng)整體性能的提高,因此是值得的。

uClinux會從內(nèi)存中的某個位置加載ROMFS作為根文件系統(tǒng)。當ROMFS為RAM駐留時,缺省位置緊接著BSS段(參考drivers/block/blkmem,c)。ROMFS文件系統(tǒng)的二進制映像romfs.img在ROM中的實際存放地址可以根據(jù)rom.ld文件計算。由于BSS數(shù)據(jù)段存放的是未初始化的數(shù)據(jù),直到運行時才建立,因此使用m68k-elf-objcopy生成的內(nèi)核二進制映像文件linux.bin中并無BSS段。Romfs.img的起始地址應該是: ROM代碼段結(jié)束地址+RAM代碼段長度+DATA數(shù)據(jù)段長度;而復制的目標地址就是BSS段的結(jié)束地址,這是一個VMA地址,可以從rom.ld文件中直接獲得。

3.3 修改啟動腳本

在uClinux完成內(nèi)核初始化后,由init(void *)內(nèi)核線程調(diào)用/bin/init,然后執(zhí)行/etc/rc腳本中的命令??梢岳眠@個腳本完成系統(tǒng)上電后的自動配置,或者運行用戶程序。ROMFS文件系統(tǒng)中/etc/rc的源文件是/vendors/Generic/big/etc/rc。

一個典型的rc文件如下所示。它完成以太網(wǎng)的設(shè)置并執(zhí)行用戶程序/bin/usrapp。

#設(shè)置主機名

hostname uClinux

/bin/expand /etc/ramfs.img /dev/ram0

mount -t proc proc /proc

mount -t ext2 /dev/ram0 /var

ifconfig lo 127.0.0.1

route add -net 127.0.0.0 netmask 255.0.0.0 lo

#配置網(wǎng)卡IP和路由

ifconfig eth0 202.119.45.98

ifconfig eth0 broadcast 202.119.45.255

route add -net 202.119.45.0 eth0

route add default gw 202.119.45.1

#執(zhí)行用戶程序

/bin/usrapp

3.4 內(nèi)核的配置和編譯

需要建立一個交叉編譯環(huán)境來完成內(nèi)核和應用程序的編譯,生成ROMFS文件系統(tǒng),并最終形成一個固化文件。www.uclinux.org也提供這樣一個工具包。正確安裝后,就可以進行編譯了。首先進入源代碼目錄uClinux-dist,執(zhí)行make xconfig,在彈出的對話框中選擇"Target Platform Selection",出現(xiàn)圖1所示的對話框。

由于直接對M5272C3評估板的代碼進行修改,因此目標板選擇M5272C3。內(nèi)核版本號選擇2.4,采用uC-libc庫。另外選中"Customize Kernel Settings"以定制需要的內(nèi)核。在內(nèi)核配置對話框中,將RAM大小配置為16MB,確認ROMFS為RAM駐留。為了可以直接mount宿主機硬盤以方便調(diào)試,還需給內(nèi)核添加對NFS文件系統(tǒng)的支持。

配置完畢后,在源代碼目錄執(zhí)行"make dep"以及"make",就得到了需要的二進制內(nèi)核映像image.bin,可以直接下載到目標板運行。

參考文獻

1 MCF5272 ColdFire Integrated Microprocessor User's Manual, Rev. 1,02/2001

2 Daniel P.Bovet, Marco Cesati. Understanding the Linux Kernel, 1st Edition, October 2000

3 M5272C3 Evaluation Board Schemetic. Rev. 1.2, 2000

本站聲明: 本文章由作者或相關(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)閉