From dbdf722879598e428608c9ff7f42287e6c63547f Mon Sep 17 00:00:00 2001 From: Bengt Rutisson Date: Thu, 8 Oct 2015 12:44:12 +0200 Subject: [PATCH] 8138717: TestGCEventMixedWithG1ConcurrentMark.java fails Reviewed-by: jwilhelm, david --- hotspot/src/share/vm/gc/shared/collectedHeap.cpp | 4 ++++ hotspot/src/share/vm/gc/shared/gcId.cpp | 8 ++++++++ hotspot/src/share/vm/gc/shared/gcId.hpp | 9 +++++++++ hotspot/src/share/vm/gc/shared/genCollectedHeap.cpp | 2 +- 4 files changed, 22 insertions(+), 1 deletion(-) diff --git a/hotspot/src/share/vm/gc/shared/collectedHeap.cpp b/hotspot/src/share/vm/gc/shared/collectedHeap.cpp index 64d3054d147..006b7192c13 100644 --- a/hotspot/src/share/vm/gc/shared/collectedHeap.cpp +++ b/hotspot/src/share/vm/gc/shared/collectedHeap.cpp @@ -573,12 +573,14 @@ void CollectedHeap::resize_all_tlabs() { void CollectedHeap::pre_full_gc_dump(GCTimer* timer) { if (HeapDumpBeforeFullGC) { + GCIdMarkAndRestore gc_id_mark; GCTraceTime tt("Heap Dump (before full gc): ", PrintGCDetails, false, timer); // We are doing a full collection and a heap dump before // full collection has been requested. HeapDumper::dump_heap(); } if (PrintClassHistogramBeforeFullGC) { + GCIdMarkAndRestore gc_id_mark; GCTraceTime tt("Class Histogram (before full gc): ", PrintGCDetails, true, timer); VM_GC_HeapInspection inspector(gclog_or_tty, false /* ! full gc */); inspector.doit(); @@ -587,10 +589,12 @@ void CollectedHeap::pre_full_gc_dump(GCTimer* timer) { void CollectedHeap::post_full_gc_dump(GCTimer* timer) { if (HeapDumpAfterFullGC) { + GCIdMarkAndRestore gc_id_mark; GCTraceTime tt("Heap Dump (after full gc): ", PrintGCDetails, false, timer); HeapDumper::dump_heap(); } if (PrintClassHistogramAfterFullGC) { + GCIdMarkAndRestore gc_id_mark; GCTraceTime tt("Class Histogram (after full gc): ", PrintGCDetails, true, timer); VM_GC_HeapInspection inspector(gclog_or_tty, false /* ! full gc */); inspector.doit(); diff --git a/hotspot/src/share/vm/gc/shared/gcId.cpp b/hotspot/src/share/vm/gc/shared/gcId.cpp index 9b405601ff7..4964f27a8c4 100644 --- a/hotspot/src/share/vm/gc/shared/gcId.cpp +++ b/hotspot/src/share/vm/gc/shared/gcId.cpp @@ -59,3 +59,11 @@ GCIdMark::~GCIdMark() { currentNamedthread()->set_gc_id(GCId::undefined()); } +GCIdMarkAndRestore::GCIdMarkAndRestore() : _gc_id(GCId::create()) { + _previous_gc_id = GCId::current(); // will assert that the GC Id is not undefinied + currentNamedthread()->set_gc_id(_gc_id); +} + +GCIdMarkAndRestore::~GCIdMarkAndRestore() { + currentNamedthread()->set_gc_id(_previous_gc_id); +} diff --git a/hotspot/src/share/vm/gc/shared/gcId.hpp b/hotspot/src/share/vm/gc/shared/gcId.hpp index 855852fff24..5b53a8f37e4 100644 --- a/hotspot/src/share/vm/gc/shared/gcId.hpp +++ b/hotspot/src/share/vm/gc/shared/gcId.hpp @@ -29,6 +29,7 @@ class GCId : public AllStatic { friend class GCIdMark; + friend class GCIdMarkAndRestore; static uint _next_id; static const uint UNDEFINED = (uint)-1; static const uint create(); @@ -49,4 +50,12 @@ class GCIdMark : public StackObj { ~GCIdMark(); }; +class GCIdMarkAndRestore : public StackObj { + uint _gc_id; + uint _previous_gc_id; + public: + GCIdMarkAndRestore(); + ~GCIdMarkAndRestore(); +}; + #endif // SHARE_VM_GC_SHARED_GCID_HPP diff --git a/hotspot/src/share/vm/gc/shared/genCollectedHeap.cpp b/hotspot/src/share/vm/gc/shared/genCollectedHeap.cpp index 56eb70f8df0..588103db31a 100644 --- a/hotspot/src/share/vm/gc/shared/genCollectedHeap.cpp +++ b/hotspot/src/share/vm/gc/shared/genCollectedHeap.cpp @@ -488,7 +488,7 @@ void GenCollectedHeap::do_collection(bool full, bool must_restore_marks_for_biased_locking = false; if (max_generation == OldGen && _old_gen->should_collect(full, size, is_tlab)) { - GCIdMark gc_id_mark; + GCIdMarkAndRestore gc_id_mark; if (!complete) { // The full_collections increment was missed above. increment_total_full_collections();