From ff7db9b11ace0895a110df09c2d274505f5356ff Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erik=20=C3=96sterlund?= Date: Thu, 7 Jun 2018 17:40:15 +0200 Subject: [PATCH] 8204554: JFR TLAB tracing broken after 8202776 Reviewed-by: rkennke, stefank --- src/hotspot/share/gc/shared/collectedHeap.cpp | 3 ++- src/hotspot/share/gc/shared/collectedHeap.hpp | 3 +++ .../share/gc/shared/collectedHeap.inline.hpp | 24 ++++++++++++------- 3 files changed, 21 insertions(+), 9 deletions(-) diff --git a/src/hotspot/share/gc/shared/collectedHeap.cpp b/src/hotspot/share/gc/shared/collectedHeap.cpp index 18a5d69d41f..75af999fc0b 100644 --- a/src/hotspot/share/gc/shared/collectedHeap.cpp +++ b/src/hotspot/share/gc/shared/collectedHeap.cpp @@ -373,7 +373,8 @@ HeapWord* CollectedHeap::obj_allocate_raw(Klass* klass, size_t size, return result; } } - return Universe::heap()->mem_allocate(size, gc_overhead_limit_was_exceeded); + + return allocate_outside_tlab(klass, size, gc_overhead_limit_was_exceeded, THREAD); } HeapWord* CollectedHeap::allocate_from_tlab_slow(Klass* klass, size_t size, TRAPS) { diff --git a/src/hotspot/share/gc/shared/collectedHeap.hpp b/src/hotspot/share/gc/shared/collectedHeap.hpp index 3d5c71e46d2..a2ab0d6a253 100644 --- a/src/hotspot/share/gc/shared/collectedHeap.hpp +++ b/src/hotspot/share/gc/shared/collectedHeap.hpp @@ -144,6 +144,9 @@ class CollectedHeap : public CHeapObj { inline static HeapWord* allocate_from_tlab(Klass* klass, size_t size, TRAPS); static HeapWord* allocate_from_tlab_slow(Klass* klass, size_t size, TRAPS); + inline static HeapWord* allocate_outside_tlab(Klass* klass, size_t size, + bool* gc_overhead_limit_was_exceeded, TRAPS); + // Raw memory allocation facilities // The obj and array allocate methods are covers for these methods. // mem_allocate() should never be diff --git a/src/hotspot/share/gc/shared/collectedHeap.inline.hpp b/src/hotspot/share/gc/shared/collectedHeap.inline.hpp index 6c2893d9f54..08c8131333f 100644 --- a/src/hotspot/share/gc/shared/collectedHeap.inline.hpp +++ b/src/hotspot/share/gc/shared/collectedHeap.inline.hpp @@ -142,14 +142,6 @@ HeapWord* CollectedHeap::common_mem_allocate_noinit(Klass* klass, size_t size, T HeapWord* result = heap->obj_allocate_raw(klass, size, &gc_overhead_limit_was_exceeded, THREAD); if (result != NULL) { - NOT_PRODUCT(Universe::heap()-> - check_for_non_bad_heap_word_value(result, size)); - assert(!HAS_PENDING_EXCEPTION, - "Unexpected exception, will result in uninitialized storage"); - THREAD->incr_allocated_bytes(size * HeapWordSize); - - AllocTracer::send_allocation_outside_tlab(klass, result, size * HeapWordSize, THREAD); - return result; } @@ -198,6 +190,22 @@ HeapWord* CollectedHeap::allocate_from_tlab(Klass* klass, size_t size, TRAPS) { return obj; } +HeapWord* CollectedHeap::allocate_outside_tlab(Klass* klass, size_t size, + bool* gc_overhead_limit_was_exceeded, TRAPS) { + HeapWord* result = Universe::heap()->mem_allocate(size, gc_overhead_limit_was_exceeded); + if (result == NULL) { + return result; + } + + NOT_PRODUCT(Universe::heap()->check_for_non_bad_heap_word_value(result, size)); + assert(!HAS_PENDING_EXCEPTION, + "Unexpected exception, will result in uninitialized storage"); + THREAD->incr_allocated_bytes(size * HeapWordSize); + + AllocTracer::send_allocation_outside_tlab(klass, result, size * HeapWordSize, THREAD); + return result; +} + void CollectedHeap::init_obj(HeapWord* obj, size_t size) { assert(obj != NULL, "cannot initialize NULL object"); const size_t hs = oopDesc::header_size();