#ifndef _DEBUG_H_ #define _DEBUG_H_ #include "asm/cpu.h" #include "generic/typedef.h" #define LOG_ASSERT_ENABLE void printf_buf(u8 *buf, u32 len); #define PRINTF(format, ...) printf(format, ## __VA_ARGS__) #define LOG_VERBOSE v #define LOG_INFO i #define LOG_DEBUG d #define LOG_WARN w #define LOG_ERROR e #define LOG_CHAR c #define _STR(x) #x #define STR(x) "["_STR(x)"]" #define _LOG_TAG_CONST_DECLARE(level, name) extern const char log_tag_const_##level##_##name #define LOG_TAG_CONST_DECLARE(level, name) _LOG_TAG_CONST_DECLARE(level, name) #define ___LOG_IS_ENABLE(level, name) (log_tag_const_##level##_##name) #define __LOG_IS_ENABLE(level, name) ___LOG_IS_ENABLE(level, name) #define _LOG_IS_ENABLE(level) __LOG_IS_ENABLE(level, LOG_TAG_CONST) #ifdef LOG_TAG_CONST LOG_TAG_CONST_DECLARE(LOG_VERBOSE, LOG_TAG_CONST); LOG_TAG_CONST_DECLARE(LOG_INFO, LOG_TAG_CONST); LOG_TAG_CONST_DECLARE(LOG_DEBUG, LOG_TAG_CONST); LOG_TAG_CONST_DECLARE(LOG_WARN, LOG_TAG_CONST); LOG_TAG_CONST_DECLARE(LOG_ERROR, LOG_TAG_CONST); LOG_TAG_CONST_DECLARE(LOG_CHAR, LOG_TAG_CONST); #define _LOG_TAG STR(LOG_TAG_CONST) #define LOG_IS_ENABLE(level) _LOG_IS_ENABLE(level) #else #define _LOG_TAG LOG_TAG #define LOG_IS_ENABLE(x) 1 #endif #define LOG_BY_MACRO 1 #define LOG_BY_CONST 2 // #define LOG_MODE LOG_BY_MACRO #define LOG_MODE LOG_BY_CONST /* * LOG 通过宏控制 */ #if (LOG_MODE == LOG_BY_MACRO) #ifdef LOG_INFO_ENABLE #define log_info(format, ...) PRINTF("[Info] :" _LOG_TAG format "\r\n", ## __VA_ARGS__) #else #define log_info(...) #endif #ifdef LOG_DEBUG_ENABLE #define log_debug(format, ...) PRINTF("[Debug] :" _LOG_TAG format "\r\n", ## __VA_ARGS__) #define log_debug_hexdump(x, y) printf_buf(x, y) #else #define log_debug(...) #define log_debug_hexdump(x, y) #endif #ifdef LOG_ERROR_ENABLE #define log_error(format, ...) PRINTF(" :" _LOG_TAG format "\r\n", ## __VA_ARGS__) #define log_error_hexdump(x, y) printf_buf(x, y) #else #define log_error(...) #define log_error_hexdump(...) #endif #ifdef LOG_DUMP_ENABLE #define log_info_hexdump(x,y) printf_buf(x,y) #else #define log_info_hexdump(...) #endif #ifdef LOG_CHAR_ENABLE #define log_char(x) putchar(x) #else #define log_char(x) #endif /* * LOG 通过常量控制 */ #elif (LOG_MODE == LOG_BY_CONST) #define log_info(format, ...) \ if (LOG_IS_ENABLE(LOG_INFO)) \ log_print(__LOG_INFO,NULL,"[Info]: " _LOG_TAG format "\r\n", ## __VA_ARGS__) #define log_info_hexdump(x, y) \ if (LOG_IS_ENABLE(LOG_INFO)) \ printf_buf(x, y) #define log_debug(format, ...) \ if (LOG_IS_ENABLE(LOG_DEBUG)) \ log_print(__LOG_DEBUG,NULL,"[Debug]: " _LOG_TAG format "\r\n", ## __VA_ARGS__) #define log_debug_hexdump(x, y) \ if (LOG_IS_ENABLE(LOG_DEBUG)) \ printf_buf(x, y) #define log_error(format, ...) \ if (LOG_IS_ENABLE(LOG_ERROR)) \ log_print(__LOG_ERROR,NULL,": " _LOG_TAG format "\r\n", ## __VA_ARGS__) #define log_error_hexdump(x, y) \ if (LOG_IS_ENABLE(LOG_ERROR)) \ printf_buf(x, y) #define log_char(x) \ if (LOG_IS_ENABLE(LOG_CHAR)) \ putchar(x) #endif #define traceSUPER_MODE() \ /*{int icfg, rets, reti; \ __asm__ volatile("%0 = icfg" : "=r"(icfg)); \ __asm__ volatile("%0 = rets" :"=r"(rets)); \ __asm__ volatile("%0 = reti" :"=r"(reti)); \ ASSERT(icfg & BIT(10), "icfg 0x%x/ rets 0x%x / reti 0x%x", icfg, rets, reti)}*/ void watchdog_close(void); #endif//__DEBUG_LOG_H_