nand multiple plane 块映射

 

  最近,搞了个nand  driver 要提供multiplane 的none rbpin 功能,搞得可以说七窍生烟 。

  首先,公司没有这方面使用先例,有也是带rb pin的。 而且啥文档都没有,又是要自己找人问;另外只有自己看code ,总算在反复调试和对照 nand datasheet的过程中弄明白了。其中最吃苦头的就是在kernel 没有调试手段了 。

  为了可以调试,首先移到uboot 上跑起来,利用cmd  分步看nand 的操作结果,和内存交换的的一些问题。将问题现象重复到 uboot下。

  调试了2周时间 ,发现在有ECC 情况下, 总是会有 读ECC error 情形;直接dump 出来啥问题没有 ,只不过数据时有不对。 反复加print ,查datasheet , 看处理流程,几乎所有地方都整了个遍,最后将 LB 号 ,PB号 print出来,改写code  ,最终才将读写擦 的扇区,块 的映射正确建立起来,避免重复写入造成的ECC error情形发生。最终在multiplane 下 none rb 也可以正确run 起来。

 

  以下是在 linux 和 uboot下 mtd nand 的 multiplane  的映射图。 花了本人最终2周时间 解决问题的核心所在。

 

你可能感兴趣的:(linux,cmd,文档)