OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 7779|回复: 18

采用阿波罗的NandFlash的文件系统,res = f_mkfs(Nand_Disc,1,4096);返回成功了,可是去open一个文件,返回还是NoFileSystem

[复制链接]

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2015-5-14
在线时间
46 小时
发表于 2016-7-7 15:37:21 | 显示全部楼层 |阅读模式
1金钱
使用的是阿波罗的的Nand fatfs文件系统,Nand芯片是 K9F4G的 512M的。
经过修改一点点;
主函数里面:        
        f_mount(Nand_Disc, &NAND_fatfs);            
        res = f_open(&NAND_file, "1:/qq.txt", FA_OPEN_EXISTING|FA_READ);       //这边返回    FR_NO_FILESYSTEM   
        if(res == FR_NO_FILESYSTEM)
        {               
            res = f_mkfs(Nand_Disc,1,4096);    //返回 OK
            if(res == FR_OK)
                 res = f_open(&NAND_file, "1:/qq.txt", FA_CREATE_ALWAYS | FA_READ);  //这边又返回    FR_NO_FILESYSTEM   
        }  
        f_close(&NAND_file);

   明明格式化成功了,为什么还是返回没有文件系统。我仿真进去看了一下,是因为每次f_mkfs格式化完成以后,去操作文件时,会再次进入RTL_Init()函数里面,
  其中  temp=FTL_CreateLUT(1);这个函数,nand_dev.lut[i]   每次f_mkfs之前数据都是00 00 01 00 02 00 03 00 04 00 05 00.....都是正确的,f_mkfs格式化以后,
  就会出现FF FF 01 00 02 00 03 00 04 00 05 00....,这样就会导致又重新低级格式化了。
  请问为什么会出现这样的情况,希望各路大神给点建议,原子哥的RTL那部分代码我没有具体看。

最佳答案

