From 961fbacd764aa23555e1c6ec0ee5438d9d5eea87 Mon Sep 17 00:00:00 2001 From: Marcus Larsson Date: Fri, 20 Nov 2015 12:42:21 +0100 Subject: [PATCH] 8143229: Replace the develop level with develop macros in Unified Logging Reviewed-by: brutisso, coleenp, dholmes, rprotacio --- hotspot/src/share/vm/logging/log.cpp | 4 ++-- hotspot/src/share/vm/logging/log.hpp | 14 ++++++++++++-- hotspot/src/share/vm/logging/logConfiguration.cpp | 1 + hotspot/src/share/vm/logging/logLevel.hpp | 11 ++--------- 4 files changed, 17 insertions(+), 13 deletions(-) diff --git a/hotspot/src/share/vm/logging/log.cpp b/hotspot/src/share/vm/logging/log.cpp index 1e9f94bec9d..eda1877c88c 100644 --- a/hotspot/src/share/vm/logging/log.cpp +++ b/hotspot/src/share/vm/logging/log.cpp @@ -37,10 +37,10 @@ void Test_log_length() { // Write long message to output file MutexLocker ml(LogConfiguration_lock); - LogConfiguration::parse_log_arguments("loglengthoutput.txt", "logging=develop", + LogConfiguration::parse_log_arguments("loglengthoutput.txt", "logging=trace", NULL, NULL, NULL); ResourceMark rm; - outputStream* logstream = LogHandle(logging)::develop_stream(); + outputStream* logstream = LogHandle(logging)::trace_stream(); logstream->print_cr("01:1234567890-" "02:1234567890-" "03:1234567890-" diff --git a/hotspot/src/share/vm/logging/log.hpp b/hotspot/src/share/vm/logging/log.hpp index bcd6cde58b4..8b65f0cd2dd 100644 --- a/hotspot/src/share/vm/logging/log.hpp +++ b/hotspot/src/share/vm/logging/log.hpp @@ -49,11 +49,21 @@ #define log_info(...) (!log_is_enabled(Info, __VA_ARGS__)) ? (void)0 : Log::write #define log_debug(...) (!log_is_enabled(Debug, __VA_ARGS__)) ? (void)0 : Log::write #define log_trace(...) (!log_is_enabled(Trace, __VA_ARGS__)) ? (void)0 : Log::write + +// Macros for logging that should be excluded in product builds. +// Available for levels Info, Debug and Trace. Includes test macro that +// evaluates to false in product builds. #ifndef PRODUCT -#define log_develop(...) (!log_is_enabled(Develop, __VA_ARGS__)) ? (void)0 : Log::write +#define log_develop_info(...) (!log_is_enabled(Info, __VA_ARGS__)) ? (void)0 : Log::write +#define log_develop_debug(...) (!log_is_enabled(Debug, __VA_ARGS__)) ? (void)0 : Log::write +#define log_develop_trace(...) (!log_is_enabled(Trace, __VA_ARGS__)) ? (void)0 : Log::write +#define develop_log_is_enabled(level, ...) log_is_enabled(level, __VA_ARGS__) #else #define DUMMY_ARGUMENT_CONSUMER(...) -#define log_develop(...) DUMMY_ARGUMENT_CONSUMER +#define log_develop_info(...) DUMMY_ARGUMENT_CONSUMER +#define log_develop_debug(...) DUMMY_ARGUMENT_CONSUMER +#define log_develop_trace(...) DUMMY_ARGUMENT_CONSUMER +#define develop_log_is_enabled(...) false #endif // Convenience macro to test if the logging is enabled on the specified level for given tags. diff --git a/hotspot/src/share/vm/logging/logConfiguration.cpp b/hotspot/src/share/vm/logging/logConfiguration.cpp index d575a458249..704c2e3e31b 100644 --- a/hotspot/src/share/vm/logging/logConfiguration.cpp +++ b/hotspot/src/share/vm/logging/logConfiguration.cpp @@ -44,6 +44,7 @@ void LogConfiguration::post_initialize() { LogDiagnosticCommand::registerCommand(); LogHandle(logging) log; log.info("Log configuration fully initialized."); + log_develop_info(logging)("Develop logging is available."); if (log.is_trace()) { ResourceMark rm; MutexLocker ml(LogConfiguration_lock); diff --git a/hotspot/src/share/vm/logging/logLevel.hpp b/hotspot/src/share/vm/logging/logLevel.hpp index 55ac3564d2c..7106c548e80 100644 --- a/hotspot/src/share/vm/logging/logLevel.hpp +++ b/hotspot/src/share/vm/logging/logLevel.hpp @@ -29,14 +29,8 @@ // The list of log levels: // -// develop - A non-product level that is finer than trace. -// Should be used for really expensive and/or -// extensive logging, or logging that shouldn't -// or can't be included in a product build. -// -// trace - Finest level of logging in product builds. -// Use for extensive/noisy logging that can -// give slow-down when enabled. +// trace - Finest level of logging. Use for extensive/noisy +// logging that can give slow-down when enabled. // // debug - A finer level of logging. Use for semi-noisy // logging that is does not fit the info level. @@ -49,7 +43,6 @@ // error - Critical messages caused by errors. // #define LOG_LEVEL_LIST \ - NOT_PRODUCT(LOG_LEVEL(Develop, develop)) \ LOG_LEVEL(Trace, trace) \ LOG_LEVEL(Debug, debug) \ LOG_LEVEL(Info, info) \