關于Nand ECC 錯誤

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的話將會是你最大的鼓舞

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/253482.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/253482.shtml
英文地址,請注明出處:http://en.pswp.cn/news/253482.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

低功耗設計——功耗估算

根據在功耗分析的過程中是否有輸入向量的提供,功耗估算方法可以分為仿真的方法(Simulative)和非仿真的方法(Non-simulative): 仿真的方法是根據用戶所提供的大量輸入向量來對電路進行模擬,利用…

uboot 與系統內核中 MTD分區的關系

分類: Nand 驅動 2011-11-06 23:48 705人閱讀 評論(2) 收藏 舉報 uboot 與系統內核中 MTD分區的關系: 分區只是內核的概念,就是說A~B地址放內核,C~D地址放文件系統,等等。 1:在內核…

Deep Learning(深度學習)學習筆記整理系列三

Deep Learning(深度學習)學習筆記整理系列 聲明: 1)該Deep Learning的學習系列是整理自網上很大牛和機器學習專家所無私奉獻的資料的。具體引用的資料請看參考文獻。具體的版本聲明也參考原文獻。 2)本文僅供學術交流&…

輾轉相除法 求最大公約數和最小公倍數

# include<stdio.h> int main() { int a,b,c,x,y; printf("請輸入兩個正整數&#xff0c;用逗號間隔&#xff1a;"); scanf("%d,%d",&a,&b); xa; yb; if (a<b) { ca; ab;      //要保證 a>b bc; } while (b!0) { ca; ab; bc%b; …

Conformal ECO 流程介紹

之前聽說過一句話&#xff0c;沒有修過ECO的人生是不完整的。最近就給我整得再次完整了。。。。。。 最近趕項目&#xff0c;RTL freeze之后&#xff0c;后仿發現出了bug&#xff08;還好攔下來了&#xff0c;不然頭更大&#xff09;&#xff0c;于是做了一次function ECO&…

最新天貓面試題(含總結):線程池+并發編程+分布式設計+中間件

最新天貓面試題&#xff08;含總結&#xff09;&#xff1a;線程池并發編程分布式設計中間件https://my.oschina.net/u/3892...

關于NAND flash的MTD分區與uboot中分區的理解 .

今天做內核移植&#xff0c;準備添加NAND flash的驅動&#xff0c;做到MTD分區時&#xff0c;想起在一本書上看到的一句話&#xff0c;說的是分區時每個區之間沒有間隙&#xff0c;前一個區的結束地址是后一個區的起始地址。可是當我看我的開發板的教程時&#xff0c;分區如下&…

Zabbix discoverer processes more than 75% busy

原文發表于cu&#xff1a;2016-06-22 Zabbix discoverer processes more than 75% busy原因及處理。 一&#xff0e;現象 配置了discovery任務后&#xff0c;zabbix dashboard 告警如下&#xff1a; Zabbix discoverer processes more than 75% busy 二&#xff0e;原因 1. 配置…

Begin()

好&#xff0c;要開始在新的博客里寫東西了&#xff0c;上一個博客的賬號和密碼都忘了... 我開通博客的申請里寫&#xff0c;我博文的內容會以機器學習和控制算法的學習筆記為主。 那我寫的估計是假的申請。 好吧&#xff0c;既然是這樣寫申請的一定程度上也是要兌現承諾的&…

圖像紫邊消除(depurple)

圖像紫邊廣泛存在于目前的手機攝像頭、數碼相機、監控攝像頭等數字成像系統所得圖像中,當我們使用這些設備在逆光、大光圈等條件下拍攝時,所得圖像的局部區域,特別是高反差區域(亮暗對比反差很大的圖像區域,比如天空、燈管與物體相接的邊緣)會比較容易觀察到紫邊,解決圖…

Swift 性能相關

起初的疑問源自于「在 Swift 中的, Struct:Protocol 比 抽象類 好在哪里&#xff1f;」。但是找來找去都是 Swift 性能相關的東西。整理了點筆記&#xff0c;供大家可以參考一下。 一些疑問 在正題開始之前&#xff0c;不知道你是否有如下的疑問&#xff1a; 為什么說 Swift 相…

linux_NandFlash_driver_超詳細分析 .

分類&#xff1a; Linux 驅動 Nand 驅動 2011-11-06 23:16 474人閱讀 評論(0) 收藏 舉報 今天學習了NandFlash的驅動&#xff0c;硬件操作非常簡單&#xff0c;就是這個linux下的驅動比較復雜&#xff0c;主要還是MTD層的問題&#xff0c;用了一下午時間整理出來一份詳細的分析…

HTTPS 路徑配置

1: 首先安裝 fiddlercertmaker.exe 文件2:Tools -> HTTPS 3: Connections 勾中Allow remote computer to connect轉載于:https://www.cnblogs.com/eason-d/p/7492177.html

CMOS圖像傳感器——相位對焦

之前介紹了許多自動對焦的方案 自動對焦方法學習_滄海一升的博客-CSDN博客自動對焦的各類方法學習介紹https://blog.csdn.net/qq_21842097/article/details/121373263 在里面提到了遮蔽像素相位檢測法,原理上算是相位檢測法(Phase Detection Auto Focus,PDAF)的一種。…

51nod 1343 行列式的根

這題分塊搞一搞&#xff0c;算到最后發現結果就是算矩陣J的行列式&#xff0c;要取模m&#xff0c;那個sign消掉了。 參考文獻在這&#xff0c;歐幾里德算法的應用&#xff0c;金斌 代碼還是比較好寫的&#xff0c;python代碼 n,mmap(int,raw_input().split()) a[] for i in ra…

Spring Cloud Config 和Spring Cloud Bus實現配置中心

2019獨角獸企業重金招聘Python工程師標準>>> Spring Cloud是很多組件的集合&#xff0c;Spring將常用的技術框架進行包裝和整合&#xff0c;如mybatis zookeeper rabbitmq redis等等&#xff0c;還有一些科技公司貢獻出來的一些經過生產環境驗證的組件如奈飛公司貢獻…

ARM Linux啟動過程分析

1. 引 言 Linux 最初是由瑞典赫爾辛基大學的學生 Linus Torvalds在1991 年開發出來的&#xff0c;之后在 GNU的支持下&#xff0c;Linux 獲得了巨大的發展。雖然 Linux 在桌面 PC 機上的普及程度遠不及微軟的 Windows 操作系統&#xff0c;但它的發展速度之快、用戶數量的日益…

你有沒有靠譜的基因?一個人靠不靠譜,其實就看這三點:“凡事有交代,件件有著落,事事有回音。”...

你有沒有靠譜的基因&#xff1f;一個人靠不靠譜&#xff0c;其實就看這三點&#xff1a;“凡事有交代&#xff0c;件件有著落&#xff0c;事事有回音。” 故事一、做了就忘了&#xff1f; 一天上班后&#xff0c;我讓小王給上級部門送一個材料。 一個小時過去了&#xff0c;沒…

CMOS圖像傳感器——閃爍(flicker)現象

一、概述 閃爍(Flicker),通常發生在室內場景,曝光時間設置如果不是光源能量周期的整數倍,則圖像不同位置處積累的信號強度不同,并呈周期性變化,這是單幀圖像的情況。在視頻序列上,如果滿足一定條件,視頻會出現條紋模式在垂直方向上緩慢移動。 二、形成原因 1、光源 …

一條命令教你安裝centos下面的pip服務

yum install -y python-pip轉載于:https://blog.51cto.com/12131824/2177874