嵌入式系統(tǒng)Flash存儲管理策略研究
3) Block_Erase_Counter( 32bit ) : 該字段用來動態(tài)記錄每個(gè)分塊的擦除次數(shù), 從而方便應(yīng)用程序?qū)?a class="contentlabel" href="http://www.ex-cimer.com/news/listbylabel/label/Flash">Flash 分塊的使用次數(shù)進(jìn)行均衡。
4) Next_Off set ( 16bit ) : 該字段為將來擴(kuò)展之用, 用來將64K 的分塊空間進(jìn)一步細(xì)化, 使得將來1 個(gè)64K 空間內(nèi)可以存儲不同類型的數(shù)據(jù)。
4 NOR Flash 分塊狀態(tài)切換與使用均衡
在Flash 的使用過程中, 必然存在著多次的數(shù)據(jù)更新, 當(dāng)前嵌入式系統(tǒng)中數(shù)據(jù)更新的一般做法是先將新數(shù)據(jù)寫入Flash, 然后將舊的數(shù)據(jù)置為無效狀態(tài)[ 6] 。如果每次數(shù)據(jù)更新都馬上將原先數(shù)據(jù)擦除,則將造成Flash 的擦除次數(shù)急劇增加。隨著數(shù)據(jù)更新次數(shù)的增多, 也就導(dǎo)致Flash 存儲系統(tǒng)中的可用資源不斷減少, 因此在某個(gè)時(shí)刻就必須對系統(tǒng)中的垃圾資源進(jìn)行回收。通過巧妙設(shè)置Flash 分塊的狀態(tài),并在資源回收過程中對源、目標(biāo)兩個(gè)分塊進(jìn)行適當(dāng)?shù)臓顟B(tài)切換, 可以確保在資源回收過程中不會因掉電原因而產(chǎn)生數(shù)據(jù)的丟失。令回收源分塊為A, 新目標(biāo)分塊為B, 資源回收流程如圖2 所示。
圖2 資源回收流程圖
對于每次系統(tǒng)上電后, 應(yīng)用程序?qū)⒆x取每個(gè)Flash 數(shù)據(jù)分塊的頭部信息, 在內(nèi)存中建立相應(yīng)的分塊信息表, 同時(shí)根據(jù)頭部信息和空閑地址搜索算法去初始化每種數(shù)據(jù)類型的起始地址與空閑區(qū)域首地址, 同時(shí)必須對異常狀態(tài)進(jìn)行檢測恢復(fù)。其中對每個(gè)分塊的初始化主要是根據(jù)分塊頭部的狀態(tài)信息進(jìn)行判斷, 檢測是否之前有掉電過, 然后做出相應(yīng)處理, 主要有以下幾種可能:
1) 狀態(tài)為BF _NOT _INIT, 則將其初始化為BF_FREE 狀態(tài)。
2) 狀態(tài)為BF_FREE 或BF_INUSE, 則在內(nèi)存中建立分塊信息, 無需其它操作。
3) 狀態(tài)為BF _ COPYIN G _ DAT A 或BF _ERASING, 則將其擦除后置為BF_FREE 狀態(tài)。
4) 分塊A 狀態(tài)為BF_SRC_DATA, 如果有另一個(gè)分塊B 為BF_COPY _FINISHED, 則根據(jù)流程圖繼續(xù)完成資源回收操作。如果有另一個(gè)分塊B 為BF_COPYING_DAT A, 則擦除B 后置為BF_FREE 狀態(tài), 然后對A 重新進(jìn)行資源回收操作。
5) 狀態(tài)為BF_INVA LID, 則該塊為壞塊, 不在內(nèi)存中建立分塊信息。為了均衡每一個(gè)分塊的使用次數(shù), 延長整塊Flash 的使用壽命, 在每次進(jìn)行分塊擦除之后, 必須先將之前記錄下來的Block_Erase_Counter 加1, 然后組成新的頭部信息重新寫回分塊頭部, 從而達(dá)到動態(tài)記錄每個(gè)分塊擦除次數(shù)的功能。在進(jìn)行空閑分塊申請的時(shí)候, 必須遍歷所有狀態(tài)為BF_FREE 分塊, 選取Block_Erase_Counter 數(shù)值最小的作為新分塊分配, 從而使得每個(gè)分塊的使用次數(shù)趨于一致。
評論