資料介紹
在嵌入式設(shè)計中,許多應(yīng)用設(shè)計都需要使用EEPROM 存儲非易失性數(shù)據(jù),由于成本原因,某些單片機在芯片內(nèi)部并沒有集成EEPROM。MSP430G 系列處理器是TI 推出的低成本16 位處理器,在MSP430G 系列單片機中并不具備EEPROM。為了存儲非易失性數(shù)據(jù),MSP430G 系列處理器在芯片內(nèi)部劃分出了256 字節(jié)的Flash 空間作為信息Flash,可用于存儲非易失性數(shù)據(jù),但是由于Flash 與EEPROM 在擦寫壽命上存在一定差距,所以在實際應(yīng)用中,這種應(yīng)用方式并不能夠滿足所有客戶的需求。本應(yīng)用筆記介紹了使用代碼區(qū)域Flash 來模擬EEPROM,通過一定的軟件處理算法,可以大大增加數(shù)據(jù)存儲周期的一種方法。本文給出了實現(xiàn)上述功能的軟件流程。1. 嵌入式Flash 存儲介質(zhì)與EEPROM 的主要特性對比電可擦除和編程只讀存儲器(EEPROM)是在絕大多數(shù)嵌入式應(yīng)用中都會使用到的用于保存非易失性數(shù)據(jù)的關(guān)鍵器件,用于在程序運行期間保存數(shù)據(jù)。Flash 閃存(Flash Memory,簡稱為"Flash")是一種非易失性( Non-Volatile )存儲器,廣泛應(yīng)用于各種嵌入式處理器中,用于存儲程序代碼。由于硬件成本原因,在許多嵌入式處理器中并沒有集成EEPROM 模塊,通常我們可以采用在片內(nèi)Flash 存儲器中保存非易失性數(shù)據(jù)的應(yīng)用方式來達到使用要求。對一些普通的應(yīng)用場合,這種使用方式可以滿足要求。表一 EEPROM與Flash 對比分析1.1 寫訪問時間由于EEPROM 和Flash 的工作特性不同,所以寫訪問時間也不相同。Flash 具有更短的寫訪問時間,所以更適用于對存儲速度有要求的場合。1.2 寫方法外置EEPROM和采用Flash 模擬EEPROM的最大不同之處在于寫的方法。EEPROM:對EEPROM 的寫操作不需要額外的操作,只需要提供電源供給;但是一旦啟動寫操作流程后,寫操作不能夠被打斷。所以需要外接電容器等措施來保證在芯片掉電時能夠維持供電,保證完成數(shù)據(jù)操作。Flash 模擬EEPROM:當(dāng)芯片上電后,寫操作可以被電源掉電和芯片復(fù)位打斷。和EEPROM 相比,需要應(yīng)用設(shè)計者增加相關(guān)的處理來應(yīng)對可能存在的異常。1.3 擦寫時間EEPROM和采用Flash 模擬EEPROM在擦除時間上存在很大的差異。與Flash 不同,EEPROM 在進行寫操作之前不要擦除操作。由于Flash 需要幾個毫秒時間進行擦除操作,所以如果在進行擦除操作的過程中出現(xiàn)電源掉電的情況,需要軟件做相關(guān)的保護處理。為了設(shè)計一個健壯的Flash 存儲器的管理軟件,需要深入的了解和掌握Flash 存儲器的擦除過程特性。2. 增加Flash 模擬EEPROM 擦寫壽命的方法可以根據(jù)用戶的需求采用不同的方法實現(xiàn)Flash 存儲器模擬EEPROM。2.1 虛擬地址加數(shù)據(jù)方案通常需要兩個頁以上的Flash 空間來模擬EEPROM。上電后,初始化代碼先查找出有效頁,同時將另外一個頁初始化為擦除狀況,以提供字節(jié)寫的能力,并用作備份和隨時準(zhǔn)備執(zhí)行寫入操作。需要存儲EEPROM 的變量數(shù)據(jù)首先寫入有效頁,當(dāng)有效頁寫滿后,需將所有數(shù)據(jù)的最后狀態(tài)保存到備份頁,并切換到備份頁進行操作。每一頁的第一個字節(jié)通常用來指示該頁的狀態(tài)。每個頁存在3 種可能狀態(tài):擦除態(tài):該頁是空的。已寫滿數(shù)據(jù)狀態(tài):該頁已經(jīng)寫滿數(shù)據(jù),準(zhǔn)備切換到下一個頁進行操作。有效頁狀態(tài):該頁包含著有效數(shù)據(jù)并且標(biāo)示狀態(tài)尚未改變,所有的有效數(shù)據(jù)全部拷貝到了已經(jīng)擦除的頁。下圖以采用兩個頁模擬EEPROM的方式為例,描述了頁狀態(tài)字的在頁0 和頁1 之間的切換過程。采用這種方式,用戶不知道數(shù)據(jù)刷新的頻率。下面的圖例以采用兩個頁模擬EEPROM 的應(yīng)用方式為例進行描述。為了方便獲取模擬EEPROM數(shù)據(jù)和更新數(shù)據(jù)內(nèi)容,每個存儲變量元素都在Flash 里定義了一個操作單元,在該操作單元中對每個存儲變量元素都分配一個虛擬操作地址,即一個EEPROM 操作單元包含一個虛擬地址單元和一個數(shù)據(jù)單元。當(dāng)需要修改數(shù)據(jù)單元內(nèi)容時,新的數(shù)據(jù)內(nèi)容和之前分配的虛擬地址一同寫入一個新的模擬EEPROM存儲器單元中,同時返回最新修改的數(shù)據(jù)內(nèi)容。EEPROM存儲單元格式描述如圖二。使用虛擬地址加數(shù)據(jù)的方案總結(jié)如下。? 為每一個目標(biāo)存儲變量分配一個虛擬地址,該虛擬地址需一同存入Flash 中。當(dāng)讀取存儲變量內(nèi)容時,需根據(jù)該變量的虛擬地址搜索虛擬EEPROM并返回最后更新的內(nèi)容。? 在軟件處理上,需要記錄下一次寫入的物理目的地址;在每一次執(zhí)行寫入操作后,根據(jù)EEPROM存儲單元大小(操作粒度),將目的操作指針自動累加。? 當(dāng)一個頁(Page)寫滿后,需要將所有變量的EEPROM數(shù)據(jù)拷貝到下一個頁,再執(zhí)行該頁的擦除操作。? 在嵌入式軟件處理上需加入合適的校驗機制,保證寫入數(shù)據(jù)的正確性并監(jiān)Flash 是否已經(jīng)失效。2.2 劃分子頁方案在Flash 中劃分出至少2 個頁(Page)用作模擬EEPROM,根據(jù)應(yīng)用需求將需寫入EEPROM 進行保存的變量數(shù)據(jù)劃分成一個定長的數(shù)組(子頁),例如16 個字節(jié)或者32 字節(jié),將頁劃分成若干子頁后,需對Flash 中的所有子頁按照地址順序進行逐次編號。每個子頁的第一個字節(jié)通常用來指示該子頁的狀態(tài),子頁狀態(tài)可以為:空、已寫入或者失效。在芯片上電初始化時,首先查找出第一個尚未寫入數(shù)據(jù)的子頁,并進行標(biāo)識,在進行寫EEPROM操作時,應(yīng)用程序需將待寫入EEPROM 子頁的所有數(shù)據(jù)按照事先約定好的順序整理好,再一次性將所有變量數(shù)據(jù)寫入空的子頁中,最后將模擬EEPROM 的操作指針指向下一個空閑的子頁,等待下一次寫入。待將一個頁的數(shù)據(jù)寫滿后,再進行一次擦除操作。需要處理好指向子頁的指針的跳轉(zhuǎn)。每個頁存在3 種可能狀態(tài):擦除態(tài):該頁是空的。已寫滿數(shù)據(jù)狀態(tài):該頁已經(jīng)寫滿數(shù)據(jù)。有效頁狀態(tài):該頁包含著有效數(shù)據(jù)并且該頁尚未寫滿,仍可向子頁寫入數(shù)據(jù)。圖三介紹了使用子頁的方式實現(xiàn)Flash 模擬EEPROM的數(shù)據(jù)處理方法。2.2.1 軟件描述在軟件實現(xiàn)上,為了便于軟件處理,建議定義一些關(guān)鍵宏定義和結(jié)構(gòu)體,指定Flash 模擬EEPROM 的起始、結(jié)束地址、頁的大小、子頁的大小、每個頁的子頁數(shù)目等參數(shù),同時將需要操作的參數(shù)封裝起來,便于軟件操作和管理,不建議定義許多離散的標(biāo)志變量。在軟件操作上,F(xiàn)lash 模擬EEPROM模塊需要提供幾個API 接口給應(yīng)用程序調(diào)用。? 通過typedef 關(guān)鍵字定義設(shè)備類型,typedef unsigned char u8;? ChkFstPowerOnInfo()用于檢測芯片是否為第一次上電并初始化EEPROM 參數(shù)到內(nèi)存,原型如下。Void ChkFstPowerOnInfo(void);? FlashWrite()用于寫Flash,傳遞的形參包括指向待寫入數(shù)據(jù)的指針,待寫入數(shù)據(jù)在子頁中的起始字節(jié)編號,寫入數(shù)據(jù)的長度,原型如下。void FlashWrite( u8 *array, u8 startNum, u8 length );? FlashErase()用于擦除Flash,傳遞的形參是子頁的編號,在擦除函數(shù)中需要根據(jù)子頁的編號判斷是否需要執(zhí)行頁的擦除操作,原型如下。void FlashErase(u8 seg_sn);2.2.2 軟件流程圖軟件啟動后,初始化模擬EEPROM流程圖描述如下。調(diào)用API,向模擬EEPROM 寫入數(shù)據(jù)的軟件流程如圖五所示。在軟件處理中,要特別注意目標(biāo)指針的切換和保證寫入數(shù)據(jù)的正確性,在代碼空間允許的情況下,可以增加一些校驗算法來保證。采用劃分子頁的方案總結(jié)如下。? 每次寫入模擬EEPROM的數(shù)據(jù)長度為定長,即為子頁的長度。? 軟件需要定義一個存儲變量結(jié)構(gòu)體,用于刷新和同步模擬EEPROM內(nèi)容。在將數(shù)據(jù)寫入模擬EEPROM之前,程序員需要按照約定的數(shù)據(jù)格式,在內(nèi)存中將所有的目標(biāo)存儲變量進行整理。? 在軟件處理上,需要計算當(dāng)前寫入和下一次寫入的物理地址;在每一次執(zhí)行寫入操作后,根據(jù)子頁長度大小,將指向子頁的目的操作指針自動累加。? 待一個頁(Page)寫滿后,需要將最后更新的模擬EEPROM數(shù)據(jù)拷貝到下一個頁,再對寫滿頁執(zhí)行一次擦除操作。? 在嵌入式軟件處理上需加入合適的校驗機制,保證寫入數(shù)據(jù)的正確性并監(jiān)測用于模擬EEPROM功能的Flash 子頁是否已經(jīng)失效。2.3 兩種方案的對比分析兩種方案的對比分析見表二。表二 兩種方案的對比分析3. 實際的嵌入式應(yīng)用根據(jù)軟件需要,建議采用字節(jié)(8bit)做為操作的最小粒度,適用性會更廣泛。3.1 Flash 存儲器擦寫壽命的提升對于MSP430G 系列的Flash 存儲器,可以保證至少10000 次的編程和擦除壽命。如圖六所示。圖六 MSP430G 系列單片機Flash 編程和擦除壽命采用劃分小頁結(jié)合至少分配2 個大頁的操作方式,則可以大大增加Flash 模擬EEPROM 的擦寫壽命。例如,對于MSP430G 系列單片機,如果將每個小頁的尺寸劃分為16 字節(jié),采用2 個大頁(每頁512 字節(jié))作為模擬EEPROM 使用,則可以提供64 個操作子頁((512/16)x2=64),可以保證至少640000 次的擦寫壽命。3.2 掉電時的異常處理如果正在進行Flash 數(shù)據(jù)存儲時發(fā)生掉電,數(shù)據(jù)可能會保存不成功,存在異常。為了增強健壯性,在軟件處理上,需要考慮設(shè)備異常掉電等可能會導(dǎo)致Flash 擦寫失敗的情況。在軟件處理中,當(dāng)成功保存Flash 數(shù)據(jù)后,再寫入該子頁的狀態(tài)標(biāo)志。單片機上電后,用戶程序?qū)⒉檎易詈笠淮螌懭氲淖禹摚賹⒃撟禹摰臄?shù)據(jù)內(nèi)容并恢復(fù)到內(nèi)存中的數(shù)據(jù)結(jié)構(gòu)中。4. 系統(tǒng)可靠性設(shè)計4.1 時鐘源的選擇由于驅(qū)動Flash 的時鐘源(ACLK、MCLK、SMCLK)和時鐘頻率可以設(shè)定,為了保證在將數(shù)據(jù)寫入模擬EEPROM時的可靠性,建議在將Flash 的時鐘頻率降低后,再對其進行操作。例如將Flash 的時鐘頻率降低到1MHz 后,進行寫入操作。需要注意,在降低了時鐘頻率后,若此時鐘源也是定時器(Timer)的時鐘源,則可能會影響到定時器的定時準(zhǔn)確性,需要軟件上做好處理。4.2 代碼在RAM中運行由于向Flash 寫入數(shù)據(jù)操作是通過執(zhí)行Flash 中程序代碼,對Flash 進行擦除和編程操作。由于對Flash 的編程需要mcu 內(nèi)部執(zhí)行一個升壓操作,所以如果有足夠的內(nèi)存空間,建議將編程、擦除等關(guān)鍵代碼拷貝到RAM中運行,可以使用關(guān)鍵字__ramfunc 指定,如下圖七所示。圖七 使用關(guān)鍵字__ramfunc 將程序指定到Ram 中運行5. 總結(jié)本文從軟件方面,以及安全性方面探討了使用MSP430G 系列單片機在使用Flash 模擬EEPROM方面的應(yīng)用,提供了兩種不同的方式供選擇。兩種方式都可以大幅度提高模擬EEPROM的編寫、擦除壽命,并且滿足高可靠性的應(yīng)用設(shè)計,用戶可以結(jié)合具體的應(yīng)用進行選擇。(mbbeetchina)
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 提高MSP430G系列單片機的Flash擦寫壽命的方法
- MSP430系列單片機(1)——基本知識
- 單片機MSP430系列的CCS基礎(chǔ)知識 45次下載
- MSP430單片機的框架程序資料免費下載 9次下載
- MSP430單片機定時器的學(xué)習(xí)筆記資料免費下載
- MSP430單片機的開發(fā)總結(jié)詳細資料免費下載 20次下載
- MSP430單片機的命名規(guī)則詳細資料免費下載 12次下載
- MSP430系列超低功耗16位單片機原理與應(yīng)用的詳細資料說明 16次下載
- 如何學(xué)習(xí)msp430單片機 24次下載
- 關(guān)于MSP430系列單片機及MSP430F449單片機在醫(yī)療儀器中的應(yīng)用 11次下載
- MSP430單片機硬件設(shè)計及接口技術(shù) 63次下載
- MSP430系列單片機及MSP430F449單片機在醫(yī)療儀器中的應(yīng)用 9次下載
- MSP430單片機實踐篇之MSP430單片機ADC模數(shù)轉(zhuǎn)換操作 43次下載
- MSP430F2系列16位超低功耗單片機模塊原理5 5次下載
- MSP430系列flash型超低功耗16位單片機
- 單片機中EEPROM和FLASH的區(qū)別是什么 3w次閱讀
- MSP430系列單片機與51單片機的區(qū)別及優(yōu)劣勢對比 3.5w次閱讀
- 如何提高MSP430單片機的操作效率 1242次閱讀
- MSP430單片機的LED驅(qū)動電路原理解析 6064次閱讀
- 基于MSP430系列單片機的常用程序編寫總結(jié) 4001次閱讀
- MSP430系列單片機特性及應(yīng)用領(lǐng)域介紹 9142次閱讀
- 基于msp430f149單片機下74hc14n應(yīng)用電路 8363次閱讀
- 略談MSP43單片機端口 1847次閱讀
- MSP430單片機定時器A結(jié)構(gòu)及其應(yīng)用范例 3928次閱讀
- MSP430單片機的選型及系列介紹 1.6w次閱讀
- MSP430低功耗運行模式原理分析及應(yīng)用 8864次閱讀
- MSP430單片機的端口介紹 5296次閱讀
- MSP430G2553的原理圖 1w次閱讀
- MSP430低功耗原理及其在海溫測量中的應(yīng)用 2258次閱讀
- 單片機FLASH與RAM、ROM的關(guān)系 1.3w次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開關(guān)電源基礎(chǔ)知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設(shè)計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統(tǒng)的設(shè)計與實現(xiàn)
- 0.61 MB | 2次下載 | 免費
- 6基于FPGA的C8051F單片機開發(fā)板設(shè)計
- 0.70 MB | 2次下載 | 免費
- 751單片機窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 8基于51單片機的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關(guān)電源設(shè)計實例指南
- 未知 | 21548次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅(qū)動電路設(shè)計》 溫德爾著
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537796次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191185次下載 | 免費
- 7十天學(xué)會AVR單片機與C語言視頻教程 下載
- 158M | 183278次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論
查看更多