2022-11-11 21:20:58 +08:00
|
|
|
#ifndef _BSP_LOG_H
|
|
|
|
#define _BSP_LOG_H
|
|
|
|
|
2023-03-19 11:11:40 +08:00
|
|
|
#include "SEGGER_RTT.h"
|
|
|
|
#include "SEGGER_RTT_Conf.h"
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
#define BUFFER_INDEX 0
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief 日志系统初始化
|
2023-06-24 20:29:57 +08:00
|
|
|
*
|
2023-03-19 11:11:40 +08:00
|
|
|
*/
|
|
|
|
void BSPLogInit();
|
|
|
|
|
2023-01-01 17:32:22 +08:00
|
|
|
/**
|
2023-03-18 20:36:21 +08:00
|
|
|
* @brief 日志功能原型,供下面的LOGI,LOGW,LOGE等使用
|
2023-06-24 20:29:57 +08:00
|
|
|
*
|
2023-01-01 17:32:22 +08:00
|
|
|
*/
|
2023-06-24 20:29:57 +08:00
|
|
|
#define LOG_PROTO(type, color, format, ...) \
|
|
|
|
SEGGER_RTT_printf(BUFFER_INDEX, " %s%s" format "\r\n%s", \
|
|
|
|
color, \
|
|
|
|
type, \
|
|
|
|
##__VA_ARGS__, \
|
2023-03-18 20:36:21 +08:00
|
|
|
RTT_CTRL_RESET)
|
|
|
|
|
2023-06-24 20:29:57 +08:00
|
|
|
/*----------------------------------------下面是日志输出的接口-------------------------------------------------*/
|
2023-03-19 11:11:40 +08:00
|
|
|
|
2023-03-18 20:36:21 +08:00
|
|
|
/* 清屏 */
|
2023-06-24 20:29:57 +08:00
|
|
|
#define LOG_CLEAR() SEGGER_RTT_WriteString(0, " " RTT_CTRL_CLEAR)
|
2023-03-18 20:36:21 +08:00
|
|
|
|
|
|
|
/* 无颜色日志输出 */
|
2023-06-24 20:29:57 +08:00
|
|
|
#define LOG(format, ...) LOG_PROTO("", "", format, ##__VA_ARGS__)
|
2023-03-18 20:36:21 +08:00
|
|
|
|
2023-06-24 20:29:57 +08:00
|
|
|
/**
|
|
|
|
* 有颜色格式日志输出,建议使用这些宏来输出日志
|
|
|
|
* @attention 注意这些接口不支持浮点格式化输出,若有需要,请使用Float2Str()函数进行转换后再打印
|
2023-07-12 20:34:13 +08:00
|
|
|
* @note 在release版本上车使用时,与makefile中添加的宏DISABLE_LOG_SYSTEM一起使用,可以关闭日志系统
|
2023-06-24 20:29:57 +08:00
|
|
|
*/
|
2023-07-12 20:34:13 +08:00
|
|
|
#if DISABLE_LOG_SYSTEM
|
2023-07-13 15:37:58 +08:00
|
|
|
#define LOGINFO(format, ...)
|
|
|
|
#define LOGWARNING(format, ...)
|
|
|
|
#define LOGERROR(format, ...)
|
2023-07-12 20:34:13 +08:00
|
|
|
#else
|
2023-03-19 11:11:40 +08:00
|
|
|
// information level
|
2023-06-24 20:29:57 +08:00
|
|
|
#define LOGINFO(format, ...) LOG_PROTO("I:", RTT_CTRL_TEXT_BRIGHT_GREEN, format, ##__VA_ARGS__)
|
2023-03-19 11:11:40 +08:00
|
|
|
// warning level
|
2023-06-24 20:29:57 +08:00
|
|
|
#define LOGWARNING(format, ...) LOG_PROTO("W:", RTT_CTRL_TEXT_BRIGHT_YELLOW, format, ##__VA_ARGS__)
|
2023-03-19 11:11:40 +08:00
|
|
|
// error level
|
2023-06-24 20:29:57 +08:00
|
|
|
#define LOGERROR(format, ...) LOG_PROTO("E:", RTT_CTRL_TEXT_BRIGHT_RED, format, ##__VA_ARGS__)
|
2023-07-12 20:34:13 +08:00
|
|
|
#endif // DISABLE_LOG_SYSTEM
|
2022-12-02 23:10:36 +08:00
|
|
|
|
2023-01-01 17:32:22 +08:00
|
|
|
/**
|
2023-03-19 11:11:40 +08:00
|
|
|
* @brief 通过segger RTT打印日志,支持格式化输出,格式化输出的实现参考printf.
|
2023-06-24 20:29:57 +08:00
|
|
|
* @attention !! 此函数不支持浮点格式化,若有需要,请使用Float2Str()函数进行转换后再打印 !!
|
|
|
|
*
|
2023-03-18 20:36:21 +08:00
|
|
|
* @param fmt 格式字符串
|
|
|
|
* @param ... 参数列表
|
|
|
|
* @return int 打印的log字符数
|
2023-01-01 17:32:22 +08:00
|
|
|
*/
|
2022-12-05 21:01:26 +08:00
|
|
|
int PrintLog(const char *fmt, ...);
|
2022-12-02 23:10:36 +08:00
|
|
|
|
2023-01-01 17:32:22 +08:00
|
|
|
/**
|
|
|
|
* @brief 利用sprintf(),将float转换为字符串进行打印
|
2023-06-24 20:29:57 +08:00
|
|
|
* @attention 浮点数需要转换为字符串后才能通过RTT打印
|
|
|
|
*
|
2023-01-01 17:32:22 +08:00
|
|
|
* @param str 转换后的字符串
|
|
|
|
* @param va 待转换的float
|
|
|
|
*/
|
2022-11-11 21:20:58 +08:00
|
|
|
void Float2Str(char *str, float va);
|
|
|
|
|
|
|
|
#endif
|