新聞中心

        EEPW首頁 > 電源與新能源 > 設計應用 > 用于SD卡的NAND flash控制芯片的設計

        用于SD卡的NAND flash控制芯片的設計

        作者: 時間:2010-11-20 來源:網絡 收藏

        本文引用地址:http://www.104case.com/article/180225.htm

          當需要更新數據時,寫入的策略可分為兩種情況。首先,當子塊仍然有空閑頁時,可直接將數據寫到子塊中的下一個空閑頁中,并在spare區中記錄該塊對應的子塊、該物理塊對應的邏輯塊以及該物理頁對應的邏輯頁,這樣,當重新上電時,就可以建立邏輯物理映射關系。其次,當母塊和子塊都寫滿時,需要從空塊池中取出一個新的子塊。如果允許一個邏輯塊對應三個或更多的物理塊,一方面管理起來比較復雜,另外也會造成空物理塊緊缺,因此,可以考慮將母塊或者子塊釋放掉,這樣,母塊或者子塊中原有的有效數據就需要搬移到新子塊中并將該母塊或子塊擦除再釋放到空塊池。出于速度的考慮,選擇母塊和子塊有效頁數較少的塊進行數據轉移并釋放。

          實踐證明,這樣操作對寫文件速度有明顯提高,特別是寫小文件時,其速度提升可達9.2倍。

          2.3 SPARE區和ECC校驗

          Flash中每個頁里的每個字節都是沒有任何差別的,物理上并沒有data區和spare區的區別,具體怎樣劃分data區和spare區,可由用戶自己決定。本采用的劃分辦法如圖4所示,這樣,每個扇區和一個spare區相連,故可方便連續讀出,并進行校驗糾錯。

          

          圖4中同時給出了Spare的區定義,其中兩字節標識本物理塊所對應的母塊;兩字節標識本物理塊對應的邏輯塊;一字節標識本物理頁對應的邏輯頁,一字節用于標識連續邏輯頁數(表示上面連續邏輯頁的個數,此域可以輔助加快建立頁映射表的時間),余下的10字節用于存放ECC,這樣可以達到4字節錯誤的糾錯能力。一般情況下,前面的4個字節是建立塊地址映射表的關鍵,其次,后面兩個字節則是建立頁地址映射表的關鍵。

          2.4 頁映射表建立時間的優化

          因為建立頁映射表需要讀取母塊和子塊中各物理頁spare區以判定該物理頁對應的邏輯頁,而每個物理頁的讀取都要花費大約50μs的時間。因此,如果對每個物理頁都讀取,建立頁映射表就會比較費時。為了加快建立頁映射表的速度,一般只希望能讀取一個物理頁,而免于讀取其他若干頁,以便加快建表速度。因為很多時候都是連續寫,而連續的幾個物理頁在邏輯上也是連續的,因此可以考慮在spare區加入連續邏輯頁號,這樣,重新建表時,就可根據連續頁號知道連續幾個物理頁對應的邏輯頁,從而加快建表的速度。對于最佳情形,有時只需要讀一個頁就可以建立整個邏輯塊的頁映射表。圖5所示是一種加快建表的示意圖。

          

          2.5 分區

          不同的,塊數是不同的,其塊映射表需要的RAM空間也不一樣。對于當前主流,有的具有8192個塊,如果對整個建表,需要的RAM空間將多達32KB,這樣成本就會比較高。一個可行的解決辦法是對flash分區,比如1024個塊為一個分區,每次只對一個分區進行建表,這樣,RAM空間就可以降低到4KB。這樣,隨著將來flash容量的增加,塊數即使再多,也能夠用同樣的方法處理,而不用增大RAM。

          3 結束語

          本文介紹了一種針對MLC flash的優異管理算法及軟件實現方法,并且已在卡上大規模商用。該算法只需簡單配置就能支持市場上的各種flash,而且也兼容各種設備。同時RAM空間需求小,成本低,壽命長,兼容性好,擴展性強,flash空間利用率高,具有很高的商用價值。


        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 洪江市| 高尔夫| 台湾省| 奇台县| 阜康市| 海林市| 宁德市| 广汉市| 澳门| 安仁县| 鞍山市| 平利县| 合江县| 沅江市| 阜新市| 伊宁县| 五峰| 盐津县| 永川市| 岳池县| 齐齐哈尔市| 瑞昌市| 潼关县| 上饶县| 白山市| 北流市| 体育| 九江县| 米脂县| 宁都县| 金堂县| 疏附县| 惠安县| 合阳县| 营口市| 鞍山市| 建瓯市| 修水县| 高淳县| 浦城县| 浦东新区|