查看完整内容[请看2#楼]

那就不清楚你的了。我 在阿波罗开发板上,运行良好
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2016-7-7 15:37:22 | 显示全部楼层
jinghong21 发表于 2016-7-12 20:08
底层没问题的,我开机注册了nanf的文件区,创建一个cfg文件,写入没问题,读取数据也都是正确的,这个cfg ...

那就不清楚你的了。我 在阿波罗开发板上,运行良好
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2015-5-14
在线时间
46 小时
 楼主| 发表于 2016-7-7 17:04:30 | 显示全部楼层
原子哥,块复制那边的话,复制完成以后,擦除源块0,这样子的话没有在源快0的spare里面写任何东西。然后fopen需要RTL_Init(),就会导致temp=FTL_CreateLUT(1);这个函数读取的块0spare就会全部为FF FF。
回复

使用道具 举报

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2015-5-14
在线时间
46 小时
 楼主| 发表于 2016-7-7 20:05:55 | 显示全部楼层
jinghong21 发表于 2016-7-7 17:04
原子哥,块复制那边的话,复制完成以后,擦除源块0,这样子的话没有在源快0的spare里面写任何东西。然后fop ...

求助这个问题 @正点原子
回复

使用道具 举报

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2015-5-14
在线时间
46 小时
 楼主| 发表于 2016-7-8 21:13:12 | 显示全部楼层
顶一下,@正点原子 原子哥,我说的这个问题是不是不应该出现的,可是我解决不了,求帮忙
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2016-7-9 00:13:03 | 显示全部楼层
jinghong21 发表于 2016-7-7 17:04
原子哥,块复制那边的话,复制完成以后,擦除源块0,这样子的话没有在源快0的spare里面写任何东西。然后fop ...

不是块复制的问题。
f_open不需要FTL_Init的。
FTL_Init只有在初始化磁盘的时候,才会使用。而初始化的时候,读取spare0区的数据和文件系统是无关的,只是和坏块管理相关。
你文件系统的东西,都市存储在数据区的。

你现在下载我们的NAND FLASH实验,测试下,是否正常。然后再下载FATFS实验,测试NAND FLASH的读写。

我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2015-5-14
在线时间
46 小时
 楼主| 发表于 2016-7-10 09:37:49 | 显示全部楼层
正点原子 发表于 2016-7-9 00:13
不是块复制的问题。
f_open不需要FTL_Init的。
FTL_Init只有在初始化磁盘的时候,才会使用。而初始化的 ...

file:///C:/Users/zhanghai/Desktop/aaaaaa.png

我试了nandflash的实验,写进去的是00 01 02 03 04 05 ....... FF,读出来的有的数据时正确的,别的数据全是FF
回复

使用道具 举报

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2015-5-14
在线时间
46 小时
 楼主| 发表于 2016-7-10 12:40:26 | 显示全部楼层
本帖最后由 jinghong21 于 2016-7-10 12:46 编辑
正点原子 发表于 2016-7-9 00:13
不是块复制的问题。
f_open不需要FTL_Init的。
FTL_Init只有在初始化磁盘的时候,才会使用。而初始化的 ...

      while(FTL_Init());                        //检测NAND FLASH,并初始化FTL

        backbuf=mymalloc(SRAMIN,NAND_ECC_SECTOR_SIZE);        //申请一个扇区的缓存
        buf=mymalloc(SRAMIN,NAND_ECC_SECTOR_SIZE);                //申请一个扇区的缓存   
//        NAND_EraseBlock(0);    //在这边加一个擦除块0,有很大的效果
        for(i=0;i<NAND_ECC_SECTOR_SIZE;i++)
            buf=i+t;        //填充数据(随机的,根据t的值来确定)   
        NAND_WritePage(0,0x400,buf,512);
        NAND_ReadPage(0,0x400,buf,512);   //如果前面不加  擦除块0的函数,读出来就是不正确的,加了擦除块0,读出来的就是正确的。  
        key=FTL_WriteSectors(buf,2,NAND_ECC_SECTOR_SIZE,1);//写入扇区        
        key=FTL_ReadSectors(buf,2,NAND_ECC_SECTOR_SIZE,1);//读取扇区

在写之前加一个擦除块0 的函数,读写就是正确的(这个读写只能直接操作nand,不能通过FTL的函数)。可是在FTL_Init()里面,块0是已经被擦除了的,只是在spare区域写了逻辑块的数据,main区域是没有任何操作的。原子哥,这是什么情况,是硬件的问题吗?  
@正点原子
而且虽然读出来的数据是错误的,但是错误的数据时有规律性的。

这边两张截图,就是写的数据和读出来的数据。

bbbbbbbb.png
aaaaaa.png
回复

使用道具 举报

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2015-5-14
在线时间
46 小时
 楼主| 发表于 2016-7-10 15:22:07 | 显示全部楼层
本帖最后由 jinghong21 于 2016-7-10 15:25 编辑
jinghong21 发表于 2016-7-10 12:40
while(FTL_Init());                        //检测NAND FLASH,并初始化FTL

        backbuf=my ...

u8 FTL_Format(void)
{
    u8 temp;
    u32 i,n,p;
    u8* buf;
    u32 goodblock=0;
        nand_dev.good_blocknum=0;
#if FTL_USE_BAD_BLOCK_SEARCH==1                                //使用擦-写-读的方式,检测坏块
        nand_dev.good_blocknum=FTL_SearchBadBlock();//搜寻坏块.耗时很久
#else                                                                                //直接使用NAND FLASH的出厂坏块标志(其他块,默认是好块)
    for(i=0;i<nand_dev.block_totalnum;i++)        
    {
                temp=FTL_CheckBadBlock(i);                        //检查一个块是否为坏块
        if(temp==0)                                                        //好块
        {
                        temp=NAND_EraseBlock(i);

                        if(temp)                                                //擦除失败,认为坏块
                        {
                                printf("Bad block:%d\r\n",i);
                                FTL_BadBlockMark(i);                //标记是坏块
                        }else nand_dev.good_blocknum++;        //好块数量加一
                }
        }
#endif
        for(i=0;i<NAND_ECC_SECTOR_SIZE;i++)
            buf=i;        //填充数据(随机的,根据t的值来确定)
    NAND_WritePage(0,0,buf,1);   //格式化以后不能有这一步,不然下面的写逻辑块数据就会不正确。
这个是我自己添加测试的,

    printf("good_blocknum:%d\r\n",nand_dev.good_blocknum);
    if(nand_dev.good_blocknum<100) return 1;        //如果好块的数量少于100,则NAND Flash报废   
    goodblock=(nand_dev.good_blocknum*93)/100;        //%93的好块用于存储数据  
    n=0;                                                                                
    for(i=0;i<nand_dev.block_totalnum;i++)                //在好块中标记上逻辑块信息
    {
        temp=FTL_CheckBadBlock(i);                          //检查一个块是否为坏块
        if(temp==0)                                          //好块
        {
            NAND_WriteSpare(i*nand_dev.block_pagenum,14,(u8*)&n,2);//写入逻辑块编号   这个写块0 的spare应该是 00 00 ,
            NAND_ReadSpare(i*nand_dev.block_pagenum,12,(u8*)&p,4);// 如果前面写了 main区域任何数据,读出来的数据确是 00 FF。不写main区域直接读就是正确的 00 00
            n++;                                                                //逻辑块编号加1
            if(n==goodblock) break;                                //全部标记完了
        }
    }

    if(FTL_CreateLUT(1))return 2;                              //重建LUT表失败
    return 0;

回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2016-7-10 15:43:27 | 显示全部楼层
jinghong21 发表于 2016-7-10 09:37
我试了nandflash的实验,写进去的是00 01 02 03 04 05 ....... FF,读出来的有的数据时正确的,别的 ...

不要做任何修改
就用我们例程测试。
库函数版本如果有问题,下载寄存器版本测试。  注意:一定不要做修改。
如果没做任何修改,还有问题,我再来看看是不是代码bug。
因为我这边测试,是不存在你说的问题的。写数据,百分百正确。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2016-7-10 15:46:31 | 显示全部楼层
jinghong21 发表于 2016-7-10 15:22
u8 FTL_Format(void)
{
    u8 temp;

你如果只想测试NAND,不用FTL,就不要混一起了。
单独调用NAND .C里面的代码就完了,别和FTL的混合起来搞。容易出问题。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2016-7-10 15:48:25 | 显示全部楼层
注意写之前,先擦除block。
比如你对block 0操作。每次写数据之前,擦除block0,然后再写,然后再读,然后在对比。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2015-5-14
在线时间
46 小时
 楼主| 发表于 2016-7-10 16:16:58 | 显示全部楼层
正点原子 发表于 2016-7-10 15:48
注意写之前,先擦除block。
比如你对block 0操作。每次写数据之前,擦除block0,然后再写,然后再读,然后 ...

现在的做法是:擦除->写512byte->读512byte没问题.上面的步骤结束以后,我再去写spare的区域,再读spare的区域,就不正确。
                        直接擦除->写是spare的区域,再读spare的区域,就是正确的。
真的有这样的现象,而且写的512byte值0页的前512个地址,和后面的spare应该不想冲的。
回复

使用道具 举报

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2015-5-14
在线时间
46 小时
 楼主| 发表于 2016-7-10 17:21:25 | 显示全部楼层
正点原子 发表于 2016-7-10 15:43
不要做任何修改
就用我们例程测试。
库函数版本如果有问题,下载寄存器版本测试。  注意:一定不要做修 ...

@正点原子  原子哥,我把我修改的地方全部去掉了,除了主芯片是407以外,去掉了LCD那些,别的我什么都没有修改。唯一的区别就是nand芯片,我这个是K9F408U0E的(512M)。但是当前的工程的结果就是异常的。帮忙看看到底是不是我这个Nand的问题。超级感谢......

实验41 FATFS实验.rar

1.97 MB, 下载次数: 402

回复

使用道具 举报

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2015-5-14
在线时间
46 小时
 楼主| 发表于 2016-7-10 17:40:30 | 显示全部楼层
本帖最后由 jinghong21 于 2016-7-10 17:53 编辑
jinghong21 发表于 2016-7-10 17:21
@正点原子  原子哥,我把我修改的地方全部去掉了,除了主芯片是407以外,去掉了LCD那些,别的我什么都没 ...

@正点原子   如果我不用例程里面的扇区2,就可以读写正常哎。我随便写了一个456扇区。
写完00 01 02 03 04 05 06 07......第一次读正确,再讲FF填满扇区,读正确,再讲00 01 02 03 04 05 06 07......写进去,读出来EEC校验错误,再写一遍,读出来又正确,后面只要重新写00 01 02 03 04 05 06 07......都要连续按两次按键写两遍,读出来ECC才不会错误。
回复

使用道具 举报

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2015-5-14
在线时间
46 小时
 楼主| 发表于 2016-7-12 19:10:51 | 显示全部楼层
发现了,是芯片的问题,我换了块K9F2G 256M的就是正常的。
回复

使用道具 举报

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2015-5-14
在线时间
46 小时
 楼主| 发表于 2016-7-12 19:38:51 | 显示全部楼层
本帖最后由 jinghong21 于 2016-7-12 19:40 编辑
正点原子 发表于 2016-7-10 15:43
不要做任何修改
就用我们例程测试。
库函数版本如果有问题,下载寄存器版本测试。  注意:一定不要做修 ...

原子哥,现在我使用256的NANDFLASH,文件系统挂上去了,可是我新建一个文件返回式OK的,写数据进去,就会说磁盘已经满了。。。用的是阿波罗的源码,没有修改。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2016-7-12 19:40:32 | 显示全部楼层
jinghong21 发表于 2016-7-12 19:38
原子哥,现在我使用256的NANDFLASH,文件系统挂上去了,可是我新建一个文件返回式OK的,写数据进去,就会 ...

你先检查下底层函数的执行正确性。
文件系统是上层的东西,你底层保证可靠先。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2015-5-14
在线时间
46 小时
 楼主| 发表于 2016-7-12 20:08:51 | 显示全部楼层
正点原子 发表于 2016-7-12 19:40
你先检查下底层函数的执行正确性。
文件系统是上层的东西,你底层保证可靠先。

底层没问题的,我开机注册了nanf的文件区,创建一个cfg文件,写入没问题,读取数据也都是正确的,这个cfg文件的大小为1K左右。然后我再创建一个BMP图片,也返回创建成功了,可是我朝里面写数据就返回FR_DISK_ERR。   
if (csect == 0) {    /* On the cluster boundary? */
    if (fp->fptr == 0) {  /* On the top of the file? */
     clst = fp->obj.sclust; /* Follow from the origin */
     if (clst == 0) {  /* If no cluster is allocated, */
      clst = create_chain(&fp->obj, 0); /* create a new cluster chain *///这一步它会执行,进去。
     }
    } else {     /* On the middle or end of the file */
#if _USE_FASTSEEK
     if (fp->cltbl) {
      clst = clmt_clust(fp, fp->fptr); /* Get cluster# from the CLMT */
     } else
#endif
     {
      clst = create_chain(&fp->obj, fp->clust); /* Follow or stretch cluster chain on the FAT */
     }
    }
    if (clst == 0) break;  /* Could not allocate a new cluster (disk full) */
    if (clst == 1) ABORT(fs, FR_INT_ERR);
    if (clst == 0xFFFFFFFF) ABORT(fs, FR_DISK_ERR);
    fp->clust = clst;   /* Update current cluster */
    if (fp->obj.sclust == 0) fp->obj.sclust = clst; /* Set start cluster if the first write */
   }
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-2-27 18:10

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表