初级会员

- 积分
- 133
- 金钱
- 133
- 注册时间
- 2018-8-26
- 在线时间
- 22 小时
|
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函数:
- int main()
- {
- volatile uint8_t res = 0;
- char finished[11];
- uint32_t bw = 0,i = 0,total,free;
- u8 buff[] = {"123456789ABCDEF\r\n"};
-
- HAL_Init(); //初始化HAL库
- Stm32_Clock_Init(336,8,2,7); //设置时钟,80Mhz
- delay_init(168); //初始化延时函数
- user_GPIO_init();
- usart1_init(115200);
- my_mem_init(SRAMIN); //初始化内部内存池
-
- exfuns_init();
- while(SD_Init())
- {
- printf("SD Card check error,please check.");
- }
-
- res = f_mount(fs,"",1);
- // if(res)
- res = f_mkfs("",0,0);
- PFout(9) = 0;
- while(1);
- }
复制代码
更新----------------------------------------------------------------------------------------
用上面的代码又跑了一遍,等了17分钟左右,指示灯翻转,格式化成功,拔出SD卡,在windows上显示属性如下图
现在的不理解的问题就是,挂载NTFS格式的SD卡,f_mount()为什么会返回0呢?
debug界面及SD卡属性:
|
-
debug
-
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秒
|