技術分享 | 從eMMC到NAND,嵌入式系統存儲的軟件優化策略

原創 2025-02-22 15:16:00 存儲的軟件優化

嵌入式系統開發領域,存儲器作為信息交互的核心載體,其技術特性直接影響着系統性能與穩定性。然而,有些人在面對Linux、安卓等複雜操作系統環境時,理解其存儲機制尚存局限,為突破這些技術瓶頸,飛淩嵌入式希望通過對存儲相關知識的分享,助力大家構建完整的存儲知識體系框架。

首先,嵌入式場景中常用來存儲數據的介質分為兩類:

·Managed NAND,以eMMC(embedded Multi-Media Card)TF卡、SD卡為主内部帶有存儲管理控制器。 

·Raw NAND,以NAND為主的未帶有存儲管理功能,隻包含簡單IO邏輯控制。

上圖描述了NAND存儲和eMMC存儲的關系,NAND Controller代指核心闆的CPU,NAND指實際參與存儲的區域,由此看出實際上eMMC和NAND的區别在于存儲管理控制是在eMMC内部還是核心闆的 CPU。存儲管理主要包括功能:壞塊管理、ECC校驗、磨損均衡、數據保持和地址管理及映射等。

一、存儲的相關概念

存儲類型分為SLC、MLC、TLC、QLC。嵌入式常用類型低存儲容量一般為SLC和MLC,高存儲容量一般是TLC。

SLC (Single-Level Cell) 速度快,壽命長,價格貴,理論擦寫次數在10萬次左右。

MLC (Multi-Level Cell) 速度較快,壽命較長、價格較貴,理論擦寫次數在3000-5000次。 

TLC (Trinary-Level Cell) 速度較慢,壽命較短、價格最便宜,理論擦寫次數在1000-3000次。 

QLC (Quad-Level Cell) 容量可以做的更大,成本上更低,劣勢就是P/E壽命更短。 

pSLC (pseudo SLC) 以 MLC的FLASH為基礎,但在每個Cell中隻存1 bit而不是2 bit數據。由于在同一個Cell中跟SLC一樣隻存儲一個bit,但又不是真的 SLC,所以稱之pSLC。依上述原理,若将MLC用做pSLC,存儲空間将減半,壽命通常可以提升到3萬次左右。

P/E (Program/Erase Count) :擦寫壽命。耐用性兩個指标之一。

TBW (Total Bytes Written) :總寫入量。是廠商用以界定質保期的數值,即超過了這個數值的寫入量之後,廠商就不再給予質保服務。耐用性兩個指标之一。 

FW (Firmware) :由于eMMC内部控制器屬于軟件編程控制器,會需要固件,eMMC在存儲廠家出廠前已經燒錄對應固件。 

WA (Write amplification) :寫放大。表示實際寫入的物理數據量是寫入數據量的多少倍,即:閃存寫入的數據量÷主控寫入的數據量 = 寫放大。 

GC(Garbage Collection) :垃圾回收。NAND介質的存儲寫入是按照頁(Page)寫入,是按照塊(Block)擦除。

二、eMMC和NAND的差異

(1)eMMC與NAND對比

(2) eMMC的相關特點

·eMMC使用單獨的硬件控制器對存儲進行管理,相比于Linux下NAND驅動管理可靠性更高。

·内部固件集成多種功能:使用壽命等健康信息記錄、根據不同的場景動态調整内部存儲策略。 

·接口标準,各廠家各容量兼容性好。 

·eMMC的存儲壽命普遍不如NAND壽命長。相比于NAND大部分使用SLC或者MLC,eMMC大部分是MLC或者TLC,eMMC相對于NAND單位壽命會低;但是由于eMMC的存儲容量一般較大,一定程度上抵消單位壽命低的劣勢。

(3)NAND的相關特點

·系統的驅動主要是由SoC廠家及系統上遊邏輯決定,針對不同的NAND存儲介質無法發揮出最大優勢,或者存在驅動邏輯兼容性問題。 

·NAND容易出現位翻轉、壞塊等情況,相比eMMC内部管理,CPU管理需要占用較大系統開銷用來維護存儲内容。 

·接口标準采用ONFI接口協議,但是不同廠家的NAND的頁、OOB區及塊大小等配置存在差異,如果物料停産需要換型會存在鏡像不兼容風險。

·NAND的布局控制是由CPU管理,對應的分區管理和邏輯定制會有很大的靈活性,根據實際應用場景制定不同的管理策略。 

·NAND單位存儲壽命較長。 

綜上,産品存儲選型建議使用帶有管理功能的eMMC。

三、存儲使用建議

·eMMC:建議預留25%空間,避免頻繁觸發GC。 

·由于存儲的最小寫入單元是Page,最小的擦除單元是Block。以16K page舉例,如果單次寫入小于 一個Page的數據,會造成寫放大。如果單次寫入數據遠遠小于Page的大小,寫放大會很嚴重。最終會導緻壽命大大縮短。建議對小數據先通過DDR内存進行緩沖,緩沖一定數據再組合寫入。 

·使用中如果出現異常斷電,定期需要對文件系統使用工具掃描修複,避免由于異常斷電數據未及時 保存導緻文件系統異常。如果是頻繁異常掉電場景,可以增加硬件加掉電保護措施,用來保證系統穩定性。

