新聞中心

Redboot修改實(shí)例

作者: 時(shí)間:2012-07-25 來源:網(wǎng)絡(luò) 收藏

在通常情況下,嵌入式開發(fā)中都需要對(duì)bootload部分的代碼進(jìn)行,以適應(yīng)實(shí)際的需求。本文以redboot為例,說明了如何redboot源碼以使其具備

本文引用地址:http://m.butianyuan.cn/article/148720.htm

1. 啟動(dòng)時(shí)提供LOGO圖片顯示

2. 為實(shí)現(xiàn)量產(chǎn),在命令行下提供自動(dòng)配置網(wǎng)絡(luò)的命令autocONfig

3. 為實(shí)現(xiàn)量產(chǎn),在命令行下提供自動(dòng)更新文件的命令update

4. 為實(shí)現(xiàn)量產(chǎn),在命令行下提供自動(dòng)配置腳本的命令autoexec

適用的運(yùn)行環(huán)境為基于ARM架構(gòu)的硬件環(huán)境,包括

運(yùn)行環(huán)境如下表所示。

是Red Hat公司開發(fā)的一個(gè)獨(dú)立運(yùn)行在嵌入式系統(tǒng)上的BootLoad程序,是目前比較流行的一個(gè)功能強(qiáng)大、可移植性好的BootLoad。

是一個(gè)采用eCos開發(fā)環(huán)境開發(fā)的應(yīng)用程序,并采用了eCos的硬件抽象層作為基礎(chǔ),但它完全可以脫離eCos環(huán)境運(yùn)行,并用來引導(dǎo)人和其他的嵌入式操作系統(tǒng),如Linux、WinCE等。

eCos實(shí)現(xiàn)系統(tǒng)可配置機(jī)制的核心就在于它是由許多個(gè)組件構(gòu)成,包括調(diào)度內(nèi)核組件、硬件抽象層、文件系統(tǒng)組件、網(wǎng)絡(luò)協(xié)議棧等,用戶可以根據(jù)不同的需求選擇組件,并對(duì)一些特定的配置選項(xiàng)進(jìn)行設(shè)置,就可以構(gòu)造出滿足特定應(yīng)用需求的系統(tǒng)。

所有的組件都在組件庫中,組件庫其實(shí)是一個(gè)包含了eCos所有系統(tǒng)組件的文件夾,其路徑對(duì)應(yīng)于“/eCos-2.0/packages”,該目錄的內(nèi)容如下所示

☆ compat

包含支持與POSIX和uITRON3.0標(biāo)準(zhǔn)兼容的組件文件包

☆ cygmon

生成Cygmon調(diào)試監(jiān)視器的配置文件包

☆ devs

eCos支持的所有外部設(shè)備驅(qū)動(dòng),如串口、以太網(wǎng)等

☆ error

包含各種常見的錯(cuò)誤和狀態(tài)描述代碼,便于系統(tǒng)調(diào)試時(shí)報(bào)告錯(cuò)誤和狀態(tài)

☆ fs

包含ROM和RAM文件系統(tǒng)包

☆ hal

包含所有硬件抽象層的目標(biāo)硬件配置文件包

☆ infra

包含系統(tǒng)定義的基本結(jié)構(gòu),如數(shù)據(jù)類型、宏定義、系統(tǒng)啟動(dòng)方式選擇

☆ io

I/O子系統(tǒng)文件包,建立在外部設(shè)備驅(qū)動(dòng)上層從而與特定硬件無關(guān)

☆ isoinfra

包含的文件包提供支持ISO標(biāo)準(zhǔn)C庫和兼容POSIX標(biāo)準(zhǔn)的接口

☆ kernel

提供eCos內(nèi)核功能的配置文件包

☆ language

包含ISO的C庫和math庫

☆ net

提供TCP/IP協(xié)議棧支持的文件包

☆ redboot

包含生成Redboot調(diào)試監(jiān)視器的配置文件包

☆ services

