littlefs 配置总结,填坑贴!

发布于 2019-09-05 21:02:29
    本帖最后由 xiaoxu5271 于 2019-9-5 21:13 编辑


首先是按照官方配置教程一路下来的 在 STM32L4 上应用 littlefs 文件系统
这些步骤是没有问题的,但是文中的littlels的版本比较老,如果使用最新版本,可能会有一些出入,参数就先按照默认配置。配置完成后出现3个坑,下面开始填坑。

(1)编译出错
这个是普遍问题,论坛搜索了一圈,发现好几个相同案例 这个帖子提出了解决办法

批注 2019-09-05 202426.png

加入头文件后,好家伙,还是有错误,如下:

(2)再次编译出错
linking...
.\build\keil\Obj\rt-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\rt-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

就是这个函数,好多,转到定义:


批注 2019-09-05 203541.png
明明有定义啊,索性就简单粗暴点,再重新声明下。

批注 2019-09-05 203653.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

定位到程序中,如下图

1.png

lfs->cfg->block_cycles 这个为 0 导致断言失败,上面注释提到,不再支持它等于0 ,应该在100-1000之间,它具体是干什么的,还暂未理解,有大佬知道的话希望能科普下。
那么这个值在哪里定义的?
就是下图这个值,原来是0,我改成的100。

批注 2019-09-05 205155.png


它对应的menuconfig 中的位置如图:

批注 2019-09-05 205347.png

这个默认是0,改为100后就正常了,如下是测试的效果:

批注 2019-09-05 205854.png

lfs error:1127: Corrupted dir pair at 0 1
应该是说明有坏块,但不影响整体测试,这个等再查查是什么原因导致的。


查看更多

关注者
0
被浏览
2.5k
5 个回答
dufanbao
dufanbao 2019-11-18
block_cycles 定义均衡擦写的循环次数,防止某一个Block擦写次数过多导致损坏
Hu_XianShen
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 有说到:
921742079
921742079 2020-01-26
国际哥 发表于 2019-12-7 15:23
lfs error:1127: Corrupted dir pair at 0 1 在第一次运行出现是正常的,格式化之后应该就不会有了,好像这 ...


一旦mkdir就挂了,需要重新格式化,然后mount,每次格式化然后重新mount,就会提示这个Corrupted dir pair at 0 1

撰写答案

请登录后再发布答案,点击登录

发布
问题

分享
好友