·産品設計初期,需要結合實際應用場景存儲數據的頻率,為保證産品壽命要求,評估選擇合适的存儲類型和容量。

四、飛淩嵌入式賦能

(1)針對eMMC,根據對壽命及健康信息讀取分析,讓應用掌握更全面的存儲信息,并作出合理的調整。

應用可以實時監控當前的存儲壽命,用來在設備存儲壽命降低到自定義阈值時發送報警信号做 特定處理。 

應用可以實時查看系統的健康信息,評估存儲的寫放大系數,用來評估應用軟件升級對存儲帶 來的影響,進而估算剩餘壽命。 

(2)針對NAND,根據增加手段統計實際NAND的擦寫、搬移、标記等信息,給出應用IO操作改善建議。

(3)針對所有類型存儲,根據對終端設備不同使用場景特點采集分析,評估出更适合場景的應用編寫參考。

·終端實際應用場景主要集中在:日志循環存儲、應用關鍵數據參數存儲及緩沖數據。

·日志循環存儲特點:循環擦寫,寫入頻繁,讀取不頻繁。和文件系統同時存在,會出現寫頻繁 和隻讀混放數據,會影響整體的穩定性。舉例:大部分eMMC的損耗平衡特性是全盤範圍,軟件上的文件系統分區未實現想要的數據隔離效果,這個其實可以在初期評估階段解決。

·關鍵數據特點:小數據量狀态信息,比較重要,信息量不大。 

·緩沖數據特點:順序寫入,整體擦除。

實際軟件開發過程中,根據如上數據特點,為保證産品穩定性在如下3個階段給出優化方案

·産品開發前做對應存儲方案選型,能夠提前評估出風險。通過實際應用場景産品的目标壽命, 評估出存儲類型、文件系統類型、應用數據讀寫建議及燒錄方式等。

·産品開發完成前做實際存儲的優化。産品的樣機測試階段需要對系統實際讀寫頻次、大小做接 口數據統計分析,對存儲做數據穩定性分析(例:NAND存儲變位及壞塊分析)。通過分析給 出讀寫數據單元大小優化建議、連續/随機讀寫優化建議。 

·産品部署前做最終的預估壽命評估。結合最終優化效果給出實際應用中的一個壽命預估。

除上述優化策略外,不同eMMC、NAND廠家在滿足接口協議标準前提下提供了不同的優化特性,部分優化特性需要結合操作系統修改才能發揮出更好的效果。

五、總結

存儲穩定性直接關乎到最終産品的穩定性,本文圍繞eMMC和NAND的特性做了對比介紹,目的是幫助研發工程師在實際開發産品過程中更簡單、更高效。


相關産品 >

  • FET3588-C核心闆

    RK3588芯片系列是Rockchip推出的旗艦級工業級産品,采用先進的8nm制程工藝,集成4核Cortex-A76+4核Cortex-A55架構,A76主頻高達2.4GHz,A55核主頻高達1.8GHz,能夠提供強大的性能支撐。飛淩FET3588-C核心闆經過了嚴苛的環境溫度測試和壓力測試,确保在高端應用中能夠穩定運行。您可以通過飛淩提供的rk3588開發套件充分評估和驗證其性能。

    了解詳情
    FET3588-C核心闆
  • FET-MX9352-C核心闆

    FET-MX9352-C核心闆基于NXP i.MX9352處理器開發設計, i.MX9352集成2個Cortex-A55核和1個Cortex-M33實時核,主頻達1.5GHz, 原生支持8路UART、2路Ethernet(含1路TSN)、2路USB 2.0、2路CAN-FD總線等常用接口。飛淩iMX93x系列在經市場驗證的 i.MX 6和i.MX 8基礎上進行了升級,集成NPU 可加速邊緣機器學習應用,i.MX9352核心闆體積小巧,便于嵌入到您的産品中。

    了解詳情
    FET-MX9352-C核心闆
  • FET527N-C核心闆

    全志8核 Cortex-A55 64位處理器T527,為您的AI應用賦能。FET527N-C核心闆基于全志T527系列高性能處理器開發設計,集成了8個ARM Cortex-A55高性能核,同時内置1個RISC-V核和1個DSP核。 具有2TOPS算力的NPU,為您的AI應用賦能。核心闆采用闆對闆連接方式,可插拔式設計便于産品的安裝與維護。 産品通過飛淩嵌入式實驗室嚴苛的工業環境測試,為您的産品穩定性保駕護航。同時,FET527N-C核心闆具有10~15年生命周期,為您的産品提供持續供應保障

    了解詳情
    FET527N-C核心闆
  • FET3576-C核心闆

    飛淩嵌入式RK3576核心闆集成了強大的處理器和豐富的接口,提供出色的計算能力和擴展性。RK3576核心闆以其卓越的性能、低功耗和穩定性,成為工業、AIoT、邊緣計算、智能移動終端等領域的理想選擇。無論是數據處理還是邊緣計算,RK3576都能為項目提供強大的硬件支持。核心闆推薦選擇飛淩嵌入式瑞芯微系列RK3576J業級核心闆、RK3576高性能核心闆 了解詳情
    FET3576-C核心闆

推薦閱讀 換一批 換一批