rt-thread下调试elmfat 问题记录

硬件平台:stm32f107   SPI flash:w25q32

RTT版本:v2.1

w25q32的驱动大神们已经写好(w25qxx.c),我只需要照猫画虎的实现相应SPI的驱动程序即可(bsp例程都有),如此spi flash就可以读写了。查看device列表如下:

接着启用DFS功能和ELMFAT类型文件系统,并挂载文件系统名为“elm”的文件系统到介质为flash0的根目录下,如下图:

#define RT_DFS_ELM_MAX_SECTOR_SIZE  4096  //spi flash的扇区大小是4096

但是会提示挂载失败,原因时flash里边的文件系统分区数据不存在,所以需要格式化一下spi flash,命令如下:

这里截图显示的是理想的情况,在我调试的时候mkfs/mkdir/open都会导致系统卡死或者崩溃,但是在单步仿真的时候,又会一步步正常运行,很是郁闷。

后来发现当全速运行异常后(仿真时不会崩溃,但是程序停止运行,却不知程序指针指在哪里),多次按F10后,程序指针忽然运行到函数get_fattime()中,然后再次全速就正常了,文件打开成功了,目录创建正常了。看样子问题和这个函数有关系了。

深入跟踪get_fattime(),发现该函数可用宏_FS_NORTC来控制是否使用,并说明该函数和RTC相关,如图

原来如此,在调试的硬件上,没有按照RTC的驱动框架实现RTC功能,而是使用I2C自己控制的片外RTC,所以get_fattime()调用RTC驱动框架接口函数失败可能是导致异常的原因。

禁止文件系统使用时间戳功能后(#define _FS_NORTC 1),一切恢复正常了。

 

转载于:https://www.cnblogs.com/emlslxl/p/7263987.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值