mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-27 03:57:23 +08:00
8b58577230
* [ulog] 解决ulog开启时间戳后与libc time以及rtc驱动相关函数干涉的问题 * ulog:当发生递归输出时,后续递归想要输出的内容可能会因为防范递归的判断而无法输出 因此修改输出规则,在发生递归时,采用简单的,无格式的方式直接输出。这样既保证不会发生递归输出,也可以保证递归输出的部分可以正常输出。 * [ulog] size_t->rt_size_t NULL->RT_NULL
223 lines
7.0 KiB
C
223 lines
7.0 KiB
C
/*
|
|
* Copyright (c) 2006-2022, RT-Thread Development Team
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
* Change Logs:
|
|
* Date Author Notes
|
|
* 2018-08-25 armink the first version
|
|
*/
|
|
|
|
#ifndef _ULOG_DEF_H_
|
|
#define _ULOG_DEF_H_
|
|
|
|
#include <rtdef.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/* logger level, the number is compatible for syslog */
|
|
#define LOG_LVL_ASSERT 0
|
|
#define LOG_LVL_ERROR 3
|
|
#define LOG_LVL_WARNING 4
|
|
#define LOG_LVL_INFO 6
|
|
#define LOG_LVL_DBG 7
|
|
|
|
/* the output silent level and all level for filter setting */
|
|
#ifndef ULOG_USING_SYSLOG
|
|
#define LOG_FILTER_LVL_SILENT 0
|
|
#define LOG_FILTER_LVL_ALL 7
|
|
#else
|
|
#define LOG_FILTER_LVL_SILENT 1
|
|
#define LOG_FILTER_LVL_ALL 255
|
|
#endif /* ULOG_USING_SYSLOG */
|
|
|
|
/* compatible for rtdbg */
|
|
#undef LOG_D
|
|
#undef LOG_I
|
|
#undef LOG_W
|
|
#undef LOG_E
|
|
#undef LOG_RAW
|
|
#undef DBG_ERROR
|
|
#undef DBG_WARNING
|
|
#undef DBG_INFO
|
|
#undef DBG_LOG
|
|
#undef dbg_log
|
|
#define DBG_ERROR LOG_LVL_ERROR
|
|
#define DBG_WARNING LOG_LVL_WARNING
|
|
#define DBG_INFO LOG_LVL_INFO
|
|
#define DBG_LOG LOG_LVL_DBG
|
|
#define dbg_log(level, ...) \
|
|
if ((level) <= LOG_LVL) \
|
|
{ \
|
|
ulog_output(level, LOG_TAG, RT_FALSE, __VA_ARGS__);\
|
|
}
|
|
|
|
#if !defined(LOG_TAG)
|
|
/* compatible for rtdbg */
|
|
#if defined(DBG_TAG)
|
|
#define LOG_TAG DBG_TAG
|
|
#elif defined(DBG_SECTION_NAME)
|
|
#define LOG_TAG DBG_SECTION_NAME
|
|
#else
|
|
#define LOG_TAG "NO_TAG"
|
|
#endif
|
|
#endif /* !defined(LOG_TAG) */
|
|
|
|
#if !defined(LOG_LVL)
|
|
/* compatible for rtdbg */
|
|
#if defined(DBG_LVL)
|
|
#define LOG_LVL DBG_LVL
|
|
#elif defined(DBG_LEVEL)
|
|
#define LOG_LVL DBG_LEVEL
|
|
#else
|
|
#define LOG_LVL LOG_LVL_DBG
|
|
#endif
|
|
#endif /* !defined(LOG_LVL) */
|
|
|
|
#if (LOG_LVL >= LOG_LVL_DBG) && (ULOG_OUTPUT_LVL >= LOG_LVL_DBG)
|
|
#define ulog_d(TAG, ...) ulog_output(LOG_LVL_DBG, TAG, RT_TRUE, __VA_ARGS__)
|
|
#else
|
|
#define ulog_d(TAG, ...)
|
|
#endif /* (LOG_LVL >= LOG_LVL_DBG) && (ULOG_OUTPUT_LVL >= LOG_LVL_DBG) */
|
|
|
|
#if (LOG_LVL >= LOG_LVL_INFO) && (ULOG_OUTPUT_LVL >= LOG_LVL_INFO)
|
|
#define ulog_i(TAG, ...) ulog_output(LOG_LVL_INFO, TAG, RT_TRUE, __VA_ARGS__)
|
|
#else
|
|
#define ulog_i(TAG, ...)
|
|
#endif /* (LOG_LVL >= LOG_LVL_INFO) && (ULOG_OUTPUT_LVL >= LOG_LVL_INFO) */
|
|
|
|
#if (LOG_LVL >= LOG_LVL_WARNING) && (ULOG_OUTPUT_LVL >= LOG_LVL_WARNING)
|
|
#define ulog_w(TAG, ...) ulog_output(LOG_LVL_WARNING, TAG, RT_TRUE, __VA_ARGS__)
|
|
#else
|
|
#define ulog_w(TAG, ...)
|
|
#endif /* (LOG_LVL >= LOG_LVL_WARNING) && (ULOG_OUTPUT_LVL >= LOG_LVL_WARNING) */
|
|
|
|
#if (LOG_LVL >= LOG_LVL_ERROR) && (ULOG_OUTPUT_LVL >= LOG_LVL_ERROR)
|
|
#define ulog_e(TAG, ...) ulog_output(LOG_LVL_ERROR, TAG, RT_TRUE, __VA_ARGS__)
|
|
#else
|
|
#define ulog_e(TAG, ...)
|
|
#endif /* (LOG_LVL >= LOG_LVL_ERROR) && (ULOG_OUTPUT_LVL >= LOG_LVL_ERROR) */
|
|
|
|
#if (LOG_LVL >= LOG_LVL_DBG) && (ULOG_OUTPUT_LVL >= LOG_LVL_DBG)
|
|
#define ulog_hex(TAG, width, buf, size) ulog_hexdump(TAG, width, buf, size)
|
|
#else
|
|
#define ulog_hex(TAG, width, buf, size)
|
|
#endif /* (LOG_LVL >= LOG_LVL_DBG) && (ULOG_OUTPUT_LVL >= LOG_LVL_DBG) */
|
|
|
|
/* assert for developer. */
|
|
#ifdef ULOG_ASSERT_ENABLE
|
|
#define ULOG_ASSERT(EXPR) \
|
|
if (!(EXPR)) \
|
|
{ \
|
|
ulog_output(LOG_LVL_ASSERT, LOG_TAG, RT_TRUE, "(%s) has assert failed at %s:%ld.", #EXPR, __FUNCTION__, __LINE__); \
|
|
ulog_flush(); \
|
|
while (1); \
|
|
}
|
|
#else
|
|
#define ULOG_ASSERT(EXPR)
|
|
#endif
|
|
|
|
/* ASSERT API definition */
|
|
#if !defined(ASSERT)
|
|
#define ASSERT ULOG_ASSERT
|
|
#endif
|
|
|
|
/* compatible for elog */
|
|
#undef assert
|
|
#undef log_e
|
|
#undef log_w
|
|
#undef log_i
|
|
#undef log_d
|
|
#undef log_v
|
|
#undef ELOG_LVL_ASSERT
|
|
#undef ELOG_LVL_ERROR
|
|
#undef ELOG_LVL_WARN
|
|
#undef ELOG_LVL_INFO
|
|
#undef ELOG_LVL_DEBUG
|
|
#undef ELOG_LVL_VERBOSE
|
|
#define assert ASSERT
|
|
#define log_e LOG_E
|
|
#define log_w LOG_W
|
|
#define log_i LOG_I
|
|
#define log_d LOG_D
|
|
#define log_v LOG_D
|
|
#define log_raw LOG_RAW
|
|
#define log_hex LOG_HEX
|
|
#define ELOG_LVL_ASSERT LOG_LVL_ASSERT
|
|
#define ELOG_LVL_ERROR LOG_LVL_ERROR
|
|
#define ELOG_LVL_WARN LOG_LVL_WARNING
|
|
#define ELOG_LVL_INFO LOG_LVL_INFO
|
|
#define ELOG_LVL_DEBUG LOG_LVL_DBG
|
|
#define ELOG_LVL_VERBOSE LOG_LVL_DBG
|
|
|
|
/* setting static output log level */
|
|
#ifndef ULOG_OUTPUT_LVL
|
|
#define ULOG_OUTPUT_LVL LOG_LVL_DBG
|
|
#endif
|
|
|
|
/* buffer size for every line's log */
|
|
#ifndef ULOG_LINE_BUF_SIZE
|
|
#define ULOG_LINE_BUF_SIZE 128
|
|
#endif
|
|
|
|
/* output filter's tag max length */
|
|
#ifndef ULOG_FILTER_TAG_MAX_LEN
|
|
#define ULOG_FILTER_TAG_MAX_LEN 23
|
|
#endif
|
|
|
|
/* output filter's keyword max length */
|
|
#ifndef ULOG_FILTER_KW_MAX_LEN
|
|
#define ULOG_FILTER_KW_MAX_LEN 15
|
|
#endif
|
|
|
|
#ifndef ULOG_NEWLINE_SIGN
|
|
#define ULOG_NEWLINE_SIGN "\r\n"
|
|
#endif
|
|
|
|
#define ULOG_FRAME_MAGIC 0x10
|
|
|
|
/* tag's level filter */
|
|
struct ulog_tag_lvl_filter
|
|
{
|
|
char tag[ULOG_FILTER_TAG_MAX_LEN + 1];
|
|
rt_uint32_t level;
|
|
rt_slist_t list;
|
|
};
|
|
typedef struct ulog_tag_lvl_filter *ulog_tag_lvl_filter_t;
|
|
|
|
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;
|
|
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;
|
|
rt_uint32_t out_level;
|
|
void (*init) (struct ulog_backend *backend);
|
|
void (*output)(struct ulog_backend *backend, rt_uint32_t level, const char *tag, rt_bool_t is_raw, const char *log, rt_size_t len);
|
|
void (*flush) (struct ulog_backend *backend);
|
|
void (*deinit)(struct ulog_backend *backend);
|
|
/* The filter will be call before output. It will return TRUE when the filter condition is math. */
|
|
rt_bool_t (*filter)(struct ulog_backend *backend, rt_uint32_t level, const char *tag, rt_bool_t is_raw, const char *log, rt_size_t len);
|
|
rt_slist_t list;
|
|
};
|
|
typedef struct ulog_backend *ulog_backend_t;
|
|
typedef rt_bool_t (*ulog_backend_filter_t)(struct ulog_backend *backend, rt_uint32_t level, const char *tag, rt_bool_t is_raw, const char *log, rt_size_t len);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* _ULOG_DEF_H_ */
|