镁光nandflash MT29F32G08+STM32通用IO口驱动,实现fatfs文件系统
真的挺久没有写文章了,一是太忙了,二是素材也少。
这不最近使用镁光的MT29F32G08型号的nandflash,使用STM32作为控制器,但是我所用的STM32是不带FMC的,我也是想偷懒站在前人的肩膀上,但是网上没有找到STM32通用IO口读写MT29F32G08的,SDN啥的上去看了一下,且不说例程能不能用,都要充值,要办会员,大家都懂的,所以只能自己写了(咱就不明白了,有些人总是拿着一些开源的东西,自己改吧改吧,扔到网站上赚米,真的是良心大大滴坏了)。
驱动用的是网上下载的一个通用驱动nand_MT29F_lld,FTL层移植的原子哥的,这里展示一下STM32通用IO口读写MT29F32G08以及fatfs和USB模拟U盘的一些关键程序。
图1STM32通用IO驱动MT29F32G08
图2 通用驱动nand_MT29F_lld
图3,移植原子哥的FTL层
图4,fatfs移植,修改user_diskio.c的读扇区函数
图5,fatfs移植,修改user_diskio.c的写扇区函数
图6,fatfs移植,修改user_diskio.c的IO控制函数
图7,USB模拟U盘,修改usbd_storage_if.c文件的读函数
图8,USB模拟U盘,修改usbd_storage_if.c文件的写函数
接下来就是用文件系统存储数据了,我这里数据量比较大,一秒钟15hz,每一条记录32字节,凑够1024字节写一次csv文件。每个文件最大写32M,写满就生成新的文件继续写,每次上电遍历目录写的文件总数,生成对应的文件名。好了,继续截图~~
上电先生成新的文件名,并打开文件。
图9,上电生成新的csv文件
使用两个buffer轮流写入数据,写满32M就关闭当前文件,并生成新的csv文件继续写,文件总数超过1500个就在不再继续写,差不多存满了。
图10 上电期间不停写入数据
检测到USB插入,就关闭当前正在写 的文件,卸载文件系统。可以把写好的文件拷贝出来。
图11 检测到USB插入
设备已经运行了一会了,看看目录下面的文件和内容吧~
图12 log显示USB已经插入
打开我的电脑
图13 正常识别U盘
看看目录
图14 目录下文件
看看文件内容
图15 文件内容
看到文件格式内容都对,符合设计需求。
到这里就结束了,但是,凡事总有个但是,我这个系统没有备用电源,所以当系统断电而我正好还在写文件的时候,这个文件就会被破坏,打不开,而当fatfs在更新目录表信息,发生断电的话,那就是文件系统损坏了,下一次上电只能重新格式化,从头开始了,以前保存的数据都会丢了。对于这个问题,我暂时还没想到解决办法(在没有备电的情况下)。如果有人有招,就提出来我试试吧。
图16 网络配图
从Nand特性谈其烧录关键点
为什么烧录Nand Flash经常失败?为什么烧录成功了,一部分Nand芯片贴板之后系统却运行不起来?…,等等,问了那么多为什么,那我反问一个问题:你了解Nand Flash的特性及其烧录关键点吗?
一、Nand flash的特性
1、位翻转
在 NAND 闪存是通过对存储单元(Cell)进行充电来完成数据存储的,存储单元的阈值电压就对应着数据值。当读取的时候,通过将它的阈值电压与参考点对比来获得其数据值。对SLC 而言,就只有两种状态和一个参考点。而对于2-Bits 的MLC 而言,它有4 种状态和三个参考点。TLC就更多状态和参考点。当读出的数据值与编程时数据值对应的阈值电压不相匹配时,表明数据发生了位翻转,就带来了可靠性问题。导致位翻转的最常见原因是“编程干扰”导致的阈值电压漂移。
2、存储结构
Nand 闪存由多个Block组成,每一个Block又由多个Page组成,Page的大小一般为512+16Bytes 、2K+64Bytes以及4096+128Bytes,Page是读取和编程的基本单位,而擦除的基本单位是Block。
NAND Flash的页,包含主区(Main Area)和备用区(Spare Area)两个域,“主区”也常称作数据区,备用区是保留区域,一般用来标记坏块(bad block)和存放ECC的值,当然有些文件系统使用备用区记录擦除次数、文件组织数据等。
图1.1 为页大小为2048+64的闪存存储结构
3、坏块及ECC
位翻转的发生是随机的,且比特误码的数量会随着擦写次数的增加而增加。但是只要比特误码的数量在ECC 能够纠正的范围内,数据的完整性就始终有保障。在有些点,每页的比特误码有可能很接近ECC 所能纠正的极限,NAND 的控制系统必须严防比特误码超过可纠错的范围,否则,就可能造成数据丢失或者系统无法正常工作。因此,这些块必须要标记为坏块。坏块永远不应该再用来存储数据。由于坏块的产生是不可避免的,NAND 制造商在对裸片测试时会选择对某些块进行坏块标记,而不是放弃整个裸片,所以大多数NAND 在出厂时就已经存在标记为坏块的块。如果一个NAND 的块被标记为坏块,那么NAND 的容量就永久性的减小了。
二、Nand系统裸片量产烧录的关键点
由于Nand flash芯片的特性,以其作为存储介质时必须对这些特性进行恰当处理,这样系统才能正常运行。系统设定各分区数据在Nand芯片的存储布局,并且在存储驱动层对Nand进行位纠错、坏块管理等处理,这些信息需要系统/驱动工程师明确。
研发阶段或小批量生产阶段,常采用在板烧录的方式,原理是将boot通过串口下载到内存跑起来,由boot从SD卡或网络将内核镜像、文件系统镜像等数据烧录到Nand flash芯片。
为了提高生产效率或别的方面考虑,会使用烧录器对Nand flash裸片进行量产烧录,由于烧录器厂家并不知道存储驱动层对Nand各种特性的处理方式,所以不加正确配置就进行烧录的话,往往出现以下情况:1. 烧录失败,经常是校验通不过;2. 烧录通过,但是部分芯片贴板之后系统运行不起来,或者运行起来某些模块出现一些错误与异常。这些大多不是烧录器本身的问题,而是裸片烧录Nand系统时几个重要的关键点没有处理好,或者说没有和目标系统相关处理一致。这些关键点包括:
1) 坏块处理策略
2) 分区(Partition)
3) 纠错码(Error Correction Codes,ECC)
当然,影响烧录的还有其他因素,比如备用区的使用情况、未用好快的格式化以及动态元数据等,但我们这里只讨论上面几个比较普遍的因素。
1、坏块处理策略
坏块一般是根据芯片的坏块标记位置进行识别的,而坏块处理策略定义了在遇到坏块时算法应该如何处理。策略算法负责将本来应该写到坏块的内容写到其它可选的好块中。最常用的坏块处理策略是跳过坏块,其他典型的还有带BBT的跳过坏块及预留块区等。
跳过坏块的处理策略是最基本最常用的坏块替换策略。当烧录中遇到坏块时,算法简单地跳过坏块,而将数据写入下一个好块。它会造成物理数据和逻辑数据的位置偏移,这通常需要分区来解决这个问题。
2、分区(Partition)
采用类跳过坏块的处理策略的Nand系统,常常会把存储区分成若干个不同的物理区域,这就是我们说的分区,概念上很像电脑硬盘的分区。使用分区使得你有能力确保你的数据可以存到预先指定的物理块区内,即便在这之前发现了一些坏块。这对一些底层软件组件比如启动引导程序和某些必须很容易定位的文件系统驱动程序来说,是非常有帮助的。
当使用跳过坏块的替换策略时,坏块会导致数据顺移到下一个好块。如果设置了分区,就可以指导烧录器确定数据的边界,确保数据文件不会侵占邻近的分区。
图2.2.1就是典型的嵌入式Linux系统的分区情况。
图2.2.1 典型的嵌入式Linux系统分区情况
3、纠错码(Error Correction Codes,ECC)
针对不同工艺、容量的NAND存储系统采用适当的ECC算法是应该的,要保证系统的可靠性,甚至是必须的。ECC纠错码一般存放在备用区中,对一整页或将页分成若干节的数据进行计算而得。数据烧录之前需要准备好ECC(硬件ECC除外),如果是纯数据则需要使用ECC算法来生成。Nand裸片量产中,知道ECC算法的纠错能力(纠错位数)是很重要的,因为要保证生产效率,烧录器如果采用ECC来进行校验数据是不实际的,而通过简单数据比对就可以知道数据的位翻转个数,如果翻转个数范围在ECC算法的纠错范围之内,则认为校验应该是通过的。
三、烧录定制
对于以上关键点或其它特殊部分,如果烧录器软件没有支持的相应的方案,需要联系原厂进行相关算法的定制,比如坏块处理方案、ECC方案等。
加入微信
更多内涵 你懂的 !
搜索微信公众号:电子产品世界
相关问答
三星固态需要装 驱动 吗-ZOL问答是Intel为超极本量身定做的新一代固态硬盘接口标准,其常规尺寸仅为42mm×22mm,单面布置NANDFlash颗粒的厚度为2.75mm,双面颗粒的厚度是3.85mm,对mSATA来说体积...
fpga上市公司排名?1)紫光国芯——长江存储3DNAND;FPGA;2)中兴通讯——中兴微电子;3)国民技术——射频芯片;移动支付限域通信RCC技术;4)景嘉微——军用GPU(JM54...14)....
NAND 与ROM有什么不同-ZOL问答我的PPC有8G的NAND但是ROM只有128MB,我想问在WM系统中NADN和ROM的使用功能一样吗,或者说NADN能够当作是ROM使用吗?在待机状态系系统会像SDMMC那样切断储存器电...
三星电子AI 驱动 芯片繁荣,二季度利润猛增,股价创新高-ZOL问答DRAM和NAND闪存都跟着水涨船高,特别是NAND涨价23%-28%,DRAM涨个20%。今年第二季度就更猛了,利润创纪录高点,营业额也涨不少。主要是AI带的头,数据中心那些高端...
WIN10输入时总是跳屏怎么处理?-ZOL问答记录了当前的nandflash有几个分区,每个分区的名字,大小,偏移量是多少系统就是依靠这些分区表找到各个文件系统的这些分区表nand中的文件系统没有必然关系...
鸿蒙仓颉龙头股票有哪些-ZOL问答并且已经宣布将使用鸿蒙操作系统来驱动其智能终端设备。5.群创光电股份有限公...2020年NAND的同比增长率将为27%,嵌入式微处理器、汽车逻辑芯片和DRAM等类别也...
14promax闪存什么技术?iPhone14ProMax的NAND型闪存(NANDFlash)采用SanDisk产品,三星电子供应LPDDR5SDRAM内存,意法半导体(STMicroelectronics)可能提供电...
东芝手机的创始人是谁?不过现在NAND闪存业务已经从东芝独立出来,变为一个新的品牌了。东芝是一直跟着时代的变化不断调整自己,一直跟着社会的变化,不断发展到今天这样一个阶段。现...
点击我的电脑“属性”,发现上面说处理器和安装内存(RAM)都不...电脑重新评估下~就解决了有用(0)回复nandihua32位的系统貌似只支持3G内存4G的就有1G是浪费掉的。有用(0)回复yh0036安装最新版的主板驱动有用(0)回复...
我想给我台式电脑装个32G固态硬盘,只装XP系统,请问~~够用否?装完之后能余出来多少G容量啊?..1、固态硬盘和普通硬盘同属于硬盘,都是用来储存和运行的,所以装什么系统都可以。2、XP不支持TRIM,只有WIN7支持,那是因为WIN7内置TRIM指令,而XP本身没有。...