OpenEdv-开源电子网

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

F4使用FAFS的f_mkfs()格式化512GB的SD卡出错

[复制链接]

2

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
133
金钱
133
注册时间
2018-8-26
在线时间
22 小时
发表于 2020-4-23 11:50:31 | 显示全部楼层 |阅读模式
15金钱
本帖最后由 我住隔壁 于 2020-4-23 13:50 编辑

手上这张512GB的SD卡如果先手动格式化成FAT32格式,再放到探索者STM32F4开发板上跑的话,SD卡挂载和数据写入都是正常的,在windows上也能看到创建的文件和写入的数据。现在的问题就是,如果是同一张卡,格式化成NTFS文件系统之后,放到开发板上跑,就不行了,FATFS使用的是R0.12版本,申请工作区间调用的是原子哥《内存管理实验》中的mymalloc()函数,单步运行发现的问题如下:
1、f_mount()函数可以执行,但返回值为0;
2、执行到f_mkfs()后一直卡死,使用step into一行一行执行,发现程序是是在用户编写的SDIO驱动程序和stm32f4xx_ll_sdmmc.c两个文件的函数中跑来跑去

小弟想问一下,这应该是什么原因造成的,该如何解决,为什么NTFS的SD卡调用f_mount()还能返回0?
另外我有一种猜想,是不是512GB的SD卡格式化需要很长时间,莫非在下所等的几分钟只是微不足道
感激不尽!

main函数:

  1. int main()
  2. {

  3.         volatile uint8_t res = 0;
  4.         char finished[11];
  5.         uint32_t bw = 0,i = 0,total,free;
  6.         u8 buff[] = {"123456789ABCDEF\r\n"};
  7.         
  8.   HAL_Init();                           //初始化HAL库   
  9.   Stm32_Clock_Init(336,8,2,7);          //设置时钟,80Mhz
  10.         delay_init(168);                       //初始化延时函数
  11.         user_GPIO_init();
  12.         usart1_init(115200);
  13.         my_mem_init(SRAMIN);                        //初始化内部内存池
  14.         
  15.         exfuns_init();
  16.         while(SD_Init())
  17.         {
  18.                 printf("SD Card check error,please check.");
  19.         }
  20.         
  21.         res = f_mount(fs,"",1);
  22. //        if(res)
  23.                 res = f_mkfs("",0,0);

  24.         PFout(9) = 0;
  25.         while(1);
  26. }
复制代码

更新----------------------------------------------------------------------------------------
用上面的代码又跑了一遍,等了17分钟左右,指示灯翻转,格式化成功,拔出SD卡,在windows上显示属性如下图

现在的不理解的问题就是,挂载NTFS格式的SD卡,f_mount()为什么会返回0呢?

debug界面及SD卡属性:



debug

debug

SD卡属性

SD卡属性

最佳答案

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

最近又研究了一会儿,最后确定NTFS的SD卡使用f_mount()挂载,返回值还是0,是由于使用了volatile关键字,单步调试发现,f_mount()在最后return的值确实不是0,只是回到主函数,res就变成了0,去掉volatile关键字,结果正常 另外,原帖子的fatfs是R0.12版本,从NTFS格式化FAT3格式最快3分钟左右,换成R0.14之后,只需1分20秒
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
133
金钱
133
注册时间
2018-8-26
在线时间
22 小时
 楼主| 发表于 2020-4-23 11:50:32 | 显示全部楼层
最近又研究了一会儿,最后确定NTFS的SD卡使用f_mount()挂载,返回值还是0,是由于使用了volatile关键字,单步调试发现,f_mount()在最后return的值确实不是0,只是回到主函数,res就变成了0,去掉volatile关键字,结果正常

另外,原帖子的fatfs是R0.12版本,从NTFS格式化FAT3格式最快3分钟左右,换成R0.14之后,只需1分20秒
回复

使用道具 举报

3

主题

1155

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
7462
金钱
7462
注册时间
2015-1-15
在线时间
1367 小时
发表于 2020-4-23 13:35:54 | 显示全部楼层
FatFs又不支持NTFS文件系统,不识别不是很正常嘛
一分耕耘一分收获。
回复

使用道具 举报

2

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
133
金钱
133
注册时间
2018-8-26
在线时间
22 小时
 楼主| 发表于 2020-4-23 13:40:08 | 显示全部楼层
yklstudent 发表于 2020-4-23 13:35
FatFs又不支持NTFS文件系统,不识别不是很正常嘛

我也是这么想的,所以f_mount的返回值不应该是FR_NO_FILESYSTEM才对吗,为什么还会返回0呢
回复

使用道具 举报

2

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
133
金钱
133
注册时间
2018-8-26
在线时间
22 小时
 楼主| 发表于 2020-4-23 13:42:25 | 显示全部楼层
yklstudent 发表于 2020-4-23 13:35
FatFs又不支持NTFS文件系统,不识别不是很正常嘛

我又测试了一次,这次等了17分钟,发现格式化FAT32成功了,现在就是f_mount为什么会返回0我不理解了
回复

使用道具 举报

3

主题

1155

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
7462
金钱
7462
注册时间
2015-1-15
在线时间
1367 小时
发表于 2020-4-23 17:15:36 | 显示全部楼层
我住隔壁 发表于 2020-4-23 13:42
我又测试了一次,这次等了17分钟,发现格式化FAT32成功了,现在就是f_mount为什么会返回0我不理解了

不理解就去研究f_mount函数都是干啥了,源码都有的,自己去好好看看,这样理解的更深
一分耕耘一分收获。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165475
金钱
165475
注册时间
2010-12-1
在线时间
2115 小时
发表于 2020-4-30 00:44:04 | 显示全部楼层
FATFS就不支持NTFS哦, 建议直接电脑格式化吧。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

2

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
133
金钱
133
注册时间
2018-8-26
在线时间
22 小时
 楼主| 发表于 2020-5-2 14:31:55 | 显示全部楼层
正点原子 发表于 2020-4-30 00:44
FATFS就不支持NTFS哦, 建议直接电脑格式化吧。

好的,谢谢
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-2 02:07

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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