Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
PM电源管理
功耗调优
RT-Thread精通PM功耗调优 - 专用LOG篇
发布于 2020-11-30 09:15:34 浏览:1612
订阅该版
[tocm] [RT-Thread 电源管理与功耗调优系列 - 目录](https://club.rt-thread.org/ask/article/3419.html) [RT-Thread精通PM功耗调优 - 思想篇](https://club.rt-thread.org/ask/article/2296.html) [RT-Thread精通PM功耗调优 - lptimer篇](https://club.rt-thread.org/ask/article/2300.html) [RT-Thread精通PM功耗调优 - 引脚篇](https://club.rt-thread.org/ask/article/2304.html) [RT-Thread精通PM功耗调优 - 线程篇](https://club.rt-thread.org/ask/article/2305.html) [RT-Thread精通PM功耗调优 - 外设篇](https://club.rt-thread.org/ask/article/2307.html) [RT-Thread精通PM功耗调优 - Tickless篇](https://club.rt-thread.org/ask/article/2324.html) [RT-Thread精通PM功耗调优 - 专用LOG篇](https://club.rt-thread.org/ask/article/2338.html) [实践:RT-Thread PM管理实战 系列](https://club.rt-thread.org/ask/article/2282.html) [上手:产品功耗管理与调优经验分享 系列](https://club.rt-thread.org/ask/article/2707.html) [应用:PM组件应用与经验分享 系列](https://club.rt-thread.org/ask/article/292.html) 本篇主要讲解PM专用LOG的实现方法。 ## 前言 * 当系统拥有文件系统后,可以把日志信息、错误信息、功耗管理(电池电量等),打印到文件,这样,利于问题的分析。 * 使用ulog组件,发现,LOG_D LOG_I等,默认只能打印到串口,不能打印到文件,用于永久保存。 * 开发ulog打印信息到文件的接口文件。 * 实现ulog打印信息到专用LOG文件的功能。 ## 介绍 什么是PM专用的LOG文件? * 专门周期性的记录电池电量、电源模式等信息的日志文件。【文件】【专属】,其他的LOG信息,不能写这个文件。 * 示例:LOG_D、LOG_I等,写到sys.log文件,LOG_PM,写到pm.log文件。 ## 实现方法 * 这个功能,是接触过的一个项目里实现的,通过修改ulog组件,增加log_id的属性,通过适配file_be,实现log信息写到文件的功能。 * 通过定义log文件大小、文件个数等属性,实现log文件的管理,如循环写入,而不是一直写一个文件(频繁的日志,时间久了,文件超大!)。 ## 验证Demo: 这里基于STM32L4 pandora,SPI Flash文件系统。 ```c https://gitee.com/zhangsz0516/rtt_pm_log /* 测试代码: LOG_PM */ void pms_log_dump(void *param) { g_pms_log_info.deepsleep_ticks = 15 * 1000; g_pms_log_info.power = 100; g_pms_log_info.voltage = 3800; g_pms_log_info.display_time += 5; g_pms_log_info.module_status = rt_pm_module_get_status(); g_pms_log_info.sleep_mode = rt_pm_get_sleep_mode(); LOG_PM(",%d,%d,%d,%d,%d,0x%x,%d", g_pms_log_info.power, g_pms_log_info.voltage, g_pms_log_info.deepsleep_ticks, g_pms_log_info.wakeup_cnt, g_pms_log_info.display_time, g_pms_log_info.module_status, g_pms_log_info.sleep_mode); } msh /log>ls Directory /log: pm.log 77149 //PM功耗专属 LOG文件,使用LOG_PM打印的 sys.log 15229 //系统的LOG文件,如通过LOG_D LOG_E等打印的。 ``` 具体的实现参考Demo。这里列举一下基本的实现方法: ### 定义LOG 文件的ID,在:ulog_def.h中 ```c enum _LOG_ID { LOG_SYS_ID = 0x00, LOG_PM_ID, LOG_MAX_ID, }; /* LOG_D LOG_I LOG_PM等宏定义【实现部分】,增加LOG_ID属性,对于用户,不关心 */ #if (LOG_LVL >= LOG_LVL_DBG) && (ULOG_OUTPUT_LVL >= LOG_LVL_DBG) #define ulog_d(LOG_ID, TAG, ...) ulog_output(LOG_ID, LOG_LVL_DBG, TAG, RT_TRUE, __VA_ARGS__) #else #define ulog_d(LOG_ID, TAG, ...) #endif /* (LOG_LVL >= LOG_LVL_DBG) && (ULOG_OUTPUT_LVL >= LOG_LVL_DBG) */ struct ulog_frame { /* magic word is 0x10 ('lo') */ rt_uint32_t magic:8; rt_uint32_t is_raw:1; rt_uint32_t log_len:23; rt_uint32_t level; rt_uint8_t id; /* 增加ID属性 */ const char *log; const char *tag; }; typedef struct ulog_frame *ulog_frame_t; struct ulog_backend { char name[RT_NAME_MAX]; rt_bool_t support_color; void (*init) (struct ulog_backend *backend); void (*output)(struct ulog_backend *backend, rt_uint8_t log_id, rt_uint32_t level, const char *tag, rt_bool_t is_raw, const char *log, size_t len); //增加log_id属性 void (*flush) (struct ulog_backend *backend); void (*deinit)(struct ulog_backend *backend); rt_slist_t list; }; ``` 作用就是标识log类型的,如系统log,pm功耗log。 ### 扩展ulog组件,ulog.h ulog.h实现函数,都增加log_id属性。 ```c //ulog.h中,全部增加LOG_ID的属性。通用的LOG_D、LOG_I等,区别于LOG_PM等新定义的。 #define LOG_E(...) ulog_e(LOG_SYS_ID, LOG_TAG, __VA_ARGS__) #define LOG_W(...) ulog_w(LOG_SYS_ID, LOG_TAG, __VA_ARGS__) #define LOG_I(...) ulog_i(LOG_SYS_ID, LOG_TAG, __VA_ARGS__) #define LOG_D(...) ulog_d(LOG_SYS_ID, LOG_TAG, __VA_ARGS__) #define LOG_RAW(...) ulog_raw(LOG_SYS_ID, __VA_ARGS__) #define LOG_HEX(name, width, buf, size) ulog_hex(LOG_SYS_ID, name, width, buf, size) #define LOG_PM(...) LOG_PM_OUTPUT(LOG_PM_ID, LOG_TAG, __VA_ARGS__) ``` ### file.be实现ulog to file ```c struct _log_file { const rt_uint8_t id; rt_int32_t file_fd; const char *root_path; const char *log_path; const char *log_name; const char *file_type; const rt_uint32_t file_size; const rt_uint32_t file_num; }; static struct _log_file _log_file_tbl[] = { { LOG_SYS_ID, -1, "/", "/log/", "sys", ".log", 512 * 1024, 10 }, /* 系统的LOG */ { LOG_PM_ID, -1, "/", "/log/", "pm", ".log", 512 * 1024, 5 }, /* PM专用LOG */ }; ``` ```c /* ulog to file,注册 */ int ulog_file_backend_init(void) { /* create device filesystem lock */ rt_mutex_init(&log_file_lock, "logfile", RT_IPC_FLAG_FIFO); ulog_init(); rt_thread_mdelay(1000); ulog_file.output = ulog_file_backend_output; ulog_backend_register(&ulog_file, "file", RT_FALSE); return 0; } ``` 其他参考demo: file_be.c ## 运行效果 ```c msh /log>ls Directory /log: pm.log 77149 sys.log 15229 msh /log>cat pm.log 11-29 11:28:50 D/pms: ,100,3800,15000,0,20,0x2,0 11-29 11:29:00 D/pms: ,100,3800,15000,0,25,0x2,0 11-29 11:29:10 D/pms: ,100,3800,15000,0,30,0x2,0 11-29 11:29:20 D/pms: ,100,3800,15000,0,35,0x2,0 11-29 11:29:30 D/pms: ,100,3800,15000,0,40,0x2,0 11-29 11:29:40 D/pms: ,100,3800,15000,0,45,0x2,0 /* pm.log 真干净,只有功耗相关的日志,无其他的调试log信息,可以使用python等脚本解析了 */ ``` ## 开启PM专用LOG的方法 ![2020-11-30_091007.png](/uploads/20201130/59a940574b2f15e40e07e5125163a734.png) ```c /* 功能实现文件 */ rtt_pm_log\rt-thread\components\utilities\ulog\backend\file_be.c /* 修改的ulog组件文件 */ rtt_pm_log\rt-thread\components\utilities\ulog\ulog.c rtt_pm_log\rt-thread\components\utilities\ulog\ulog.h rtt_pm_log\rt-thread\components\utilities\ulog\ulog_def.h ```
1
条评论
默认排序
按发布时间排序
登录
注册新账号
关于作者
张世争
学以致用
文章
131
回答
813
被采纳
177
关注TA
发私信
相关文章
1
STM32F103的低功耗
2
最近用rtthread系统下AD采样并低功耗,中断响应不及时
3
rt-thread低功耗休眠应用问题请教
4
关于RTT对低功耗的支持
5
RT-Thread怎么休眠实现低功耗。
6
RT-Thread V3.0支持的低功耗,OS会自行进入吗?
7
关于RTThread3.0低功耗休眠模式
8
RTT3.0的bsp包中哪些MCU自带低功耗定时器?
9
关于低功耗上次说针对L4出个BSP的,怎么迟迟不见呀
10
低功耗问题。
推荐文章
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组件
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
I2C_IIC
ESP8266
UART
WIZnet_W5500
ota在线升级
cubemx
PWM
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
keil_MDK
SFUD
msh
ulog
C++_cpp
MicroPython
本月问答贡献
三世执戟
5
个答案
1
次被采纳
RTT_逍遥
4
个答案
1
次被采纳
KunYi
4
个答案
1
次被采纳
xiaorui
1
个答案
1
次被采纳
JonasWen
1
个答案
1
次被采纳
本月文章贡献
出出啊
1
篇文章
3
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
3
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
投诉
建议
回到
底部