运行环境
CPU:君正M300
运行操作系统:Linux5.10.180
调试环境:Ubuntu18.04.6
调试模块:nandflash
本调试方法是使用nandflash的mtd字符驱动,对flash进行不带文件系统的读写方式并测试flash的ecc码,使用bch算法计算纠错码并存储到flash
bch的算法这里不多做解释和说明,网上很多,这里不做过多解释,bch.c bitrev.c等相关的BCH ECC校验算法来源于内核源码kernel/lib/bch.c
使用内核的/lib/bch.c来做nandflash的ecc校验并纠正,前2个bit错误时可以校验并纠正,但是随机的人为弄错4bit就无法纠正了,在网上查找说是有小小的语法错误
bch_encode函数里的代码里有这样一句*pdata++
编译器根本不是(*pdata),然后pdata++
将这两句分开写就可以了
定义个unsigned int k = 0;的变量
将w = cpu_to_be32(*pdata++);改成
w = cpu_to_be32(pdata[k]);
K++;
就可以了
或者改成
w = cpu_to_be32(*pdata);
pdata++;
修改为上述代码后ecc可正常使用,但是读的时候会由打印sfcnand_do_read error, ret = -77的错误,该错误下篇分析