基于MPC8247嵌入式電力交換系統的設計與實現
2.1.2 配置DHCP
主機系統需要設置DHCP服務器,用于目標系統在采用BOOTP啟動時獲取IP地址。設置之前首先要知道目標系統的MAC地址,同時要保證主機系統安裝了DHCPD服務器。修改虛擬機中/etc/dhcpd.conf配置文件,然后用如下命令重新啟動dhcpd服務:
#/etc/init.d/dhcpd restart
同時啟動dhcpd服務,使主機每次啟動時自動啟動該服務。
2.1.3 配置TFTP服務器
TFTP(簡單文件傳輸協議)服務器用于目標系統從主機系統上獲取可執行的代碼或內核映象文件。
以超級用戶登錄主機系統,編輯下面文件:
#vim/etc/xinetd.conf
去掉下面一行的注釋:
#tftp dgram udp wait root/usr/sbin/tcdp in.tftpd
根目錄下創建tftpboot目錄:
#mkdir tftpboot
將每次編譯好的目標代碼拷貝到該目錄下,在系統服務中啟動TFTPD服務(運行#setup,在“System services”中選擇。)然后執行:#service xinetd restart即可。
2.1.4 配置NFS
NFS主要是給目標系統提供一個根文件系統(Root Filesystem)。
首先,編輯配置文件/etc/exporlts:
#vi exports
如果原來不存在,添加一行:
/home/com_target_master*(rw,no_root_squash)
“/home/com_target_master”是根文件系統所在的目錄,“*”允許主機所在網段所有機器訪問。和配置TFTP一樣,在系統服務中啟動NFS服務,重新啟動系統或運行:
#service nfs restart
2.2 目標板FLASH資源分配
對于系統平臺來說,建立良好的FLASH分區是系統成功運行的基本保證。具體FLASH資源分配如表1所示。本文引用地址:http://www.104case.com/article/148132.htm
3 嵌入式系統開發的實現過程
本文的軟件平臺是基于電力交換設備,DPN8000的開發環境為模型。搭建軟件層次模型如下:
3.1 Linux系統引導模塊uboot
U-Boot是德國DENX軟件中心依照GPL(General Public License)發布的系統引導模塊,支持多種處理器,如ARM系列、PowerPC系列、MIP S系列、X86系列等。根據自己的目標系統修改編輯U-Boot包下的源文件,進行移植,最后編譯U-Boot后生成二進制文件,用于引導系統。
在U-Boot代碼中,主要有關的代碼設置在MYM(uboot)\cpu\mpc8260.c的代碼中實現,但是該地址的定義在其平臺說明頭文件中。故增加一個mpc8247平臺——mpc8260ads,在$(u-boot)\include\config目錄下增加一個相應平臺配置頭文件說明-mpc8260ads.h,將與硬件有關的配置放在此文件中。對應SDRAM,FLASH等定義如下:
(1)SDRAM的地址設定
#define CFG_OR1 0xF0002900
#define CFG_PSDMR 0xc4322423
以上定義的為SDRAM的地址設定,由MPC8247片選CS1相關的寄存器設定。
(2)FLASH的地址設定
#define CFG_FLASH_BASE 0xfe000000
#define CFG_BR0_PRELIM
CFG_FLASH_BASE | 0x00001801
#define CFG_OR0_PRELIM
CFG_FLASH_BASE | 0x000008C2
以上定義的為FLASH的地址設定,由MPC8247片選CS0相關的寄存器設定。
(3)FPGA地址設定
#define CFG_FPGA_BASE 0xF4500000
#define CFG_BR3_PRELIM CFG_FPGA_BASE| 0x00001801
#define CFG_OR3_PRELIM 0xFFFF8010
以上定義的為FPGA的地址設定,由MPC8247片選CS0相關的寄存器設定。
修改完成后,通過make得到u-boot.bin文件。
3.2 Linux內核的移植
由于嵌入式系統存儲資源有限,精簡內核就顯得尤為重要。建立系統的新內核,最主要的工作就是配置內核參數配置內核文件,進入內核釋放的目錄下執行命令:#make menuconfig會生成新的.config文件。然后執行#make uImage,生成新的uImage,將生成的內核拷貝到tf tp目錄下即可。
使用tftp將內核鏡像文件下載到目標板上,重新引導后,目標板即可成功啟動。
評論