From 5c99d95a63336d824babc525335bb5be31215e5c Mon Sep 17 00:00:00 2001 From: Kim Barrett Date: Mon, 26 Nov 2018 13:17:39 -0500 Subject: [PATCH] 8214202: DirtyCardQueueSet::get_completed_buffer should not clear _process_completed Remove flag clearing and simplify get_completed-buffer. Reviewed-by: tschatzl, sjohanss --- src/hotspot/share/gc/g1/dirtyCardQueue.cpp | 21 ++++++++++----------- src/hotspot/share/gc/shared/ptrQueue.cpp | 2 +- 2 files changed, 11 insertions(+), 12 deletions(-) diff --git a/src/hotspot/share/gc/g1/dirtyCardQueue.cpp b/src/hotspot/share/gc/g1/dirtyCardQueue.cpp index 67504982996..7529c6c4479 100644 --- a/src/hotspot/share/gc/g1/dirtyCardQueue.cpp +++ b/src/hotspot/share/gc/g1/dirtyCardQueue.cpp @@ -221,23 +221,22 @@ bool DirtyCardQueueSet::mut_process_buffer(BufferNode* node) { BufferNode* DirtyCardQueueSet::get_completed_buffer(size_t stop_at) { - BufferNode* nd = NULL; MutexLockerEx x(_cbl_mon, Mutex::_no_safepoint_check_flag); if (_n_completed_buffers <= stop_at) { - _process_completed = false; return NULL; } - if (_completed_buffers_head != NULL) { - nd = _completed_buffers_head; - assert(_n_completed_buffers > 0, "Invariant"); - _completed_buffers_head = nd->next(); - _n_completed_buffers--; - if (_completed_buffers_head == NULL) { - assert(_n_completed_buffers == 0, "Invariant"); - _completed_buffers_tail = NULL; - } + assert(_n_completed_buffers > 0, "invariant"); + assert(_completed_buffers_head != NULL, "invariant"); + assert(_completed_buffers_tail != NULL, "invariant"); + + BufferNode* nd = _completed_buffers_head; + _completed_buffers_head = nd->next(); + _n_completed_buffers--; + if (_completed_buffers_head == NULL) { + assert(_n_completed_buffers == 0, "Invariant"); + _completed_buffers_tail = NULL; } DEBUG_ONLY(assert_completed_buffer_list_len_correct_locked()); return nd; diff --git a/src/hotspot/share/gc/shared/ptrQueue.cpp b/src/hotspot/share/gc/shared/ptrQueue.cpp index fb26c1dba52..03c1861b056 100644 --- a/src/hotspot/share/gc/shared/ptrQueue.cpp +++ b/src/hotspot/share/gc/shared/ptrQueue.cpp @@ -327,7 +327,7 @@ void PtrQueueSet::merge_bufferlists(PtrQueueSet *src) { void PtrQueueSet::notify_if_necessary() { MutexLockerEx x(_cbl_mon, Mutex::_no_safepoint_check_flag); - assert(_process_completed_threshold >= 0, "_process_completed is negative"); + assert(_process_completed_threshold >= 0, "_process_completed_threshold is negative"); if (_n_completed_buffers >= (size_t)_process_completed_threshold || _max_completed_queue == 0) { _process_completed = true; if (_notify_when_complete)