From f2c1ba20ece0cf4a515c1b0eadda462a9b3e4298 Mon Sep 17 00:00:00 2001 From: Erik Helin Date: Wed, 5 Oct 2016 16:00:10 +0200 Subject: [PATCH] 8167190: Remove confusing timestamps from the gc log Reviewed-by: sjohanss, pliden --- .../share/vm/gc/shared/gcTraceTime.inline.hpp | 14 +++---- .../test/gc/logging/TestPrintReferences.java | 2 +- .../test/native/logging/test_gcTraceTime.cpp | 40 +++++++++---------- .../logging/TestLogRotation.java | 4 +- 4 files changed, 28 insertions(+), 32 deletions(-) diff --git a/hotspot/src/share/vm/gc/shared/gcTraceTime.inline.hpp b/hotspot/src/share/vm/gc/shared/gcTraceTime.inline.hpp index b324e60f1cc..4b9c4e1ba88 100644 --- a/hotspot/src/share/vm/gc/shared/gcTraceTime.inline.hpp +++ b/hotspot/src/share/vm/gc/shared/gcTraceTime.inline.hpp @@ -35,7 +35,6 @@ #include "prims/jni_md.h" #include "utilities/ticks.hpp" -#define LOG_STOP_TIME_FORMAT "(%.3fs, %.3fs) %.3fms" #define LOG_STOP_HEAP_FORMAT SIZE_FORMAT "M->" SIZE_FORMAT "M(" SIZE_FORMAT "M)" inline void GCTraceTimeImpl::log_start(jlong start_counter) { @@ -46,7 +45,7 @@ inline void GCTraceTimeImpl::log_start(jlong start_counter) { if (_gc_cause != GCCause::_no_gc) { out.print(" (%s)", GCCause::to_string(_gc_cause)); } - out.print_cr(" (%.3fs)", TimeHelper::counter_to_seconds(start_counter)); + out.cr(); } } @@ -71,7 +70,7 @@ inline void GCTraceTimeImpl::log_stop(jlong start_counter, jlong stop_counter) { out.print(" " LOG_STOP_HEAP_FORMAT, used_before_m, used_m, capacity_m); } - out.print_cr(" " LOG_STOP_TIME_FORMAT, start_time_in_secs, stop_time_in_secs, duration_in_ms); + out.print_cr(" %.3fms", duration_in_ms); } inline void GCTraceTimeImpl::time_stamp(Ticks& ticks) { @@ -117,7 +116,7 @@ template ::GCTraceConcTimeImpl(const char* title) : _enabled(LogImpl::is_level(Level)), _start_time(os::elapsed_counter()), _title(title) { if (_enabled) { - LogImpl::template write("%s (%.3fs)", _title, TimeHelper::counter_to_seconds(_start_time)); + LogImpl::template write("%s", _title); } } @@ -125,11 +124,8 @@ template ::~GCTraceConcTimeImpl() { if (_enabled) { jlong stop_time = os::elapsed_counter(); - LogImpl::template write("%s " LOG_STOP_TIME_FORMAT, - _title, - TimeHelper::counter_to_seconds(_start_time), - TimeHelper::counter_to_seconds(stop_time), - TimeHelper::counter_to_millis(stop_time - _start_time)); + LogImpl::template write("%s %0.3fms", _title, + TimeHelper::counter_to_millis(stop_time - _start_time)); } } diff --git a/hotspot/test/gc/logging/TestPrintReferences.java b/hotspot/test/gc/logging/TestPrintReferences.java index 193263493be..82adb871b5e 100644 --- a/hotspot/test/gc/logging/TestPrintReferences.java +++ b/hotspot/test/gc/logging/TestPrintReferences.java @@ -41,7 +41,7 @@ public class TestPrintReferences { OutputAnalyzer output = new OutputAnalyzer(pb_enabled.start()); String countRegex = "[0-9]+ refs"; - String timeRegex = "\\([0-9]+[.,][0-9]+s, [0-9]+[.,][0-9]+s\\) [0-9]+[.,][0-9]+ms"; + String timeRegex = "[0-9]+[.,][0-9]+ms"; output.shouldMatch(".* GC\\([0-9]+\\) SoftReference " + timeRegex + "\n" + ".* GC\\([0-9]+\\) WeakReference " + timeRegex + "\n" + diff --git a/hotspot/test/native/logging/test_gcTraceTime.cpp b/hotspot/test/native/logging/test_gcTraceTime.cpp index 2046cc8c5a9..05763d59e22 100644 --- a/hotspot/test/native/logging/test_gcTraceTime.cpp +++ b/hotspot/test/native/logging/test_gcTraceTime.cpp @@ -48,8 +48,8 @@ TEST_VM_F(GCTraceTimeTest, full) { } const char* expected[] = { - "[gc,start", "] Test GC (Allocation Failure) (", "s)", - "[gc", "] Test GC (Allocation Failure) ", "M) (", "s, ", "s) ", "ms", + "[gc,start", "] Test GC (Allocation Failure)", + "[gc", "] Test GC (Allocation Failure) ", "M) ", "ms", NULL }; EXPECT_TRUE(file_contains_substrings_in_order(TestLogFileName, expected)); @@ -71,8 +71,8 @@ TEST_VM_F(GCTraceTimeTest, full_multitag) { } const char* expected[] = { - "[gc,ref,start", "] Test GC (Allocation Failure) (", "s)", - "[gc,ref", "] Test GC (Allocation Failure) ", "M) (", "s, ", "s) ", "ms", + "[gc,ref,start", "] Test GC (Allocation Failure)", + "[gc,ref", "] Test GC (Allocation Failure) ", "M) ", "ms", NULL }; EXPECT_TRUE(file_contains_substrings_in_order(TestLogFileName, expected)); @@ -92,17 +92,17 @@ TEST_VM_F(GCTraceTimeTest, no_heap) { } const char* expected[] = { - // [2.975s][debug][gc,start] Test GC (Allocation Failure) (2.975s) - "[gc,start", "] Test GC (Allocation Failure) (", "s)", - // [2.975s][debug][gc ] Test GC (Allocation Failure) (2.975s, 2.975s) 0.026ms - "[gc", "] Test GC (Allocation Failure) ", "(", "s, ", "s) ", "ms", + // [2.975s][debug][gc,start] Test GC (Allocation Failure) + "[gc,start", "] Test GC (Allocation Failure)", + // [2.975s][debug][gc ] Test GC (Allocation Failure) 0.026ms + "[gc", "] Test GC (Allocation Failure) ", "ms", NULL }; EXPECT_TRUE(file_contains_substrings_in_order(TestLogFileName, expected)); const char* not_expected[] = { - // [2.975s][debug][gc ] Test GC 59M->59M(502M) (2.975s, 2.975s) 0.026ms - "[gc", "] Test GC ", "M) (", "s, ", "s) ", "ms", + // [2.975s][debug][gc ] Test GC 59M->59M(502M) 0.026ms + "[gc", "] Test GC ", "M) ", "ms", }; EXPECT_FALSE(file_contains_substrings_in_order(TestLogFileName, not_expected)); } @@ -123,10 +123,10 @@ TEST_VM_F(GCTraceTimeTest, no_cause) { } const char* expected[] = { - // [2.975s][debug][gc,start] Test GC (2.975s) - "[gc,start", "] Test GC ", "s)", - // [2.975s][debug][gc ] Test GC 59M->59M(502M) (2.975s, 2.975s) 0.026ms - "[gc", "] Test GC ", "M) (", "s, ", "s) ", "ms", + // [2.975s][debug][gc,start] Test GC + "[gc,start", "] Test GC", + // [2.975s][debug][gc ] Test GC 59M->59M(502M) 0.026ms + "[gc", "] Test GC ", "M) ", "ms", NULL }; EXPECT_TRUE(file_contains_substrings_in_order(TestLogFileName, expected)); @@ -146,17 +146,17 @@ TEST_VM_F(GCTraceTimeTest, no_heap_no_cause) { } const char* expected[] = { - // [2.975s][debug][gc,start] Test GC (2.975s) - "[gc,start", "] Test GC ", "s)", - // [2.975s][debug][gc ] Test GC (2.975s, 2.975s) 0.026ms - "[gc", "] Test GC ", "(", "s, ", "s) ", "ms", + // [2.975s][debug][gc,start] Test GC + "[gc,start", "] Test GC", + // [2.975s][debug][gc ] Test GC 0.026ms + "[gc", "] Test GC ", "ms", NULL }; EXPECT_TRUE(file_contains_substrings_in_order(TestLogFileName, expected)); const char* not_expected[] = { - // [2.975s][debug][gc ] Test GC 59M->59M(502M) (2.975s, 2.975s) 0.026ms - "[gc", "] Test GC ", "M) (", "s, ", "s) ", "ms", + // [2.975s][debug][gc ] Test GC 59M->59M(502M) 0.026ms + "[gc", "] Test GC ", "M) ", "ms", }; EXPECT_FALSE(file_contains_substrings_in_order(TestLogFileName, not_expected)); } diff --git a/hotspot/test/serviceability/logging/TestLogRotation.java b/hotspot/test/serviceability/logging/TestLogRotation.java index f1eaf41acc2..c6f971a7af8 100644 --- a/hotspot/test/serviceability/logging/TestLogRotation.java +++ b/hotspot/test/serviceability/logging/TestLogRotation.java @@ -41,8 +41,8 @@ class GCLoggingGenerator { public static void main(String[] args) throws Exception { long sizeOfLog = Long.parseLong(args[0]); - long lines = sizeOfLog / 80; - // full.GC generates ad least 1-line which is not shorter then 80 chars + long lines = sizeOfLog / 70; + // full.GC generates ad least 1-line which is not shorter then 70 chars // for some GC 2 shorter lines are generated for (long i = 0; i < lines; i++) { System.gc();