Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Kernel
【BUG】ulog多个backend后端输出日志时可能造成日志被截断
发布于 2019-04-29 14:16:54 浏览:1843
订阅该版
**问题描述:**我实现了多个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.8k
关于作者
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
NXP MCXN947测评(二)ETH设备使用
2
【RA8D1-Vision Board】适配 LVGL V8
3
VISION BOARD 第二弹 基础工程配置和点亮一个LED灯
4
musb移植问题记录【设备注册3次挂起】
5
关于使用CherryUSB时候使用外挂的usb phy 芯片配置的一点注意事项
热门标签
RT-Thread Studio
串口
LWIP
Env
SPI
Bootloader
AT
ART-Pi
Hardfault
CAN总线
FinSH
USB
文件系统
RT-Thread
DMA
SCons
线程
RT-Thread Nano
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
ota在线升级
WIZnet_W5500
I2C_IIC
UART
flash
cubemx
packages_软件包
freemodbus
潘多拉开发板_Pandora
PWM
定时器
ADC
BSP
中断
keil_MDK
编译报错
socket
MicroPython
GD32
msh
Debug
ulog
SDIO总线
SFUD
rt_mq_消息队列_msg_queue
C++_cpp
本月问答贡献
xiaorui
7
个答案
3
次被采纳
sakumisu
4
个答案
3
次被采纳
三世执戟
31
个答案
1
次被采纳
梦笑真美
18
个答案
1
次被采纳
踩姑娘的小蘑菇
14
个答案
1
次被采纳
本月文章贡献
Z_Y
2
篇文章
5
次点赞
Alipay
2
篇文章
3
次点赞
2345vor
2
篇文章
1
次点赞
比特饼干
1
篇文章
6
次点赞
Lu_盼盼
1
篇文章
3
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部