最近因项目需要,做一个数据采集的单片机平台。需要移植 FatFs 。现在把最后成果贴上来。

1、摘要

在 STM32 单片机上,成功移植 FatFs 0.12b,使用的 Nand Flash 芯片为 K9F2G08 。

特点: 系统配合 FatFs 实现了坏块管理,硬件ECC,软件 ECC 纠错

2、代码分析

2.1、擦写均衡分析

在create_chain 函数中实现,每次分配都由当前scl 指向的 free cluster 开始,逐块检查,是否有可用 cluster 存在。如果没有则取下一块,直到回到起始点,说明已经没有 free cluster 了。

因为每次都紧邻 scl 取 free cluster, 那么每次的起始 scl 值在哪里,就决定了擦写位置。

通过查看代码,很可惜,发现 scl 每次都重新从 1 开始查找 free cluster。所以,默认条件下,FatFs 不支持擦写均衡。

如果能把每次分配的cluster号记录下来,下次接着向后分配,则可实现擦写均衡。未来有时间再来实现吧。也许你现在就能实现哦,另忘了实现了分享一份给我。

2.2、坏块管理分析

通过2.1对create_chain 函数的分析,我们知道get_fat是完成真实的 free cluster的分配。而每次 get_fat 函数都会调用 move_window 函数实际的读入一次该 sector。所以,我们只需要在读取函数中,对坏块进行检查,返回 出错,则分配的 cluster 自动移到下一个。从而完成跳过坏块存储数据。

具体实现如下:

如果 FSMC_NAND_ReadSmallPage 检测到坏块,则 NAND_disk_read 返回 RES_ERROR。

2.3、STM32的硬件ECC

在FSMC_NAND_Init 函数中打开STM32的硬件ECC配置。如下红色字。

FSMC_NANDInitStructure.FSMC_Bank = FSMC_Bank2_NAND;

FSMC_NANDInitStructure.FSMC_Waitfeature = FSMC_Waitfeature_Enable;

FSMC_NANDInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_8b;

FSMC_NANDInitStructure.FSMC_ECC = FSMC_ECC_Enable;

FSMC_NANDInitStructure.FSMC_ECCPageSize = FSMC_ECCPageSize_256Bytes;

FSMC_NANDInitStructure.FSMC_TCLRSetupTime = 0x00;

FSMC_NANDInitStructure.FSMC_TARSetupTime = 0x00;

FSMC_NANDInitStructure.FSMC_CommonSpaceTimingStruct = &p;

FSMC_NANDInitStructure.FSMC_AttributeSpaceTimingStruct = &p;

这里使用的是 FSMC_ECCPageSize_256Bytes ,而 K9F2G08 的最小page 为 2048, 所以,我们在驱动中,会再把 2048 的page 页再分为8个256的小页面分别进行 ECC 运算。这样做的好处很明显,坏处就是加大了复杂度。具体实现参见 FSMC_NAND_WriteSmallPage和FSMC_NAND_ReadSmallPage 函数。

每次在硬件运算 ECC 开始时都需要打开ECC开关,算完一页后,又需要关闭开关。在读取ECC值之前还必须等待计算完毕。

while(FSMC_GetFlagStatus(FSMC_Bank2_NAND,FSMC_FLAG_FEMPT)==Bit_RESET);

做到这几条就可以通过 FSMC_GetECC 函数获取正确的 ECC 值了。

另外因为我们的计算特性,所以在坏块标志后特别加入了一个我们自定义的ECC标识。

2.4、ECC纠错

首先是 ECC 错误识别,代码如下:

说明:eccRd为存储时计算的ECC什值; eccCl 为当前运算的值。

eccXor 不为零时,说明检测到错误。再通过 FSMC_NAND_GetBitPosition 函数获得具体的出错bit的位置。具体算法请阅参考文献。

 

2.5、文件组成

FatFs 目录

+----  ffconf.h   对 FatFs 进行配置的文件

+----  ff.h

+----  ff.c       是 FatFs 的实现文件,擦写均衡在 create_chain 函数中已实现。

+----  ccsbcs.c   文件名支持英文

+----  cc936.c    文件名支技中文

+----  diskio.c   是 FatFs 与自定义驱动层的接口函数

+----  NandDisk.c 为自己实现的 NandFlash 匹配函数,坏块管理在这里实现。

BSP 目录

+----  fsmc_nand.h  对 K9F2G08 的各种参数定义

+----  fsmc_nand.c  实现硬件级别的读写驱动,STM32 的 硬件 ECC 在这里使用。还实现了 ECC 自动纠错

注:为了获得 64*2K 的擦除缓冲区,系统还使用了一块 SRAM 芯片,以支持 malloc 内存 分配函数。这个文件由你自己的系统提供。

3、引用文献

FatFs 系统

http://elm-chan.org/fsw/ff/00index_e.html

ECC 算法详细说明

http://www.360doc.com/content/11/0523/17/496343_118837985.shtml

STM32   ECC校验的一些心得

http://www.51hei.com/bbs/dpj-32707-1.html

