Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Filesystem
littlefs 配置总结,填坑贴!
发布于 2019-09-05 21:02:29 浏览:9009
订阅该版
* 本帖最后由 xiaoxu5271 于 2019-9-5 21:13 编辑 * 首先是按照官方配置教程一路下来的 [在 STM32L4 上应用 littlefs 文件系统](https://www.rt-thread.org/document/site/application-note/components/dfs/an0027-littlefs/) 。 这些步骤是没有问题的,但是文中的littlels的版本比较老,如果使用最新版本,可能会有一些出入,参数就先按照默认配置。配置完成后出现3个坑,下面开始填坑。 **(1)编译出错** 这个是普遍问题,论坛搜索了一圈,发现好几个相同案例 [这个帖子提出了解决办法](https://www.rt-thread.org/qa/forum.php?mod=viewthread&tid=10483&highlight=littlefs)。 ![批注 2019-09-05 202426.png](/uploads/201909/05/210701vvfotbfh88bt01dv.png) 加入头文件后,好家伙,还是有错误,如下: **(2)再次编译出错** ```linking... .\build\keil\Obj t-thread.axf: Error: L6218E: Undefined symbol LFS_TRACE (referred from lfs.o). Not enough information to list image symbols. Not enough information to list load addresses in the image map. Finished: 2 information, 0 warning and 1 error messages. ".\build\keil\Obj t-thread.axf" - 1 Error(s), 30 Warning(s). Target not created. Build Time Elapsed: 00:00:05```这个错误的意思是 LFS_TRACE 这个函数 在lfs.c中没有被声明,搞他! ![批注 2019-09-05 203515.png](/uploads/201909/05/210750tofx1b1c7r6f7zcx.png) 就是这个函数,好多,转到定义: ![批注 2019-09-05 203541.png](/uploads/201909/05/210933omogmsc1ng67m77g.png) 明明有定义啊,索性就简单粗暴点,再重新声明下。 ![批注 2019-09-05 203653.png](/uploads/201909/05/211046k6e6tsztopfeuhhf.png) ```/* * The little filesystem * * Copyright (c) 2017, Arm Limited. All rights reserved. * SPDX-License-Identifier: BSD-3-Clause */ #include "lfs_util.h" #include "lfs.h" #define LFS_TRACE(fmt, ...) //lcx add 2019-09-05 20:33:01 在这里重新定义下 #define LFS_BLOCK_NULL ((lfs_block_t)-1) #define LFS_BLOCK_INLINE ((lfs_block_t)-2)``` 再编译,好了,不报错了,,可是。。。 **(3)初始化失败** ![未命名图片.png](/uploads/201909/05/211154nhuhhe6ah9hw0ahn.png) 定位到程序中,如下图 ![1.png](/uploads/201909/05/211224pxdkx19yjybcjk2v.png) lfs->cfg->block_cycles 这个为 0 导致断言失败,上面注释提到,不再支持它等于0 ,应该在100-1000之间,它具体是干什么的,还暂未理解,有大佬知道的话希望能科普下。 那么这个值在哪里定义的? 就是下图这个值,原来是0,我改成的100。 ![批注 2019-09-05 205155.png](/uploads/201909/05/211242gc9gs4x5sgx6c8g5.png) 它对应的menuconfig 中的位置如图: ![批注 2019-09-05 205347.png](/uploads/201909/05/211323nx6x3nl1zexzichn.png) 这个默认是0,改为100后就正常了,如下是测试的效果: ![批注 2019-09-05 205854.png](/uploads/201909/05/205910zc83poox3po5cqqw.png) lfs error:1127: Corrupted dir pair at 0 1 应该是说明有坏块,但不影响整体测试,这个等再查查是什么原因导致的。
查看更多
5
个回答
默认排序
按发布时间排序
aozima
2019-09-05
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
谢谢楼主分享
dufanbao
2019-11-18
这家伙很懒,什么也没写!
block_cycles 定义均衡擦写的循环次数,防止某一个Block擦写次数过多导致损坏
Hu_XianShen
2019-12-06
这家伙很懒,什么也没写!
\ | / - RT - Thread Operating System / | \ 4.0.2 build Dec 6 2019 2006 - 2019 Copyright by rt-thread team [D/FAL] (fal_flash_init:61) Flash device | onchip_flash_16k | addr: 0x08000000 | len: 0x00080000 | blk_size: 0x00004000 |initialized finish. [I/FAL] ==================== FAL partition table ==================== [I/FAL] | name | flash_dev | offset | length | [I/FAL] ------------------------------------------------------------- [I/FAL] | filesystem1 | onchip_flash_16k | 0x00000000 | 0x00010000 | [I/FAL] | filesystem2 | onchip_flash_16k | 0x00010000 | 0x00010000 | [I/FAL] | filesystem3 | onchip_flash_16k | 0x00020000 | 0x00020000 | [I/FAL] | filesystem | onchip_flash_16k | 0x00040000 | 0x00040000 | [I/FAL] ============================================================= [I/FAL] RT-Thread Flash Abstraction Layer (V0.4.0) initialize success. [I/FAL] The FAL MTD NOR device (filesystem) created successfully lfs error:968: Corrupted dir pair at 0 1 [E/main] ret:-12 lfs error:968: Corrupted dir pair at 0 1 [E/main] Failed to initialize filesystem! msh />echo "aaa" a.txt open file:a.txt failed! msh />ls No such directory msh /> 楼主有继续查找错误吗?我的格式化文件系统和挂载都失败!文件系统不能用!用的STM32F2
国际哥
2019-12-07
这家伙很懒,什么也没写!
lfs error:1127: Corrupted dir pair at 0 1 在第一次运行出现是正常的,格式化之后应该就不会有了,好像这个 issue 有说到:[https://github.com/ARMmbed/littlefs/issues/206](https://github.com/ARMmbed/littlefs/issues/206)
921742079
2020-01-26
这家伙很懒,什么也没写!
>lfs error:1127: Corrupted dir pair at 0 1 在第一次运行出现是正常的,格式化之后应该就不会有了,好像这 ... --- 一旦mkdir就挂了,需要重新格式化,然后mount,每次格式化然后重新mount,就会提示这个Corrupted dir pair at 0 1
撰写答案
登录
注册新账号
关注者
0
被浏览
9k
关于作者
xiaoxu5271
这家伙很懒,什么也没写!
提问
3
回答
6
被采纳
0
关注TA
发私信
相关问题
1
字库除了SD卡和http还有别的方式导入吗
2
如何同时使用RTT文件系统于NAND Flash 和 SD卡,针对Realboard4088?
3
EasyFlash好棒
4
SD卡挂在的SPI总线又要加个DA设备
5
sd卡与flash 同时挂载 挂载路径shell怎么区分 访问
6
请教ramfs使用方法
7
rtt stable2.0.x版本 sd卡及文件系统
8
nandflash文件系统UFFS请教
9
关于SD卡挂载文件系统的问题(已解决)
10
Yaffs采用GPL2许可
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
机器人操作系统 (ROS2) 和 RT-Thread 通信
4
五分钟玩转RT-Thread新社区
5
国产MCU移植系列教程汇总,欢迎查看!
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
musb移植问题记录【设备注册3次挂起】
2
关于使用CherryUSB时候使用外挂的usb phy 芯片配置的一点注意事项
3
【Vision Board 创客营】Vision Board上的ADC实践
4
FRDM-MCXN947 & RT-Thread的CAN实践——控制GM6020云台电机
5
[Vision Board创客营]WDT实践之配置、issue、PR一条龙
热门标签
RT-Thread Studio
串口
LWIP
Env
SPI
Bootloader
AT
ART-Pi
CAN总线
Hardfault
FinSH
USB
文件系统
RT-Thread
DMA
SCons
线程
RT-Thread Nano
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
ota在线升级
WIZnet_W5500
I2C_IIC
UART
flash
cubemx
packages_软件包
freemodbus
潘多拉开发板_Pandora
PWM
定时器
ADC
BSP
中断
keil_MDK
编译报错
socket
MicroPython
GD32
msh
Debug
ulog
SDIO总线
SFUD
rt_mq_消息队列_msg_queue
C++_cpp
本月问答贡献
xiaorui
7
个答案
3
次被采纳
sakumisu
4
个答案
3
次被采纳
三世执戟
31
个答案
1
次被采纳
梦笑真美
18
个答案
1
次被采纳
踩姑娘的小蘑菇
14
个答案
1
次被采纳
本月文章贡献
Z_Y
2
篇文章
5
次点赞
Alipay
2
篇文章
3
次点赞
2345vor
2
篇文章
1
次点赞
比特饼干
1
篇文章
6
次点赞
Lu_盼盼
1
篇文章
3
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部