杰理打印log_info,log_debug,log_error定义位置

 

//include_lib\system\debug.h

#ifndef _DEBUG_H_
#define _DEBUG_H_

#include "asm/cpu.h"
#include "generic/typedef.h"

// -- output terminal color
#define RedBold             "\033[31;1m" // 红色加粗
#define RedBoldBlink        "\033[31;1;5m" // 红色加粗、闪烁
#define GreenBold             "\033[32;1m" // 红色加粗
#define GreenBoldBlink        "\033[32;1;5m" // 红色加粗、闪烁
#define YellowBold             "\033[33;1m" // 红色加粗
#define YellowBoldBlink        "\033[33;1;5m" // 红色加粗、闪烁
#define BlueBold            "\033[34;1m" // 蓝色加粗
#define BlueBoldBlink       "\033[34;1;5m" // 蓝色加粗、闪烁
#define PurpleBold          "\033[35;1m"   // 紫色加粗
#define PurpleBoldBlink     "\033[35;1;5m" // 紫色加粗、闪烁
#define DGreenBold             "\033[36;1m" // 红色加粗
#define DGreenBoldBlink        "\033[36;1;5m" // 红色加粗、闪烁
#define WhiteBold             "\033[37;1m" // 红色加粗
#define WhiteBoldBlink        "\033[37;1;5m" // 红色加粗、闪烁
#define Reset               "\033[0;25m"   // 颜色复位

#define LOG_ASSERT_ENABLE

void printf_buf(u8 *buf, u32 len);

#define PRINTF(format, ...)         printf("\e[1;31m" "[%s %d]:" "PRINTF(...\n" "\e[0m",__FUNCTION__,__LINE__);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 //0
#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("<Error> :" _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,"<Error>: " _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_

建议将

#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(format, ...)       \
    if (LOG_IS_ENABLE(LOG_INFO)) \
        printf("\e[1;35m" "[%s %d]:" "log_info(format, ...)" "\e[0m",__FUNCTION__,__LINE__);log_print(__LOG_INFO,NULL,"[Info]: " _LOG_TAG format "\r\n", ## __VA_ARGS__)
posted @ 2024-04-17 11:25  败人两字非傲即惰  阅读(20)  评论(0编辑  收藏  举报