使用NVRAM的簡單解決方案
來源:宇芯有限公司 日期:2020-09-11 10:19:21
許多供應商提供專為NVRAM使用的現(xiàn)成文件系統(tǒng)軟件。除非要求某些專門功能,否則開發(fā)人員自行設計在經(jīng)濟上會所產生的問題。數(shù)據(jù)結構的存儲主要是針對特定應用程序的,因此將進一步解決。本文芯片存儲器供應商宇芯電子介紹關于使用NVRAM的簡單解決方案。
非易失性使用普通的易失RAM很簡單。上電時必須將其初始化為一個已知值,然后可以根據(jù)需要對其進行寫入和讀取。借助
NV-SRAM,面臨兩個新挑戰(zhàn):
•開機時,軟件需要識別NVRAM是否已初始化,如果尚未初始化,請執(zhí)行該初始化。
•數(shù)據(jù)的完整性,尤其是斷電一段時間后,需要進行驗證。
NVRAM初始化
首次啟動NVRAM時,就像普通RAM一樣,它包含不確定的數(shù)據(jù),需要初始化。在隨后的情況下,軟件需要識別NVRAM已初始化,并且不會覆蓋此保存的數(shù)據(jù)。
進行這種識別的最簡單方法是使用簽名,該簽名只是可以快速識別的字節(jié)序列,不能隨機出現(xiàn)。這種理想是不可能的,因為任何字節(jié)序列(無論多長)都可能隨機發(fā)生。只是最大程度地減少這種可能性,同時仍然使檢查變得快捷容易。如果簽名只有4個字節(jié),則隨機發(fā)生簽名的可能性為40億比1。對于幾乎所有可以想象的應用程序來說已經(jīng)足夠了。并且可以快速檢查32位值。
通過仔細選擇簽名值便可以減少意外發(fā)生的機會。一個連續(xù)的數(shù)字序列(例如1、2、3、4)比“隨機”集合感覺不太可能。畢竟彩票最后一次是什么時候產生連續(xù)的數(shù)字序列的?當然這種序列與其他序列一樣可能或不太可能。但是通過考慮內存的工作方式,特定序列的可能性可能會增加。首次開機時的內存可能具有哪些值?大致有四種可能性:
1、完全隨機
2、全零
3、所有的
4、一些反映芯片架構的規(guī)則模式(例如交替的1和0)
如果為(1),那么任何簽名都會給我們40億比1的機會。其他任何一個都可以通過使用正確的簽名來檢測??赡艿那闆r如下:0x00、0xff,0xaa,0x55??。這應該覆蓋所有(2),(3)和(4),但仍僅為32位。
初始化序列需要謹慎。設置有效數(shù)據(jù),然后將簽名初始化為過程中的最后一件事是至關重要的。
非易失性NV-SRAM完整性
當然,使用簽名并不能保證數(shù)據(jù)的完整性。使用校驗和或CRC進行錯誤檢查,甚至使用數(shù)據(jù)自校正機制都是明智的。
使用NVRAM進行系統(tǒng)啟動
當使用NVRAM時,啟動邏輯需要容納簽名驗證和數(shù)據(jù)完整性檢查:
結論
在嵌入式設計中使用NVRAM很簡單,但是確實需要按此處所述小心地適應其功能。使用全局簽名和錯誤檢查的方法適用于許多應用程序。對于非常大的數(shù)據(jù)庫,單獨檢查每個數(shù)據(jù)塊可能會更有效率。使用C ++對應用程序代碼開發(fā)人員隱藏NVRAM管理,從而最大程度地減少程序員錯誤的可能性,也可能是值得的。
關鍵詞:NVSRAM
宇芯有限公司自成立以來,我們專注于代理國內外各大知名品牌的半導體元器件,代理品牌有NETSOL、JSC、everspin代理、來楊Lyontek、ISSI、CYPRESS等多個品牌總代理資質,主要產品線為sram、mram、psram等其他存儲器芯片,致力于為客戶提供具有競爭優(yōu)勢的產品,是一家專業(yè)提供存儲方案解決商。