nand multiple plane 块映射

本文分享了作者在实现NAND驱动multiplane功能过程中遇到的问题及解决方法。从无文档资料的情况下,通过在U-boot环境下逐步调试,最终解决了ECC错误等问题,并详细介绍了扇区与块映射的调整过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

  最近,搞了个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周时间 解决问题的核心所在。

 

### NAND Flash Plane 数量架构及相关配置 NAND Flash 的存储结构通常被划分为多个平面(Plane),这种设计旨在提升设备的整体性能。具体而言,NAND Flash 厂商会将内存阵列(Memory Array)分割成两个独立的平面[^1]。每个平面对应不同的 Block 地址范围,并支持并行操作。这意味着可以在同一时间针对这两个平面中的不同 Block 执行读取、写入或擦除操作。 #### 平面划分的意义 通过将内存阵列拆分至多两个平面,NAND Flash 能够显著提高数据吞吐率。尽管单个平面内的操作仍然遵循串行原则——即无法在同一时刻对同一个平面的不同区域同时进行读取和写入操作[^2],但跨平面的操作则能够实现真正的并发处理。例如: - **读取操作**:可以从一个平面读取数据的同时,在另一个平面执行写入或擦除。 - **写入操作**:在一个平面完成编程动作期间,另一平面可以准备下一组待写入的数据。 - **擦除操作**:当某个平面正在进行区级别的擦除时,其他平面仍可用于正常访问。 此特性使得基于双平面设计的 NAND Flash 更适合高带宽需求的应用场景,比如固态硬盘 (SSD) 或者嵌入式多媒体卡 (eMMC)。 以下是关于如何利用 Python 来模拟简单的双平面调度逻辑的一个例子: ```python class NANDFlash: def __init__(self, num_planes=2): self.planes = [{'status': 'idle'} for _ in range(num_planes)] def operate(self, plane_id, operation_type='read'): if self.planes[plane_id]['status'] == 'idle': print(f"Performing {operation_type} on Plane-{plane_id}") self.planes[plane_id]['status'] = operation_type else: print(f"Plane-{plane_id} is busy with another task.") nand_flash_device = NANDFlash() nand_flash_device.operate(plane_id=0, operation_type="write") # Writing to Plane-0 nand_flash_device.operate(plane_id=1, operation_type="read") # Reading from Plane-1 simultaneously ``` 上述代码片段展示了创建具有指定数量平面的虚拟 NAND Flash 设备类 `NANDFlash` ,并通过实例化该类来演示基本的异步 I/O 操作管理方法。 值得注意的是,虽然当前主流产品普遍采用两平面的设计方案,但在某些高端应用场合也可能存在更多平面数的产品变体。然而,增加额外平面必然会带来成本上升以及控制复杂度增高的挑战,因此实际部署需权衡利弊做出最佳决策[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鬼臾区

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值