摘要:
本文主要介紹系統在系列處理器的開發中怎么實現去掉BOOT Flash,直接從Flash引導的。
關鍵詞:BOOT Flash,Flash,
引言
美國公司的實時嵌入式系統和美國公司系列處理器已經廣泛的應用在通信行業的通信產品中,在用系統進行開發時,會生成兩個文件,一個是文件,此文件類似中的BIOS,是引導文件,完成內存初始化,內核初始化,基本硬件的初始化并最終引導系統啟動,另外一個是文件,此文件中包括系統內核及上層應用程序,而這兩個文件在的開發中一般都存儲在兩片不同的Flash上,及存儲在BOOT Flash,而存儲在Flash上。
產品需要
實際開發中,生成的沒有壓縮的大小一般為512K左右,在 5.4中是460K左右,而在 5.5中是540K左右,一般存儲的Flash只需要512K大小,因為即使540K的 也可以截成512K。
在硬件開發Flash選型時,BOOT Flash芯片一般采用SST公司的、等,Flash芯片一般會采用Intel、AMD公司的,根據需要可能會采用容量為4M、8M、16M、32M大小不等。從節省成本的角度考慮,是不是可以將直接裝載到Flash中并引導呢,這樣不是可以省掉一片BOOT Flash嗎?
系統中,加上上層應用程序的生成的文件一般為3M左右,所以不管你采用4M、8M或者更大容量的Flash,同時裝載、文件也是綽綽有余的。
實際情況
我和一個做硬件的朋友曾經做過這樣的測試,直接從Flash引導,并引導系統,實際上是可行的。
要解決此問題,實際上只要將Flash的地址稍做處理就可以的。
我們將Flash地址映射成兩個地址段,一段用做,一段用做使用,用做的地址段為~,另外一段用做的地址段為~(假設此Flash大小為8M大小),在~地址段寫入,在~地址段寫入,加電后,PC指針會跳到地址執行第一條指令,引導起來并最終系統引導成功。
實現過程
1、 片選
在.s文件中要做如下的片選操作,片選0為BOOT Flash的地址片選,片選1為Flash的地址片選,其中為
/* ------------------------------------------------------------------------ */
/* Chip 0 for */
/* ------------------------------------------------------------------------ */
lis r5, HIADJ( | | BR_WP | BR_V)
addi r5, r5, LO( | | BR_WP | BR_V)
stw r5, BR0(0)(r4)
lis r5, HIADJ( | | )
addi r5, r5, LO( | | )
stw r5, OR0(0)(r4)
/* ------------------------------------------------------------------------ */
/* Chip 1 for FLASH */
/* ------------------------------------------------------------------------ */
lis r5, HIADJ( | | )
addi r5, r5, LO( | | )
stw r5, BR1(0)(r4)
lis r5, HIADJ( | | )
addi r5, r5, LO( | | )
stw r5, OR1(0)(r4)
2、 地址映射
在.c文件中有一的地址映射數組的聲明,對BOOT Flash和Flash的地址按照如下的地址映射后,系統才會讓你對此地址進行相應的讀寫操作。
{
(void *) ,
(void *) ,
, /* 8 m - Flash 1 */
| LE,
|
},
{
(void *) ,
(void *) ,
, /* Flash */
| LE |
BLE ,
| |
OT
}
3、 文件燒錄
還存在一個問題,因為BOOT Flash是可以在燒錄器上燒錄的,而Flash芯片是直接焊接在的主板上,只能通過相應的Flash驅動才能進行讀寫的,是不可能通過燒錄器燒錄,要解決此問題那只能按照如下辦法解決。
在主板上要保
留有 Flash座,要有一片從BOOT Flash引導的BOOT Flash芯片mpc860上電初始化流程分析,此芯片中要有已經燒錄好的可以正常運行的程序,先將此芯片加到 Flash座上,加電將系統引導起來,然后用事先寫好的將及寫入Flash的函數將及文件寫入Flash相應的地址段,注意寫入地址要正確mpc860上電初始化流程分析,即的第一條指令必須寫在地址,關電后將BOOT Flash從座中取出來,加電后系統就從Flash中引導起來了。