1 嵌入式系統(tǒng)的軟件組成
1.1 系統(tǒng)的軟件組成
嵌入式的軟件系統(tǒng)主要由Bootloader、操作系統(tǒng)、文件系統(tǒng)、應用程序等組成。其中,Bootloader是介于硬件和操作系統(tǒng)之間的一層,其作用就好像PC機中的BIOS。系統(tǒng)加電運行后,由系統(tǒng)自動加載。通過這段程序,可以初始化硬件設備,建立內存空間的映射圖,從而將系統(tǒng)的硬件環(huán)境帶到一個合適的狀態(tài),以便為最終調用操作系統(tǒng)內核準備好環(huán)境。對于一個嵌入式系統(tǒng),通常BootLoader是依賴于硬件而實現(xiàn)的。對于不同類型的嵌入式芯片、不同的操作系統(tǒng)和外圍接口都需要重新移植、修改和編譯Bootloader。
1.2 U-Boot分析
嵌入式Linux系統(tǒng)中常用的Bootloader引導程序有U-Boot,redboot,blob和vivi等,其中U-Boot遵循GPL條款的開放源碼項目,功能最為強大;U-Boot對PowerPC系列處理器支持最豐富,同時還支持MIPS,x86,ARM,Nios,XScale等諸多常用系列的處理器;U-Boot引導程序分為Stage 1和Stage 2兩大部分,Stage 1中主要包括設備初始化、中斷設置、時鐘設置和存儲器初始化等工作,并且采用匯編語言實現(xiàn),而一些通用功能大多采用C語言實現(xiàn),放在Stage 2中。
2 U-Boot的啟動分析
Stage 1的代碼在CPU/arm920t/start.s中定義,它包括從系統(tǒng)上電后在0x00000000地址開始執(zhí)行的部分。這部分代碼系統(tǒng)啟動后,從NAND FLASH自動加載到SDRAM中,它包括對S3C2410A中寄存器的初始化和將U-Boot的Stage 2代碼從FLASH拷貝到SDRAM。Stage 2的起始地址是在Stage1代碼中指定的。被復制到SDRAM后,就從*階段跳到這個入口地址,開始執(zhí)行剩余部分代碼。第二階段主要是對內存的分配,對NAND FLASH以及對外圍設備的初始化,其代碼在lib-arm/board.C中。啟動的流程分析如圖1所示。
(1)跳轉到C語言程序之后,首先定義初始化函數(shù)表,程序在lib-arm/board.e中,如下所示:
(2)初始化FLASH設備和顯示FLASH設備信息;
(3)初始化系統(tǒng)內存分配函數(shù);
(4)如果目標系統(tǒng)擁有NAND設備,則初始化NAND設備;
(5)初始化顯示設備;
(6)初始化網絡設備,填寫IP地址、MAC地址等信息;
(7)開啟中斷處理;
(8)進入命令循環(huán),接收用戶從串口的命令輸入。
3 U-Boot的移植方法
本文選用交叉編譯環(huán)境arm-linux-gcc-2.95.3,選用U-Boot-1.1.4版本作為移植平臺。為了使U-Boot支持新的開發(fā)板,一種簡便的做法是在U-Boot已經支持的開發(fā)板中選擇一種與目標板接近的,在其基礎上進行修改。這里選用的是smdk2410的配置。
3.1 修改cpu/arm920t/start.S文件
Start.s是采用匯編語言編寫的U-Boot程序入口代碼,完成對底層硬件的初始化,其中有一個很重要的功能是從NAND FLASH中把Stage 2階段的代碼復制到SDRAM中。在此階段,涉及到對NANDFLASH的讀操作,在U-Boot中,沒有對NANDFLASH讀操作的驅動,采用以下方法實現(xiàn):
通過調用board/smdk2410/nand_read.C中的nand_read_11函數(shù)將Stage 2階段的代碼復制到ram中。
3.2 修改board/smdk2410目錄下文件
(1)增加對NANDFLASH的讀驅動nand_read.c
(2)在smdk2410.C文件中添加對NANDFLASH初始化的程序
在此主要是對主板的GPIO的一些設置,并加上對NANDFLASH初始化程序。
(3)在該目錄下的Makefile文件中添加nand_read.C文件的編譯
OBJS:=smdk24 10.o FLASH.o nand_read.o
3.3 在include文件中設置NAND FLASH硬件參數(shù)
在/linux/mtd/nand_ids.h中設置參數(shù):
3.4 編譯與運行
配置好以后,進入U-Boot主目錄,重新編譯U-Boot代碼,運行命令:
(1)查看交叉編譯器的版本號
arm-linux-gcc-v
(2)清除生成的連接
Make distclean
(3)編譯make smdk2410_config
(4)make CROSS-COMPILE=arm-linux-編譯成功后,將生成三個文件:
u-boot:ELF格式的文件,可以被大多數(shù)Debug程序識別。
u-boot.bin:二進制bin文件,純碎的U-Boot二進制執(zhí)行代碼,不保存ELF格式和調試信息。這個文件用于燒到用戶的開發(fā)板中。
u-boot.srec:Motorola S-Record格式,可以通過串口下載到開發(fā)板中。
&nbs