123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- #ifndef SUNXI_HAL_LOG_H
- #define SUNXI_HAL_LOG_H
- #ifdef __cplusplus
- extern "C"
- {
- #endif
- #include <stdio.h>
- //#define CONFIG_KERNEL_FREERTOS
- //#define CONFIG_RTTKERNEL
- #ifdef CONFIG_KERNEL_FREERTOS
- #include <awlog.h>
- #define hal_log_err(fmt, ...) pr_err(fmt"\n", ##__VA_ARGS__)
- #define hal_log_warn(fmt, ...) pr_warn(fmt"\n", ##__VA_ARGS__)
- #define hal_log_info(fmt, ...) pr_info(fmt"\n", ##__VA_ARGS__)
- #define hal_log_debug(fmt, ...) pr_debug(fmt"\n", ##__VA_ARGS__)
- #elif defined CONFIG_RTTKERNEL
- #include <log.h>
- #define hal_log_err(fmt, ...) pr_err(fmt"\n", ##__VA_ARGS__)
- #define hal_log_warn(fmt, ...) pr_warn(fmt"\n", ##__VA_ARGS__)
- #define hal_log_info(fmt, ...) pr_info(fmt"\n", ##__VA_ARGS__)
- #define hal_log_debug(fmt, ...) pr_debug(fmt"\n", ##__VA_ARGS__)
- #else
- int printk(const char *fmt, ...);
- #define HAL_XPOSTO(x) "\033[" #x "D\033[" #x "C"
- #define HAL_LOG_LAYOUT "%s%s%s: [%s:%04u]: %s%s"
- #define HAL_LOG_BACKEND_CALL(log_lv, log_color, log_format, color_off, ...) \
- printk(HAL_LOG_LAYOUT log_format "%s""\n\r", \
- log_color, log_lv, color_off, __func__, __LINE__, HAL_XPOSTO(30),\
- log_color, ##__VA_ARGS__, color_off)
- #define HAL_LOG_COLOR(log_lv, log_color, log_format, ...) \
- HAL_LOG_BACKEND_CALL(log_lv, log_color, log_format, \
- HAL_LOG_COLOR_OFF, ##__VA_ARGS__)
- #define HAL_LOG_COLOR_OFF "\033[0m"
- #define HAL_LOG_COLOR_RED "\033[1;40;31m"
- #define HAL_LOG_COLOR_YELLOW "\033[1;40;33m"
- #define HAL_LOG_COLOR_BLUE "\033[1;40;34m"
- #define HAL_LOG_COLOR_PURPLE "\033[1;40;35m"
- #define HAL_LOG_ERROR_PREFIX "[ERR]"
- #define HAL_LOG_WARNING_PREFIX "[WRN]"
- #define HAL_LOG_INFO_PREFIX "[INF]"
- #define HAL_LOG_DEBUG_PREFIX "[DBG]"
- #define hal_log_err(...) \
- do { HAL_LOG_COLOR(HAL_LOG_ERROR_PREFIX, HAL_LOG_COLOR_OFF, ##__VA_ARGS__); } while(0)
- #define hal_log_warn(...) \
- do { HAL_LOG_COLOR(HAL_LOG_WARNING_PREFIX, HAL_LOG_COLOR_OFF, ##__VA_ARGS__); } while(0)
- #define hal_log_info(...) \
- do { HAL_LOG_COLOR(HAL_LOG_INFO_PREFIX, HAL_LOG_COLOR_OFF, ##__VA_ARGS__); } while(0)
- #define hal_log_debug(...) \
- do { HAL_LOG_COLOR(HAL_LOG_DEBUG_PREFIX, HAL_LOG_COLOR_OFF, ##__VA_ARGS__); } while(0)
- #endif
- #ifdef __cplusplus
- }
- #endif
- #endif
|