Nand ECC学习

来源:互联网 发布:百度关键词挖掘软件 编辑:程序博客网 时间:2024/06/05 14:21
 Nand ECC校验和纠错原理及2.6.27内核ECC代码分析.pdf    samsung_ecc_algorithm_for_256b.pdf    samsung_ecc_algorithm_for_512b.pdf  

内核代码已经实现了256Byte/3Byte和512Byte/3Byte ECC算法,现在芯片定义要搞204Byte/nByte,还不知道算法怎样实现。

Google下找过Samsung的两个官方文档:
samsung_ecc_algorithm_for_256b.pdf samsung_ecc_algorithm_for_512b.pdf
看完有后感觉有些细节实现地方还没描述出来。

再看一下内核源码:http://lxr.linux.no/#linux+v2.6.21/drivers/mtd/nand/nand_ecc.c
基本搞明白流程了,但行极性生成还是有点困惑。

最后在找wwxbei在uc上发表的[原创]Nand ECC校验和纠错原理及2.6.27内核ECC代码分析
读完后有种豁然开朗感觉,thanks wwxbei!

归纳起来:
nand flash读写可能会出现个别bit错误,通过ECC算法纠正1bit错误、检测错2bit错误。
3bit以上的错误ECC算法就管不了了。纠正1bit错误方法自然是找到哪一行、哪一列。
以256Byte/22bit为例。将256Byte数据看成一个256行8列的bit矩阵,256行用8bit、8列用3bit,一共要11bit来定位某一个bit在矩阵中的位置。ECC算法总每一个行列位置实际用到是一对可以表示极性的数据来,因此ECC数据量是11bit * 2 = 22bit。
同理512Byte/24bit,12bit * 2 = 24bit。

<script>window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdMiniList":false,"bdPic":"","bdStyle":"0","bdSize":"16"},"share":{}};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://bdimg.share.baidu.com/static/api/js/share.js?v=89860593.js?cdnversion='+~(-new Date()/36e5)];</script>
阅读(3022) | 评论(0) | 转发(0) |
0

上一篇:soft lockup

下一篇:Mips cache lock

相关热门文章
  • SHTML是什么_SSI有什么用...
  • 卡尔曼滤波的原理说明...
  • shell中字符串操作
  • 关于java中的“错误:找不到或...
  • linux设备驱动归纳总结...
  • linux dhcp peizhi roc
  • 关于Unix文件的软链接
  • 求教这个命令什么意思,我是新...
  • sed -e "/grep/d" 是什么意思...
  • 谁能够帮我解决LINUX 2.6 10...
给主人留下些什么吧!~~
原创粉丝点击