包含提供動(dòng)態(tài)內(nèi)存分配和文件壓縮與解壓功能的庫文件

與硬件相關(guān)的文件按照如上所述,分別對(duì)應(yīng)以下的子目錄:

“/eCos-2.0/packages/hal/arm”:Architectur HAL

“/eCos-2.0/packages/hal/arm/arm9”:Variant HAL

“/eCos-2.0/packages/hal/arm/arm9/ep93xx”:Platform. HAL

為了實(shí)現(xiàn)本文開頭的四項(xiàng)特殊功能,需要eCos中的部分代碼。修改的文件為:

“/eCos-2.0/packages/hal/arm/arm9/ep93xx/v2_0/src/ep93xx_misc.c”

“/eCos-2.0/packages/redboot/v2_0/src/Flash.c”

“/eCos-2.0/packages/redboot/v2_0/src/io.c”

“/eCos-2.0/packages/redboot/v2_0/src/main.c”

ep93xx_misc的修改

在本例中,開發(fā)平臺(tái)上添加了一塊FPGA芯片,通過該FPGA實(shí)現(xiàn)了對(duì)LCD的控制,因此對(duì)于raSTer的初始化過程有所不同。

該部分的修改,主要目的是提供“啟動(dòng)時(shí)提供logo圖片顯示”的功能。

增加__FPGA_LCD__宏定義

增加_RASTER_宏定義

_RASTER_ 完成Raster設(shè)置并且顯示開機(jī)界面。

_ FPGA_LCD _ 完成FPGA設(shè)置并且顯示開機(jī)界面。

Raster:

initRaster用來初始化LCD controller

LCD 界面定制在Nor Flash AddrESS 0x60DC0000

Copy Kernel 到指定Address, Copy zImage 到0x800000(SDRAM Address)

FPGA:

1. check chip 分區(qū)是否存在

2. 如果存在則Copy logo and chip 到指定地址。

3. 初始化FGPA。

4. 顯示開機(jī)界面。

5. Copy Kernel 到指定地址。

初始化FPGA流程:

1. Config相關(guān)GPIO

a) GPIO 0-7===D0~D7為輸出

b) GPIO 9,11,12===PROG_B,CSI_B,CCLK為輸出 8,10===DONE,INIT_B為輸入

2. Clear相關(guān)SDRAM

a) set prog_b low to clear the config data

b) start the config process

c) ready to read the init_b status

3. 寫Chip.bin

4. 顯示logo

SDRAM write流程如下圖所示:

1. 根據(jù)CPU_buffer的使用情況,將準(zhǔn)備寫入SDRAM的數(shù)據(jù),先存入CPU_buffer中。

2. 然后需要依次配置ADDR1、ADDR0、CONTROL_REG。

3. cpu_sdram_cmdgen會(huì)根據(jù)以上寄存器的設(shè)置,將cpu_buffer中的數(shù)據(jù)發(fā)送至arbiter,后存入SDRAM.

4. 數(shù)據(jù)請(qǐng)求完成后,cpu_sdram_cmdgen會(huì)將CONTROL_REG.ACT自動(dòng)清除。

5. CPU可以通過查詢CONTROL_REG.ACT位,得知當(dāng)前寫入SDRAM數(shù)據(jù)的操作是否完成。

6. 寫SDRAM步驟如下

a) write (16'h00F0, 16'haaaa);

b) write (16'h00F1, 16'hbbbb);

c) write (16'h00F2, 16'hcccc);

d) write (16'h00F3, 16'hdddd);

e) write (16'h00F4, 16'heeee);

f) write (16'h00F5, 16'hffff);

g) write (16'h00F6, 16'h5555);

h) write (16'h00F7, 16'h6666);

i) write (16'h00F8, 16'h9999);

j) write (16'h00F9, 16'h7777);

k) write (16'h00Fa, 16'h8888);


上一頁 1 2 下一頁

關(guān)鍵詞: 實(shí)例 修改 Redboot

評(píng)論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