Nand flash ECC數據錯誤怎么辦?
我編譯過kernel 當時選了ECC校驗 啟動以后報錯 去掉了,就不報錯了 所以我會先考慮是不是這個問題 一般來說,硬件ECC校驗出錯可能性比較小吧? |
?
我啥也不懂
-----摘自網絡經典文章:“LINUX系統移植“ 我們的內核都是通過UBOOT寫到Nand Flash的, UBOOT通過的軟件ECC算法產生ECC校驗碼, 這與內核校驗的ECC碼不一樣, 內核中的ECC碼是由S3C2410中Nand Flash控制器產生的. 所以, 我們在這里選擇禁止內核ECC校驗. 修改drivers/mtd/nand/s3c2410.c 文件: [arm@localhost linux2.6.14]$ vi drivers/mtd/nand/s3c2410.c 找到s3c2410_nand_init_chip()函數,在該函數體最后加上一條語句: chip->eccmode = NAND_ECC_NONE; 保存,退出。 |
?
?
ECC很重要,SPARE區域在NAND FLASH架構定義之初就是主要用來存放ECC編碼的,因為NAND FLASH數據出錯概率高需要加ECC進行校驗
1.一個頁讀/寫失敗了,那么是否要將其所在塊標識成壞塊?
一般應用NAND FLASH時都會同時使用ECC糾錯,無論是硬件糾錯還是軟件實現。在有ECC的情況下如果寫入一個Page失敗是可以將其讀出以判斷出現的錯誤是否可以被ECC校驗糾正。若可以被ECC糾正則可以考慮仍將該頁所在塊視為有效塊。若是出現頁寫入錯誤就將該塊表為壞塊,軟件在實現上會更容易。根據具體需要可以選擇不同的處理
2. ecc是做什么的?ecc校驗失敗是否可以確定該塊已經變成了壞塊呢?ecc校驗是否可以關閉?
ECC代表Error Correction Code及糾錯碼,是NAND FLASH應用的關鍵。因為NAND FLASH的數據可靠性問題一般使用NAND FLASH都需要對其數據進行ECC校驗。一般的用法是在寫入NAND FLASH時在主數據區內寫入正常數據,而住數據區數據的ECC校驗碼則寫入Spare區。將住數據區數據讀出時Spare區的ECC碼也必須一起讀出以便進行ECC校驗及糾錯。基本上若是讀出數據后發現ECC校驗失敗則當前塊必須被標記為壞塊。軟件實現的ECC校驗算法一般都可以關閉,有硬件直接實現的ECC校驗模塊則需要看硬件是否支持關閉ECC。一般都可以關閉。
3. 是否只有當擦除一個塊失敗之后,才可以把該塊視為壞塊?
如前所述,仍然是軟件策略選擇問題。若是擦除失敗,仍可嘗試寫入數據并讀出看ECC能否糾錯,若是可被ECC糾正,則可以將該塊視為有效塊。因為塊擦除失敗有相當概率是因為塊內一兩位無法被擦除造成,一般使用的硬件ECC糾錯都可糾至少兩位以上錯誤,糾錯4-8位也不少見。在擦除失敗之后直接將其標為壞塊可以作為最簡單的軟件處理方法。
以上內容摘自網絡
-------------------------------------------------
"mount_devfs_fs(): unable to mount devfs, err: -2"一個困擾了我很久的問題,主要是ecc的問題。在此我把我的理解說一下好了:
??? 搞清楚你在driver/mtd/nand/s3c2410.c文件中有沒有把NAND_ECC_SOFT改成NAND_ECC_NONE,這個網上不少的人都會做(聽說會與yaffs文件系統有沖突,但我發現反而和cramfs文件系統有沖突)。這個地方我那時候沒有交代清楚,不好意思^_^
??? 假設你把NAND_ECC_SOFT改成NAND_ECC_NONE,那[*] ? ? Lets Yaffs do its own ECC 這一步是必需的。
??? 最后,如果你把NAND_ECC_SOFT改成NAND_ECC_NONE的話,那你下載yaffs文件系統的時候就不應該加上-e的參數了。
??? 這個東西我可是經歷了無數次的"mount_devfs_fs(): unable to mount devfs, err: -2"才悟出來的,本來想不講出來的,但實在太多人問這個問題了,實在不忍^_^
??? 最后給點建議:先讓內核掛載cramfs試試看(記得把NAND_ECC_SOFT改成NAND_ECC_NONE哦),因為這個文件系統只要用下載內核的命令下載就行,成功掛載cramfs的話將會是你最大的鼓舞