You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							222 lines
						
					
					
						
							7.0 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							222 lines
						
					
					
						
							7.0 KiB
						
					
					
				| /* | |
|  * 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_ */
 | |
| 
 |