Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Kernel
【BUG】ulog多个backend后端输出日志时可能造成日志被截断
发布于 2019-04-29 14:16:54 浏览:1863
订阅该版
**问题描述:**我实现了多个ulog后端,如uart串口,spi-nor flash和nand flash,并且系统支持ULOG_USING_COLOR。Uart后端支持support_color,但是spi-nor flash和nand flash作为日志的永久存储介质不支持support_color。后端注册顺序为:uart->spi-nor flash->nand flash。当输出日志时,发现nand flash里存储的每一条日志前后都被截断了,走查代码发现ulog_output_to_all_backend()函数里存在BUG,源代码如下(版本3.1.1): ![捕获.JPG](/uploads/201904/29/140553l31rkqhk7r175z66.jpg) 当日志输出到uart后端时,由于支持support_color,所以代码走402行分支; 当日志输出到spi-nor flash后端时,由于不支持support_color,代码走else分支,412行和413行修改了入参log指针和日志长度size; 当日志输出到nand-flash后端时,同样走else分支,但是log和size变量已经被修改了,log已经不包含color信息,但在此基础上又执行了一次头尾截断,所以造成输出到nand flash里的日志头尾被截断了。 **解决方法:**在遍历所有后端时,增加两个临时变量保存入参log和size,在不支持support_color的分支里对临时变量进行修改,不修改原入参变量。
查看更多
7
个回答
默认排序
按发布时间排序
armink
2019-04-29
这家伙很懒,什么也没写!
楼主分析的很仔细,方便提交 pr 并修正吗?
armink
2019-04-29
这家伙很懒,什么也没写!
另外,关于 flash log 功能,有个将日志存储至 flash 的软件包,不知道你用过没有 [http://packages.rt-thread.org/itemDetail.html?package=ulog_easyflash](http://packages.rt-thread.org/itemDetail.html?package=ulog_easyflash)
walen918
2019-04-30
这家伙很懒,什么也没写!
>另外,关于 flash log 功能,有个将日志存储至 flash 的软件包,不知道你用过没有 > >http://packages.rt-thr ... --- 你好,我看过你写的easyflash,很棒,我没有使用过,我用的是我们自己的flash驱动。另外,不知道RTT的patch如何提交,我先提出问题,如果官方能修复就很好了,如果没有修复我再找时间提交吧
armink
2019-05-01
这家伙很懒,什么也没写!
RT-Thread 也希望更多的开发者能加入进来,共同为我们的 OS 添砖加瓦。 这个问题应该好改,你可以先试试,直接在 GitHub 上就能修改并发起 pr ,我们这里也有一份教程,可以参考下:[https://www.rt-thread.org/document/site/development-guide/github/github/](https://www.rt-thread.org/document/site/development-guide/github/github/)
z843757475
2019-07-30
这家伙很懒,什么也没写!
你好 请问你试过 ulog输出后端 改成文件系统吗
armink
2019-07-31
这家伙很懒,什么也没写!
>你好 请问你试过 ulog输出后端 改成文件系统吗 --- 可以自己先实现哦
hongsenlin
2021-08-18
这家伙很懒,什么也没写!
我也碰到了这个问题,保存到文件中出了好多乱码。还没更新吗?
撰写答案
登录
注册新账号
关注者
0
被浏览
1.9k
关于作者
walen918
这家伙很懒,什么也没写!
提问
1
回答
1
被采纳
0
关注TA
发私信
相关问题
1
cpu使用率分析
2
选择FreeRTOS, 还是RT-Thread。
3
thread heap stack overflow ?
4
rtt消息队列delay问题
5
释放被删除线程的内存地方在哪里啊
6
请教:各线程结束后,释放其中的内存的连续性问题
7
STM32F103中断关于信号量、邮箱问题
8
RTT中的线程栈大小如何控制
9
关于线程由执行态变为挂起态的代码实现,,,
10
rt_malloc(rt_size_t size)内存分配函数最小分配尺寸问题
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
机器人操作系统 (ROS2) 和 RT-Thread 通信
4
国产MCU移植系列教程汇总,欢迎查看!
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 挂载romfs与ramfs
2
[Vision Board创客营]使用openmv识别阿尼亚
3
smart启动流程详解
4
小内存管理(1)--- 内存初始化
5
spi自动初始化程序
热门标签
RT-Thread Studio
串口
LWIP
Env
SPI
Bootloader
AT
ART-Pi
Hardfault
CAN总线
FinSH
USB
文件系统
DMA
RT-Thread
SCons
线程
RT-Thread Nano
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
ota在线升级
WIZnet_W5500
I2C_IIC
UART
flash
cubemx
packages_软件包
freemodbus
PWM
潘多拉开发板_Pandora
定时器
BSP
ADC
中断
flashDB
编译报错
socket
keil_MDK
GD32
msh
Debug
SFUD
MicroPython
ulog
SDIO总线
rt_mq_消息队列_msg_queue
本月问答贡献
小小李sunny
4
个答案
3
次被采纳
a1012112796
3
个答案
2
次被采纳
聚散无由
1
个答案
2
次被采纳
用户名由3_15位
4
个答案
1
次被采纳
aeniac
3
个答案
1
次被采纳
本月文章贡献
zhuzhuzhu
1
篇文章
4
次点赞
聚散无由
1
篇文章
3
次点赞
踩姑娘的小蘑菇
1
篇文章
2
次点赞
Hlafklio
1
篇文章
2
次点赞
YDPB_5935
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部