Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
easyflash
关于easyflash和easylog开启ELOG_BUF_OUTPUT_ENABLE和ELOG_FLASH_USING_BUF_MODE
发布于 2024-11-15 09:08:45 浏览:23
订阅该版
[tocm] elog_buf.c: ```c void elog_buf_output(const char *log, size_t size) { size_t write_size = 0, write_index = 0; if (!is_enabled) { elog_port_output(log, size); return; } while (true) { if (buf_write_size + size > ELOG_BUF_OUTPUT_BUF_SIZE) { write_size = ELOG_BUF_OUTPUT_BUF_SIZE - buf_write_size; memcpy(log_buf + buf_write_size, log + write_index, write_size); write_index += write_size; size -= write_size; /* output log */ elog_port_output(log_buf, ELOG_BUF_OUTPUT_BUF_SIZE); /* reset write index */ buf_write_size = 0; } else { memcpy(log_buf + buf_write_size, log + write_index, size); buf_write_size += size; break; } } } ``` elog_flash.c ```c /** * Write log to flash. The flash write use buffer mode. * * @param log log * @param size log size */ void elog_flash_write(const char *log, size_t size) { ... ... while (true) { if (cur_buf_size + size > ELOG_FLASH_BUF_SIZE) { write_size = ELOG_FLASH_BUF_SIZE - cur_buf_size; elog_memcpy(log_buf + cur_buf_size, log + write_index, write_size); write_index += write_size; size -= write_size; cur_buf_size += write_size; /* unlock flash log buffer */ log_buf_unlock(); /* write all buffered log to flash, cur_buf_size will reset */ elog_flash_flush(); /* lock flash log buffer */ log_buf_lock(); } else { elog_memcpy(log_buf + cur_buf_size, log + write_index, size); cur_buf_size += size; break; } } ... ... } ``` ## 疑问: 这里当缓存的buffer满之后去打印或者存储的处理,是不是会存在最后一条日志缺失的问题? elog_buf.c: ```c write_size = ELOG_BUF_OUTPUT_BUF_SIZE - buf_write_size; ``` elog_flash.c ```c write_size = ELOG_FLASH_BUF_SIZE - cur_buf_size; ``` 最后一条日志的write_size理论上永远比实际的size小,存在`size -= write_size`的字节被丢弃的问题。
查看更多
0
个回答
默认排序
按发布时间排序
暂无答案,快来添加答案吧
撰写答案
登录
注册新账号
关注者
0
被浏览
23
关于作者
邢雲子
这家伙很懒,什么也没写!
提问
4
回答
5
被采纳
0
关注TA
发私信
相关问题
1
easyflash 用来存储 传感器定时采样的数据适不适合?
2
easyflash存放于fat文件系统中,但是会擦除文件系统
3
EasyFlash移植失败,硬件发生错误?
4
easyflash demo擦写完数据后再上电就挂了?
5
easyflash初始化env无法自动写入默认环境变量?
6
有在STM32L4上用easyflash的么?请教个问题
7
[已解决] easyflash 使用内部 flash 无法保存参数
8
FAL 上的FlashDB、EasyFlash、EasyLogger调试经历
9
easyflash存储问题
10
easyflash可以用来存储300个小文件且能够按照日期分类检索吗?
推荐文章
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官方usb驱动之虚拟串口
2
RTduino物联网应用零基础入门
3
TinyUSB Demo运行教程
4
RT-Thread学习大礼包一键带走!
5
freemodbus从机调试说明
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
ART-Pi
FinSH
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
WIZnet_W5500
ota在线升级
UART
cubemx
PWM
flash
packages_软件包
freemodbus
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
rt_mq_消息队列_msg_queue
keil_MDK
ulog
C++_cpp
at_device
本月问答贡献
踩姑娘的小蘑菇
4
个答案
3
次被采纳
张世争
8
个答案
2
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
KunYi
5
个答案
1
次被采纳
rv666
3
个答案
1
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
4
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部