From 398279899da1e9223891e2356e56fb035880eddf Mon Sep 17 00:00:00 2001 From: pankore <86098180+pankore@users.noreply.github.com> Date: Wed, 8 Mar 2023 06:00:38 +0800 Subject: [PATCH] [Ameba] Dynamic logging (#25273) * [logging] dynamic log level setting * [logging] cleaup * [logging] use enums instead of macros * [logging] cleanup * [logging] change loglevel to enum class - change namespace * [logging] use to_underlying - change enum class name * [logging] fix compile errors - change back the namespace to chip::Logging::Platform --- src/platform/Ameba/Logging.cpp | 29 ++++++++++++++++++++++------- src/platform/Ameba/Logging.h | 21 +++++++++++++++++++++ 2 files changed, 43 insertions(+), 7 deletions(-) create mode 100644 src/platform/Ameba/Logging.h diff --git a/src/platform/Ameba/Logging.cpp b/src/platform/Ameba/Logging.cpp index 5bd55a72e94b37..edafd0f8a962e6 100644 --- a/src/platform/Ameba/Logging.cpp +++ b/src/platform/Ameba/Logging.cpp @@ -25,18 +25,30 @@ #include #include +#include #include +#include "Logging.h" #include -#ifdef LOG_LOCAL_LEVEL -#undef LOG_LOCAL_LEVEL -#endif - namespace chip { namespace Logging { namespace Platform { +namespace { +LogLevel log_level = LogLevel::kDetail; +} + +void LogSetLevel(LogLevel level) +{ + log_level = level; +} + +LogLevel LogGetLevel() +{ + return log_level; +} + void LogV(const char * module, uint8_t category, const char * msg, va_list v) { char tag[11]; @@ -50,14 +62,17 @@ void LogV(const char * module, uint8_t category, const char * msg, va_list v) switch (category) { case kLogCategory_Error: - printf("%s %s\r\n", tag, formattedMsg); + if (to_underlying(log_level) >= to_underlying(LogLevel::kError)) + printf("%s %s\r\n", tag, formattedMsg); break; case kLogCategory_Progress: default: - printf("%s %s\r\n", tag, formattedMsg); + if (to_underlying(log_level) >= to_underlying(LogLevel::kProgress)) + printf("%s %s\r\n", tag, formattedMsg); break; case kLogCategory_Detail: - printf("%s %s\r\n", tag, formattedMsg); + if (to_underlying(log_level) >= to_underlying(LogLevel::kDetail)) + printf("%s %s\r\n", tag, formattedMsg); break; } } diff --git a/src/platform/Ameba/Logging.h b/src/platform/Ameba/Logging.h new file mode 100644 index 00000000000000..dca1bed9d6aa6e --- /dev/null +++ b/src/platform/Ameba/Logging.h @@ -0,0 +1,21 @@ +#pragma once + +#include + +namespace chip { +namespace Logging { +namespace Platform { + +enum class LogLevel +{ + kError, + kProgress, + kDetail, +}; + +void LogSetLevel(LogLevel level); +LogLevel LogGetLevel(); + +} // namespace Platform +} // namespace Logging +} // namespace chip