Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
ulog输出不了信息?
发布于 2019-02-18 15:08:15 浏览:2500
订阅该版
* 本帖最后由 viyjk99 于 2019-2-18 15:10 编辑 * 1、用的bsp包中stm32f20x 2、rtconfig中配置如下: ```/* Utilities */ #define RT_USING_RYM #define RT_USING_ULOG #define ULOG_OUTPUT_LVL_D #define ULOG_OUTPUT_LVL 7 #define ULOG_ASSERT_ENABLE #define ULOG_LINE_BUF_SIZE 356 /* log format */ #define ULOG_USING_COLOR #define ULOG_OUTPUT_TIME #define ULOG_OUTPUT_LEVEL #define ULOG_OUTPUT_TAG #define ULOG_BACKEND_USING_CONSOLE #define ULOG_SW_VERSION_NUM 0x00101```3、keil工程中添加:ulog.c、console_be.c 4、在使用ulog的源文件中添加: ```#define LOG_TAG "at.gps" #define LOG_LVL LOG_LVL_DBG #define DBG_ENABLE #define DBG_COLOR #ifndef LOG_TAG #define DBG_SECTION_NAME "at" #else #define DBG_SECTION_NAME LOG_TAG #endif /* LOG_TAG */ #ifdef AT_DEBUG #define DBG_LEVEL DBG_LOG #else #define DBG_LEVEL DBG_INFO #endif /* AT_DEBUG */ #include
```5、使用:```application.c中添加: void rt_init_thread_entry(void *parameter) { #ifdef RT_USING_ULOG ulog_init(); #endif ......... } gnss.c中添加 LOG_D("gnss_rx:%s", rx_buf);``` 6、编译通过 7、在console调试串口usart1中未输出 是还有什么地方没设置好吗?
查看更多
13
个回答
默认排序
按发布时间排序
misonyo
2019-02-18
这家伙很懒,什么也没写!
楼主,建议使用bsp/stm32 目录下的BSP,添加ULOG请使用ENV添加,不要手动添加,请参考文档:[https://www.rt-thread.org/document/site/programming-manual/ulog/ulog/](https://www.rt-thread.org/document/site/programming-manual/ulog/ulog/)
armink
2019-02-18
这家伙很懒,什么也没写!
直接跑这个 例子 呢?[https://github.com/RT-Thread/rt-thread/blob/master/examples/ulog/ulog_example.c](https://github.com/RT-Thread/rt-thread/blob/master/examples/ulog/ulog_example.c)
armink
2019-02-18
这家伙很懒,什么也没写!
[i=s] 本帖最后由 armink 于 2019-2-18 17:16 编辑 [/i] [md]你写的宏太多了 直接使用 ``[/md] ``` #define LOG_TAG "gsm" #define LOG_LVL LOG_LVL_DBG #include
LOG_D("I am debug log"); ```
viyjk99
2019-02-19
这家伙很懒,什么也没写!
1、用ENV添加了 ``` /* Utilities */ #define RT_USING_LOGTRACE #define LOG_TRACE_MAX_SESSION 16 #define LOG_TRACE_USING_LEVEL_INFO #define RT_USING_RYM #define RT_USING_ULOG #define ULOG_OUTPUT_LVL_D #define ULOG_OUTPUT_LVL 7 #define ULOG_ASSERT_ENABLE #define ULOG_LINE_BUF_SIZE 128 #define ULOG_USING_ASYNC_OUTPUT #define ULOG_ASYNC_OUTPUT_BUF_SIZE 2048 #define ULOG_ASYNC_OUTPUT_BY_THREAD #define ULOG_ASYNC_OUTPUT_THREAD_STACK 1024 #define ULOG_ASYNC_OUTPUT_THREAD_PRIORITY 30 /* log format */ #define ULOG_USING_COLOR #define ULOG_OUTPUT_TIME #define ULOG_OUTPUT_LEVEL #define ULOG_OUTPUT_TAG #define ULOG_BACKEND_USING_CONSOLE #define ULOG_SW_VERSION_NUM 0x00101 ``` 2、宏替换成: ``` #define LOG_TAG "gsm" #define LOG_LVL LOG_LVL_DBG #include
``` 3、直接跑例子 [https://github.com/RT-Thread/rt- ... ulog/ulog_example.c](https://github.com/RT-Thread/rt- ... ulog/ulog_example.c) 还是不行......
armink
2019-02-19
这家伙很懒,什么也没写!
直接在 qemu 里用 ulog_example.c 跑呢 也可以单步进入 LOG_D 函数看看哪里退出了
viyjk99
2019-02-19
这家伙很懒,什么也没写!
单步后发现在这里 ``` void ulog_output_to_all_backend(rt_uint32_t level, const char *tag, rt_bool_t is_raw, const char *log, rt_size_t size) { rt_slist_t *node; ulog_backend_t backend; if (!ulog.init_ok) return; /* output for all backends */ for (node = rt_slist_first(&ulog.backend_list); node; node = rt_slist_next(node)) { backend = rt_slist_entry(node, struct ulog_backend, list); #if !defined(ULOG_USING_COLOR) || defined(ULOG_USING_SYSLOG) backend->output(backend, level, tag, is_raw, log, size); #else if (backend->support_color) { backend->output(backend, level, tag, is_raw, log, size); } else { /* recalculate the log start address and log size when backend not supported color */ rt_size_t color_info_len = rt_strlen(color_output_info[level]); if (color_info_len) { rt_size_t color_hdr_len = rt_strlen(CSI_START) + color_info_len; log += color_hdr_len; size -= (color_hdr_len + (sizeof(CSI_END) - 1)); } backend->output(backend, level, tag, is_raw, log, size); } #endif /* !defined(ULOG_USING_COLOR) || defined(ULOG_USING_SYSLOG) */ } } ``` 进不了for循环,也就是说,没有指定backends rtconfig.h种有指定 #define ULOG_BACKEND_USING_CONSOLE 还有哪里设置没正确?
viyjk99
2019-02-19
这家伙很懒,什么也没写!
解决了。 把初始化函数从 ulog_init(); 修改为: ulog_console_backend_init();
armink
2019-02-19
这家伙很懒,什么也没写!
开启组件自动初始化
viyjk99
2019-02-19
这家伙很懒,什么也没写!
是的,应该是用的BSP包中模板还不完善。 遇到问题解决,对RTT又熟悉一点了。
armink
2019-02-19
这家伙很懒,什么也没写!
>是的,应该是用的BSP包中模板还不完善。 > >遇到问题解决,对RTT又熟悉一点了。 ... --- 哪个 BSP 呢
撰写答案
登录
注册新账号
关注者
0
被浏览
2.5k
关于作者
viyjk99
这家伙很懒,什么也没写!
提问
12
回答
20
被采纳
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
STM32H7R7运行CherryUSB
2
RT-Smart首次线下培训,锁定2024 RT-Thread开发者大会!
3
使用RC522软件包驱动FM1722
4
常量数据类型和表达式陷阱分享
5
进行i2c驱动移植的经验总结
热门标签
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
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部