最后如果想要下载程序的朋友请点这里:源程序下载

STM32下FatFs的移植,实现了坏块管理,硬件ECC,ECC纠错,并进行擦写均衡分析的更多相关文章

  1. nand flash坏块管理OOB,BBT,ECC

    转:http://www.cnblogs.com/elect-fans/archive/2012/05/14/2500643.html 0.NAND的操作管理方式 NAND FLASH的管理方式:以三 ...

  2. 【转】nand flash坏块管理OOB,BBT,ECC

    0.NAND的操作管理方式      NAND FLASH的管理方式:以三星FLASH为例,一片Nand flash为一个设备(device),1 (Device) = xxxx (Blocks),1 ...

  3. Nand Flash基础知识与坏块管理机制的研究

    概述 Flash名称的由来,Flash的擦除操作是以block块为单位的,与此相对应的是其他很多存储设备,是以bit位为最小读取/写入的单位,Flash是一次性地擦除整个块:在发送一个擦除命令后,一次 ...

  4. BBM(Bad Block Management)坏块管理

    不管WL算法如何高明,在使用中都会碰到一个头痛的问题,那就是坏块,所以一个SSD必须要有坏块管理机制.何谓坏块?一个闪存块里包含有不稳定的地址,不能保证读/写/擦时数据的准确性.            ...

  5. nand flash 的oob 及坏块管理

    0.NAND的操作管理方式      NAND FLASH的管理方式:以三星FLASH为例,一片Nand flash为一个设备(device),1 (Device) = xxxx (Blocks),1 ...

  6. NAND Flash大容量存储器K9F1G08U的坏块管理方法

    转: http://www.360doc.com/content/11/0915/10/7715138_148381804.shtml 在进行数据存储的时候,我们需要保证数据的完整性,而NAND Fl ...

  7. 坏块管理(Bad Block Management,BBM)

    看了很多坏块管理的文章,加上自己的理解,把整个坏块管理做了个总结. 坏块分类 1.出厂坏块 又叫初始坏块,厂商会给点最小有效块值(NVB,mininum number of valid blocks) ...

  8. Oracle corrupt block(坏块) 详解

    转自:http://blog.csdn.net/tianlesoftware/article/details/5024966 一. 坏块说明 1.1 相关链接 在看坏块之前,先看几个相关的链接,在后面 ...

  9. Windows下将ImageMagick移植到Android平台

    Windows下将ImageMagick移植到Android平台 原文链接  http://www.pedant.cn/2014/06/18/imagemagick-ported-android/ I ...

随机推荐

  1. mysql求最大第二,最大第三个数

    题目是这样的: 集团有多个部门,部门下有多个员工,求每个部门绩效排名第二的人员 sql语句是这样的 SELECT dep, MAX(score) FROM zx WHERE score NOT IN ...

  2. java-int类型:int默认为0导致更新操作未赋值的情况下将值更新为0

    日常开发中,做更新操作的时候的处理方法为:当这个字段有值则更新,没有值就不更新,在mybatis的xml中表现为: <!-- 修改记录,只修改只不为空的字段 --> <update ...

  3. 如何使用Google Map API开发Android地图应用

    两年前开发过的GoogleMap已经大变样,最近有项目要用到GoogleMap,重新来配置Android GoogleMap开发环境,还真是踩了不少坑. 一.下载Android SDK Manager ...

  4. 获取真实Ip地址

    /** * @author zhoulongqin * @see 获取客户端ip * @param * @return 客户端ip(String) webserve ip不一定获取的到 */ publ ...

  5. JetBrains注册码计算(IntelliJ IDEA 15.0注册码激活)

    安装前修改时间为2099年等很多年后的时间点,安装后选择免费试用30天,然后退出idea,把时间修改回来,这样就可以成功注册了 如果之前使用过授权服务器等激活方式,不弹出试用界面,请到C:\Users ...

  6. SQL语句 - MERGE INTO 、Cross/Outer Apply用法理解

    MERGE INTO 语法: MERGE INTO table_name alias1 USING (table|view|sub_query) alias2ON (join condition) W ...

  7. Sina 新浪Ip归属地Api 很好用的,使用get请求

    前言 这几天做了一个客服管理系统,需要根据游客的Ip获取他的归属地,刚开始使用了,www.ip138.com 抓取ip归属地,用这还可以,但是不显示国家:于是是找了这个新浪的Api,很不错啊 用法 1 ...

  8. 视图UIView的大小和位置属性详解

    UIView类中定义了三个属性,分别是frame.bounds与center属性: IKit中的坐标系X轴正方向为水平向右,Y轴正方向为竖直向下. frame属性指的是视图在其父视图坐标系中的位置与尺 ...

  9. html5 css3 loading 效果

    canvas  html5load1 主要思路update  实现12个点的绘制和旋转效果 var update = function() { ctx.save();// 把当前绘图状态保存起来 ct ...

  10. OC----面向对象

    创建一个类 comm+n 实例变量的可见度 @public,@protect@private @public  // 共有的,在类的内部和外部都可以进行访问 @protected   // 受保护的, ...