Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
ulog异步输出模式下,初始化LOG无法打印问题分析
发布于 2019-05-15 16:37:14 浏览:2147
订阅该版
* 本帖最后由 eric007 于 2019-5-15 16:34 编辑 * **问题描述:** [list=1] (*)在系统循环中无LOG_X打印时,在初始化过程调用LOG_X(...)打印的日志信息均未打印输出 (*)在系统循环中有LOG_X打印时,初始化过程的日志信息会和系统循环中的首次日志信息同时打印 [/list] **问题分析:** menuconfig中ulog配置如下 ![ulog.PNG](/uploads/201905/15/115819eei76v5eucc5v6ou.png) 通过调试,问题出在ulog线程在打印log信息之前,会将ulog.async_notice信号量进行清零操作(代码如下); ```void ulog_async_waiting_log(rt_int32_t time) { rt_sem_control(&ulog.async_notice, RT_IPC_CMD_RESET, RT_NULL); rt_sem_take(&ulog.async_notice, time); } static void async_output_thread_entry(void *param) { while (1) { ulog_async_waiting_log(RT_WAITING_FOREVER); ulog_async_output(); } }``` 而初始化过程日志信息刚开始无法被打印问题原因如下: [list=1] (*)ulog线程被调度之前,初始化过程的日志会被保存到ulog.async_rbb链表中,由ulog线程进行统一输出打印 (*)ulog线程首次调用ulog_async_waiting_log时,会将ulog.async_notice信号量清零,然后获取信号量造成线程被挂起,初始化日志得不到输出 (*)当系统再次进行日志输出时,ulog线程被唤醒,并将ulog.async_rbb链表上所有日志信息进行输出,即此时会将初始化日志一起打印输出 [/list] **解决方案:** 该问题有多种解决方法: 为了尽量不修改原有代码基础上,同时不降低效率的方法,个人觉得是将ulog_async_waiting_log函数中信号清零与获取先后顺序调换,如下 ```void ulog_async_waiting_log(rt_int32_t time) { rt_sem_take(&ulog.async_notice, time); rt_sem_control(&ulog.async_notice, RT_IPC_CMD_RESET, RT_NULL); }``` 若有不对之处,敬请批评指正。
查看更多
5
个回答
默认排序
按发布时间排序
Xiou
2019-05-15
这家伙很懒,什么也没写!
版主肯定会对你说 “PR”,有点奇怪,对于链表的遍历任务,为什么不用事件而是信号量。
armink
2019-05-16
这家伙很懒,什么也没写!
[attach]8689[/attach] 在这里增加个 ulog_async_output 试试好使吗
eric007
2019-05-16
这家伙很懒,什么也没写!
>在这里增加个 ulog_async_output 试试好使吗 --- 这种方法也试过,可以使用,就是让人觉得有些多余。 还有去掉信号量清零步骤也可以,但在一些情况下会造成没必要的循环+函数调用
armink
2019-05-16
这家伙很懒,什么也没写!
>这种方法也试过,可以使用,就是让人觉得有些多余。 >还有去掉信号量清零步骤也可以,但在一些情况下会造 ... --- 还好吧,那就这样改了
armink
2019-05-16
这家伙很懒,什么也没写!
[https://github.com/RT-Thread/rt-thread/pull/2694](https://github.com/RT-Thread/rt-thread/pull/2694) 已经发 pr 了,多谢反馈哈
撰写答案
登录
注册新账号
关注者
0
被浏览
2.1k
关于作者
eric007
这家伙很懒,什么也没写!
提问
4
回答
23
被采纳
0
关注TA
发私信
相关问题
1
有关动态模块加载的一篇论文
2
最近的调程序总结
3
晕掉了,这么久都不见layer2的踪影啊
4
继续K9ii的历程
5
[GUI相关] FreeType 2
6
[GUI相关]嵌入式系统中文输入法的设计
7
20081101 RT-Thread开发者聚会总结
8
嵌入式系统基础
9
linux2.4.19在at91rm9200 上的寄存器设置
10
[转]基于嵌入式Linux的通用触摸屏校准程序
推荐文章
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-Smart首次线下培训,锁定2024 RT-Thread开发者大会!
2
使用RC522软件包驱动FM1722
3
常量数据类型和表达式陷阱分享
4
进行i2c驱动移植的经验总结
5
在VSCode中使用clang-format
热门标签
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
UART
WIZnet_W5500
ota在线升级
freemodbus
PWM
flash
cubemx
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
中断
编译报错
Debug
SFUD
rt_mq_消息队列_msg_queue
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
踩姑娘的小蘑菇
4
个答案
1
次被采纳
红枫
4
个答案
1
次被采纳
张世争
4
个答案
1
次被采纳
Ryan_CW
4
个答案
1
次被采纳
xiaorui
1
个答案
1
次被采纳
本月文章贡献
catcatbing
3
篇文章
5
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
Woshizhapuren
1
篇文章
5
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部