Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
littlefs
10
关于littlefs中,读取文件数据错误
发布于 2021-10-29 13:42:18 浏览:1475
订阅该版
```c #include
#include
#include "main.h" #define W25QXX_CS_SET HAL_GPIO_WritePin(SPI1_CS_GPIO_Port,SPI1_CS_Pin,GPIO_PIN_SET); //W25QXXµÄƬѡÐźŲ»Ñ¡Í¨ #define W25QXX_CS_RESET HAL_GPIO_WritePin(SPI1_CS_GPIO_Port,SPI1_CS_Pin,GPIO_PIN_RESET); //W25QXXµÄƬѡÐźŲ»Ñ¡Í¨ osMutexId SPIMutexHandle; static char log_buf[256]; void sfud_log_debug(const char *file, const long line, const char *format, ...); /** * SPI write data then read data */ static sfud_err spi_write_read(const sfud_spi *spi,uint8_t *write_buf, size_t write_size, uint8_t *read_buf, size_t read_size) { sfud_err result = SFUD_SUCCESS; if (write_size) SFUD_ASSERT(write_buf); if (read_size) SFUD_ASSERT(read_buf); /* µÍµçƽÐźÅʹÄÜCSÒý½Å */ W25QXX_CS_RESET; /* ¿ªÊ¼¶ÁдÊý¾Ý */ if(read_size && write_size) { if( HAL_OK != HAL_SPI_Transmit(&hspi1, (uint8_t *)write_buf, write_size, 1000) ) result = SFUD_ERR_TIMEOUT; if( HAL_OK != HAL_SPI_Receive(&hspi1, (uint8_t *)read_buf, read_size, 1000) ) result = SFUD_ERR_TIMEOUT; } else if (write_size) { if( HAL_OK != HAL_SPI_Transmit(&hspi1, (uint8_t *)write_buf, write_size, 1000) ) result = SFUD_ERR_TIMEOUT; } else { if( HAL_OK != HAL_SPI_Receive(&hspi1, (uint8_t *)read_buf, read_size, 1000) ) result = SFUD_ERR_TIMEOUT; } /* ¸ßµçƽÐźÅʧÄÜCSÒý½Å */ W25QXX_CS_SET; return result; } static void spi_lock(const sfud_spi *spi) { osMutexWait(SPIMutexHandle, portMAX_DELAY); } static void spi_unlock(const sfud_spi *spi) { osMutexRelease(SPIMutexHandle); } /* about 100 microsecond delay */ static void retry_delay_100us(void) { DWT_Delay_us(100); } sfud_err sfud_spi_port_init(sfud_flash *flash) { sfud_err result = SFUD_SUCCESS; osMutexDef(spiMutex); SPIMutexHandle = osMutexCreate(osMutex(spiMutex)); /* ͬ²½ Flash ÒÆÖ²ËùÐèµÄ½Ó¿Ú¼°Êý¾Ý */ flash->spi.wr = spi_write_read; flash->spi.lock = spi_lock; flash->spi.unlock = spi_unlock; /* about 100 microsecond delay */ flash->retry.delay = retry_delay_100us; /* adout 60 seconds timeout */ flash->retry.times = 60 * 10000; return result; } /** * This function is print debug info. * * @param file the file which has call this function * @param line the line number which has call this function * @param format output format * @param ... args */ void sfud_log_debug(const char *file, const long line, const char *format, ...) { va_list args; /* args point to the first variable parameter */ va_start(args, format); printf("[SFUD](%s:%ld) ", file, line); /* must use vprintf to print */ vsnprintf(log_buf, sizeof(log_buf), format, args); printf("%s\r\n", log_buf); va_end(args); } /** * This function is print routine info. * * @param format output format * @param ... args */ void sfud_log_info(const char *format, ...) { va_list args; /* args point to the first variable parameter */ va_start(args, format); printf("[SFUD]"); /* must use vprintf to print */ vsnprintf(log_buf, sizeof(log_buf), format, args); printf("%s\r\n", log_buf); va_end(args); } ``` 之前在RTT里使用没有任何问题,现在换了FREERTOS,将littlefs移植过来之后,写文件没有出现过问题,但是读文件时会出现文件命名还有数据,读出来的数据长度是0,或者读出的数据出现很多0xff,此时retry_time之后,查询spi总线状态,发现一直处于busy。
查看更多
3
个回答
默认排序
按发布时间排序
出出啊
2021-10-29
恃人不如自恃,人之为己者不如己之自为也
哦,那就换回 rtt 嘛。 可能是引脚配置出问题了,底层驱动不工作了
宋策_0114
2021-10-29
这家伙很懒,什么也没写!
**问题已解决** 原因:在A线程读文件过程中,B线程又执行了打开路径或打开文件等命令,导致lfs_t *lfs和lfs_file_t *file变量重新被赋值,从而A线程读过程中出错。
风来吴山
2022-01-01
这家伙很懒,什么也没写!
littlefs有个sync的同步,实现它。
撰写答案
登录
注册新账号
关注者
0
被浏览
1.5k
关于作者
宋策_0114
这家伙很懒,什么也没写!
提问
2
回答
3
被采纳
0
关注TA
发私信
相关问题
1
dfs_mount挂载文件系统路径的路径必须为‘/’才能成功
2
romfs无法执行df命令
3
w25q128挂载littlefs出现assert failed?
4
使用littlefs出现Corrupted dir pair at 1 0
5
使用片上flash的 littlefs 无法创建多个目录
6
littlefs挂载总是在lfs.c文件中 LFS_ASSERT
7
littlefs文件系统卡顿问题
8
需要littlefs 挂载在片上flash
9
日志存储是使用fat如何做磨损平衡?
10
挂载littlefs文件系统的flash寿命计算方式?
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
Rt-thread中OTA下载后,bootloader不搬程序
2
ulog 日志 LOG_HEX 输出时间改为本地日期时间
3
在RT-Thread Studio中构建前执行python命令
4
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
5
CherryUSB开发笔记(一):FSDEV USB IP核的 HID Remote WakeUp (USB HID 远程唤醒) 2025-01-18 V1.1
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
I2C_IIC
ESP8266
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
xusiwei1236
5
个答案
2
次被采纳
踩姑娘的小蘑菇
1
个答案
2
次被采纳
用户名由3_15位
7
个答案
1
次被采纳
bernard
4
个答案
1
次被采纳
张世争
1
个答案
1
次被采纳
本月文章贡献
聚散无由
2
篇文章
15
次点赞
catcatbing
2
篇文章
5
次点赞
Wade
2
篇文章
2
次点赞
Ghost_Girls
1
篇文章
6
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部