Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
外部flash
flashDB
20
FlashDB使用求助
发布于 2022-08-11 10:17:28 浏览:918
订阅该版
最近一个项目需要用到外部flash存储日志,我根据论坛这个帖子实现了flashdb的使用,我项目的需求要使用tsdb来存储日志,我想着把四个例程都跑一下,但是在运行时出问题了,麻烦大佬们帮我看看是不是有啥参数没配置对,,, https://club.rt-thread.org/ask/article/349aa10c2052cd40.html 代码段 `````c /* * Copyright (c) 2006-2021, RT-Thread Development Team * * SPDX-License-Identifier: Apache-2.0 * * Change Logs: * Date Author Notes * 2022-07-13 lenovo the first version */ #include
#include
#include
#include
#define FDB_LOG_TAG "flashdb" static uint32_t boot_count = 0; static time_t boot_time[10] = {0, 1, 2, 3}; /* default KV nodes */ static struct fdb_default_kv_node default_kv_table[] = { {"username", "armink", 0}, /* string KV */ {"password", "123456", 0}, /* string KV */ {"boot_count", &boot_count, sizeof(boot_count)}, /* int type KV */ {"boot_time", &boot_time, sizeof(boot_time)}, /* int array type KV */ }; /* KVDB object */ static struct fdb_kvdb kvdb = { 0 }; /* TSDB object */ struct fdb_tsdb _global_tsdb = { 0 }; /* counts for simulated timestamp */ static int counts = 0; extern void kvdb_basic_sample(fdb_kvdb_t kvdb); extern void kvdb_type_string_sample(fdb_kvdb_t kvdb); extern void kvdb_type_blob_sample(fdb_kvdb_t kvdb); extern void tsdb_sample(fdb_tsdb_t tsdb); static void lock(fdb_db_t db) { __disable_irq(); } static void unlock(fdb_db_t db) { __enable_irq(); } static fdb_time_t get_time(void) { /* Using the counts instead of timestamp. * Please change this function to return RTC time. */ return ++counts; } static int flashdb(void) { fdb_err_t result; #ifdef FDB_USING_KVDB { /* KVDB Sample */ struct fdb_default_kv default_kv; default_kv.kvs = default_kv_table; default_kv.num = sizeof(default_kv_table) / sizeof(default_kv_table[0]); /* set the lock and unlock function if you want */ fdb_kvdb_control(&kvdb, FDB_KVDB_CTRL_SET_LOCK, (void *)lock); fdb_kvdb_control(&kvdb, FDB_KVDB_CTRL_SET_UNLOCK, (void *)unlock); /* Key-Value database initialization * * &kvdb: database object * "env": database name * "fdb_kvdb1": The flash partition name base on FAL. Please make sure it's in FAL partition table. * Please change to YOUR partition name. * &default_kv: The default KV nodes. It will auto add to KVDB when first initialize successfully. * NULL: The user data if you need, now is empty. */ /* init函数的第三个参数,是用于存储数据的fal分区,大家根据自己的情况选择 */ result = fdb_kvdb_init(&kvdb, "env", "fdb_kvdb1", &default_kv, NULL); if (result != FDB_NO_ERR) { return -1; } else { /* 这部分例程在运行时会卡死 */ /* run basic KV samples */ kvdb_basic_sample(&kvdb); /* run string KV samples */ kvdb_type_string_sample(&kvdb); /* run blob KV samples */ kvdb_type_blob_sample(&kvdb); } } #endif /* FDB_USING_KVDB */ #ifdef FDB_USING_TSDB { /* TSDB Sample */ /* set the lock and unlock function if you want */ fdb_tsdb_control(&_global_tsdb, FDB_TSDB_CTRL_SET_LOCK, (void *)lock); fdb_tsdb_control(&_global_tsdb, FDB_TSDB_CTRL_SET_UNLOCK, (void *)unlock); /* Time series database initialization * * &tsdb: database object * "log": database name * "fdb_tsdb1": The flash partition name base on FAL. Please make sure it's in FAL partition table. * Please change to YOUR partition name. * get_time: The get current timestamp function. * 128: maximum length of each log * NULL: The user data if you need, now is empty. */ result = fdb_tsdb_init(&_global_tsdb, "log", "fdb_tsdb1", get_time, 128, NULL); /* read last saved time for simulated timestamp */ fdb_tsdb_control(&_global_tsdb, FDB_TSDB_CTRL_GET_LAST_TIME, &counts); if (result != FDB_NO_ERR) { return -1; } else{ /* run TSDB sample */ tsdb_sample(&_global_tsdb); } } #endif /* FDB_USING_TSDB */ return RT_EOK; } INIT_ENV_EXPORT(flashdb); ````` 原理图 ![Snipaste_2022-08-08_11-00-00.png](https://oss-club.rt-thread.org/uploads/20220811/5a6e4b7f4f9a9731565f9818815d89e8.png "Snipaste_2022-08-08_11-00-00.png") 运行截图1 ![kvdb_basic_sample.png](https://oss-club.rt-thread.org/uploads/20220811/e22b63e1059f2d1eae494ceeaacde919.png "kvdb_basic_sample.png") 运行截图2 ![kvdb_type_string_sample.png](https://oss-club.rt-thread.org/uploads/20220811/a8cda7ab9eef54fd6ec0d454d63659ba.png.webp "kvdb_type_string_sample.png") 运行截图3 ![kvdb_type_blob_sample.png](https://oss-club.rt-thread.org/uploads/20220811/9ab6a4974d3d3bf28f5ec454d75d4277.png.webp "kvdb_type_blob_sample.png") 运行截图4 ![tsdb_sample.png](https://oss-club.rt-thread.org/uploads/20220811/ad6a4600117e1d4e6a5a4c26e2598cdb.png.webp "tsdb_sample.png") 这个是录制的gif图 ![11211.gif](https://oss-club.rt-thread.org/uploads/20220811/f385d0e8a68b74d7caff695a66d7a8cd.gif "11211.gif") [cj_csjtarget.rar](https://club.rt-thread.org/file_download/9218486fd79c2de6)
查看更多
2
个回答
默认排序
按发布时间排序
张世争
2022-08-11
学以致用
- 可以把 FlashDB 的 断言功能打开,可能断言了,也就是 `FDB_ASSERT` 可以使用 `RT_ASSERT` - 注意下各个线程栈的情况,是否足够
abcde1224
2022-08-15
这家伙很懒,什么也没写!
问题解决了,sfud默认的频率是50Mhz,需要根据使用的flash修改spi最大速率的参数,我自己调整到了500k才正常工作了,注意这个速率在cubeMX配置spi接口时设置的那个分频是不起作用的,只有在这个地方修改才有效 ![spi速率修改.png](https://oss-club.rt-thread.org/uploads/20220815/f7b61365b4cea07f4ab39c83817fa3bc.png "spi速率修改.png") 再放一张正常运行的gif图 ![runok.gif](https://oss-club.rt-thread.org/uploads/20220815/043d748857a224ee93e8865a428e5020.gif "runok.gif")
撰写答案
登录
注册新账号
关注者
0
被浏览
918
关于作者
abcde1224
这家伙很懒,什么也没写!
提问
2
回答
5
被采纳
0
关注TA
发私信
相关问题
1
程序分散加载到外部QSPI FLASH 启动问题
2
stm32f429如何下载程序到外部flash
3
安卓手机不能识别挂载w25q flash
4
rtthread stlink加载外部算法问题
5
flashdb kv value的最大字节
6
关于F1使用通用BOOT+片外FLASH升级SFUD初始化失败的问题
7
文件系统挂载到指定内存区域
8
ART-Pi的APP运行在外部Flash,那还能对内部flash进行读写操作吗?
9
外部flash是nm25q128挂载不上有大神指点嘛
10
挂载外部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
freemodbus主机在freertos的适配,参考rtthread例程
2
开源共生 商业共赢 | RT-Thread 2024开发者大会议程正式发布!
3
【24嵌入式设计大赛】基于RT-Thread星火一号的智慧家居系统
4
RT-Thread EtherKit开源以太网硬件正式发布
5
还在担心bsp不好维护吗?快使用yml管理主线bsp
热门标签
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
ESP8266
I2C_IIC
WIZnet_W5500
UART
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
SFUD
msh
rt_mq_消息队列_msg_queue
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1443
个答案
289
次被采纳
张世争
805
个答案
174
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
148
次被采纳
本月文章贡献
出出啊
1
篇文章
4
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
1
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部