2018-10-08 12:20:49 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2018 Gunar Schorcht
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup cpu_esp32
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Common log macros
|
|
|
|
*
|
|
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ESP_COMMON_LOG_H
|
|
|
|
#define ESP_COMMON_LOG_H
|
|
|
|
|
|
|
|
#ifndef DOXYGEN
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2019-08-20 16:17:01 +02:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2018-10-08 12:20:49 +02:00
|
|
|
#include "log.h"
|
|
|
|
|
2019-08-20 16:17:01 +02:00
|
|
|
extern uint32_t system_get_time_ms (void);
|
2019-11-20 06:46:42 +01:00
|
|
|
extern int ets_printf(const char *fmt, ...);
|
2019-08-20 16:17:01 +02:00
|
|
|
|
2019-08-20 18:22:35 +02:00
|
|
|
#if MODULE_ESP_LOG_COLORED
|
2019-08-20 16:17:01 +02:00
|
|
|
|
|
|
|
#define LOG_RESET_COLOR "\033[0m"
|
2019-11-20 06:46:42 +01:00
|
|
|
#define LOG_COLOR_E "\033[1;31m"
|
|
|
|
#define LOG_COLOR_W "\033[1;33m"
|
|
|
|
#define LOG_COLOR_I "\033[1m"
|
|
|
|
#define LOG_COLOR_D "\033[0;32m"
|
2019-08-20 16:17:01 +02:00
|
|
|
#define LOG_COLOR_V
|
|
|
|
|
2019-08-20 18:22:35 +02:00
|
|
|
#else /* MODULE_ESP_LOG_COLORED */
|
2019-08-20 16:17:01 +02:00
|
|
|
|
|
|
|
#define LOG_COLOR_E
|
|
|
|
#define LOG_COLOR_W
|
|
|
|
#define LOG_COLOR_I
|
|
|
|
#define LOG_COLOR_D
|
|
|
|
#define LOG_COLOR_V
|
|
|
|
#define LOG_RESET_COLOR
|
|
|
|
|
2019-08-20 18:22:35 +02:00
|
|
|
#endif /* MODULE_ESP_LOG_COLORED */
|
2019-08-20 16:17:01 +02:00
|
|
|
|
2019-08-20 16:21:36 +02:00
|
|
|
#if MODULE_ESP_LOG_TAGGED
|
|
|
|
|
2019-08-20 16:17:01 +02:00
|
|
|
#define LOG_FORMAT(letter, format) LOG_COLOR_ ## letter #letter " (%d) [%s] " format LOG_RESET_COLOR
|
|
|
|
|
|
|
|
#define LOG_TAG(level, letter, tag, format, ...) \
|
|
|
|
do { \
|
|
|
|
if ((unsigned)level <= (unsigned)LOG_LEVEL) { \
|
|
|
|
printf(LOG_FORMAT(letter, format), system_get_time_ms(), tag, ##__VA_ARGS__); \
|
2019-11-20 06:46:42 +01:00
|
|
|
fflush(stdout); \
|
2019-08-20 16:17:01 +02:00
|
|
|
} \
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
#define LOG_TAG_EARLY(level, letter, tag, format, ...) \
|
|
|
|
do { \
|
|
|
|
if (LOG_LEVEL >= level) { \
|
|
|
|
ets_printf(LOG_FORMAT(letter, format), system_get_time_ms(), tag, ##__VA_ARGS__); \
|
|
|
|
} \
|
|
|
|
} while(0)
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2019-08-20 16:21:36 +02:00
|
|
|
#else /* MODULE_ESP_LOG_TAGGED */
|
|
|
|
|
|
|
|
#define LOG_FORMAT(letter, format) LOG_COLOR_ ## letter format LOG_RESET_COLOR
|
|
|
|
|
|
|
|
#define LOG_TAG(level, letter, tag, format, ...) \
|
|
|
|
do { \
|
|
|
|
(void)tag; \
|
|
|
|
if ((unsigned)level <= (unsigned)LOG_LEVEL) { \
|
|
|
|
printf(LOG_FORMAT(letter, format), ##__VA_ARGS__); \
|
2019-11-20 06:46:42 +01:00
|
|
|
fflush(stdout); \
|
2019-08-20 16:21:36 +02:00
|
|
|
} \
|
|
|
|
} while (0U)
|
|
|
|
|
|
|
|
#define LOG_TAG_EARLY(level, letter, tag, format, ...) \
|
|
|
|
do { \
|
|
|
|
(void)tag; \
|
|
|
|
if ((unsigned)level <= (unsigned)LOG_LEVEL) { \
|
|
|
|
ets_printf(LOG_FORMAT(letter, format), ##__VA_ARGS__); \
|
|
|
|
} \
|
|
|
|
} while (0U)
|
|
|
|
|
|
|
|
#endif /* MODULE_ESP_LOG_TAGGED */
|
|
|
|
|
2018-10-08 12:20:49 +02:00
|
|
|
/**
|
|
|
|
* Override LOG_* definitions with a tagged version. By default the function
|
2019-08-20 16:17:01 +02:00
|
|
|
* name is used as tag.
|
2018-10-08 12:20:49 +02:00
|
|
|
*/
|
2019-08-20 16:17:01 +02:00
|
|
|
#ifndef MODULE_LOG_PRINTFNOFORMAT
|
2018-10-08 12:20:49 +02:00
|
|
|
#undef LOG_ERROR
|
|
|
|
#undef LOG_INFO
|
|
|
|
#undef LOG_WARNING
|
|
|
|
#undef LOG_DEBUG
|
2019-08-20 16:17:01 +02:00
|
|
|
#define LOG_ERROR(format, ...) LOG_TAG(LOG_ERROR , E, __func__, format, ##__VA_ARGS__)
|
|
|
|
#define LOG_WARNING(format, ...) LOG_TAG(LOG_WARNING, W, __func__, format, ##__VA_ARGS__)
|
|
|
|
#define LOG_INFO(format, ...) LOG_TAG(LOG_INFO , I, __func__, format, ##__VA_ARGS__)
|
|
|
|
#define LOG_DEBUG(format, ...) LOG_TAG(LOG_DEBUG , D, __func__, format, ##__VA_ARGS__)
|
|
|
|
#endif
|
2018-10-08 12:20:49 +02:00
|
|
|
|
|
|
|
/** Tagged LOG_* definitions */
|
2019-08-20 16:17:01 +02:00
|
|
|
#define LOG_TAG_ERROR(tag, format, ...) LOG_TAG(LOG_ERROR , E, tag, format, ##__VA_ARGS__)
|
|
|
|
#define LOG_TAG_WARNING(tag, format, ...) LOG_TAG(LOG_WARNING, W, tag, format, ##__VA_ARGS__)
|
|
|
|
#define LOG_TAG_INFO(tag, format, ...) LOG_TAG(LOG_INFO , I, tag, format, ##__VA_ARGS__)
|
|
|
|
#define LOG_TAG_DEBUG(tag, format, ...) LOG_TAG(LOG_DEBUG , D, tag, format, ##__VA_ARGS__)
|
2019-12-20 16:09:04 +01:00
|
|
|
#define LOG_TAG_ALL(tag, format, ...) LOG_TAG(LOG_ALL , V, tag, format, ##__VA_ARGS__)
|
2018-10-08 12:20:49 +02:00
|
|
|
|
|
|
|
/** definitions for source code compatibility with ESP-IDF */
|
2019-08-20 16:17:01 +02:00
|
|
|
#define ESP_EARLY_LOGE(tag, format, ...) LOG_TAG_EARLY(LOG_ERROR , E, tag, format "\n", ##__VA_ARGS__)
|
|
|
|
#define ESP_EARLY_LOGW(tag, format, ...) LOG_TAG_EARLY(LOG_WARNING, W, tag, format "\n", ##__VA_ARGS__)
|
|
|
|
#define ESP_EARLY_LOGI(tag, format, ...) LOG_TAG_EARLY(LOG_INFO , I, tag, format "\n", ##__VA_ARGS__)
|
|
|
|
#define ESP_LOGE(tag, format, ...) LOG_TAG(LOG_ERROR , E, tag, format "\n", ##__VA_ARGS__)
|
|
|
|
#define ESP_LOGW(tag, format, ...) LOG_TAG(LOG_WARNING, W, tag, format "\n", ##__VA_ARGS__)
|
|
|
|
#define ESP_LOGI(tag, format, ...) LOG_TAG(LOG_INFO , I, tag, format "\n", ##__VA_ARGS__)
|
2018-10-08 12:20:49 +02:00
|
|
|
|
|
|
|
#if ENABLE_DEBUG
|
|
|
|
|
2019-08-20 16:17:01 +02:00
|
|
|
#define ESP_EARLY_LOGD(tag, format, ...) LOG_TAG_EARLY(LOG_DEBUG, D, tag, format "\n", ##__VA_ARGS__)
|
|
|
|
#define ESP_EARLY_LOGV(tag, format, ...) LOG_TAG_EARLY(LOG_ALL , V, tag, format "\n", ##__VA_ARGS__)
|
|
|
|
#define ESP_LOGD(tag, format, ...) LOG_TAG(LOG_DEBUG, D, tag, format "\n", ##__VA_ARGS__)
|
|
|
|
#define ESP_LOGV(tag, format, ...) LOG_TAG(LOG_ALL , V, tag, format "\n", ##__VA_ARGS__)
|
2018-10-08 12:20:49 +02:00
|
|
|
|
|
|
|
#else /* ENABLE_DEBUG */
|
|
|
|
|
|
|
|
#define ESP_EARLY_LOGD( tag, format, ... ) (void)tag
|
|
|
|
#define ESP_EARLY_LOGV( tag, format, ... ) (void)tag
|
|
|
|
#define ESP_LOGD( tag, format, ... ) (void)tag
|
|
|
|
#define ESP_LOGV( tag, format, ... ) (void)tag
|
|
|
|
|
|
|
|
#endif /* ENABLE_DEBUG */
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* DOXYGEN */
|
|
|
|
|
|
|
|
#endif /* ESP_COMMON_LOG_H */
|