annotate src/share/vm/gc_implementation/g1/concurrentG1RefineThread.cpp @ 20211:82693fb204a5

8038930: G1CodeRootSet::test fails with assert(_num_chunks_handed_out == 0) failed: No elements must have been handed out yet Summary: The test incorrectly assumed that it had been started with no other previous compilation activity. Fix this by allowing multiple code root free chunk lists, and use one separate from the global one to perform the test. Reviewed-by: brutisso
author tschatzl
date Wed, 16 Apr 2014 10:14:50 +0200
parents 581e70386ec9
children 570cb6369f17
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
1 /*
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1394
diff changeset
2 * Copyright (c) 2001, 2010, Oracle and/or its affiliates. All rights reserved.
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
4 *
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
7 * published by the Free Software Foundation.
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
8 *
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
13 * accompanied this code).
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
14 *
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
18 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1394
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1394
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1394
diff changeset
21 * questions.
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
22 *
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
23 */
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
24
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
25 #include "precompiled.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
26 #include "gc_implementation/g1/concurrentG1Refine.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
27 #include "gc_implementation/g1/concurrentG1RefineThread.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
28 #include "gc_implementation/g1/g1CollectedHeap.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
29 #include "gc_implementation/g1/g1CollectorPolicy.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
30 #include "memory/resourceArea.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
31 #include "runtime/handles.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
32 #include "runtime/mutexLocker.hpp"
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
33
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
34 ConcurrentG1RefineThread::
795
215f81b4d9b3 6841831: G1: assert(contains_reference(from),"We just added it!") fires
iveresov
parents: 794
diff changeset
35 ConcurrentG1RefineThread(ConcurrentG1Refine* cg1r, ConcurrentG1RefineThread *next,
17844
8847586c9037 8016302: Change type of the number of GC workers to unsigned int (2)
vkempik
parents: 3919
diff changeset
36 uint worker_id_offset, uint worker_id) :
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
37 ConcurrentGCThread(),
795
215f81b4d9b3 6841831: G1: assert(contains_reference(from),"We just added it!") fires
iveresov
parents: 794
diff changeset
38 _worker_id_offset(worker_id_offset),
794
315a5d70b295 6484957: G1: parallel concurrent refinement
iveresov
parents: 751
diff changeset
39 _worker_id(worker_id),
315a5d70b295 6484957: G1: parallel concurrent refinement
iveresov
parents: 751
diff changeset
40 _active(false),
315a5d70b295 6484957: G1: parallel concurrent refinement
iveresov
parents: 751
diff changeset
41 _next(next),
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
42 _monitor(NULL),
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
43 _cg1r(cg1r),
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
44 _vtime_accum(0.0)
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
45 {
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
46
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
47 // Each thread has its own monitor. The i-th thread is responsible for signalling
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
48 // to thread i+1 if the number of buffers in the queue exceeds a threashold for this
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
49 // thread. Monitors are also used to wake up the threads during termination.
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
50 // The 0th worker in notified by mutator threads and has a special monitor.
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
51 // The last worker is used for young gen rset size sampling.
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
52 if (worker_id > 0) {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
53 _monitor = new Monitor(Mutex::nonleaf, "Refinement monitor", true);
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
54 } else {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
55 _monitor = DirtyCardQ_CBL_mon;
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
56 }
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
57 initialize();
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
58 create_and_start();
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
59 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
60
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
61 void ConcurrentG1RefineThread::initialize() {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
62 if (_worker_id < cg1r()->worker_thread_num()) {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
63 // Current thread activation threshold
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
64 _threshold = MIN2<int>(cg1r()->thread_threshold_step() * (_worker_id + 1) + cg1r()->green_zone(),
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
65 cg1r()->yellow_zone());
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
66 // A thread deactivates once the number of buffer reached a deactivation threshold
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
67 _deactivation_threshold = MAX2<int>(_threshold - cg1r()->thread_threshold_step(), cg1r()->green_zone());
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
68 } else {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
69 set_active(true);
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
70 }
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
71 }
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
72
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
73 void ConcurrentG1RefineThread::sample_young_list_rs_lengths() {
20192
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
74 SuspendibleThreadSetJoiner sts;
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
75 G1CollectedHeap* g1h = G1CollectedHeap::heap();
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
76 G1CollectorPolicy* g1p = g1h->g1_policy();
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
77 if (g1p->adaptive_young_list_length()) {
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
78 int regions_visited = 0;
1394
1316cec51b4d 6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents: 1282
diff changeset
79 g1h->young_list()->rs_length_sampling_init();
1316cec51b4d 6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents: 1282
diff changeset
80 while (g1h->young_list()->rs_length_sampling_more()) {
1316cec51b4d 6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents: 1282
diff changeset
81 g1h->young_list()->rs_length_sampling_next();
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
82 ++regions_visited;
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
83
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
84 // we try to yield every time we visit 10 regions
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
85 if (regions_visited == 10) {
20192
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
86 if (sts.should_yield()) {
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
87 sts.yield();
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
88 // we just abandon the iteration
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
89 break;
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
90 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
91 regions_visited = 0;
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
92 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
93 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
94
3919
4f41766176cf 7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents: 1972
diff changeset
95 g1p->revise_young_list_target_length_if_necessary();
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
96 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
97 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
98
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
99 void ConcurrentG1RefineThread::run_young_rs_sampling() {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
100 DirtyCardQueueSet& dcqs = JavaThread::dirty_card_queue_set();
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
101 _vtime_start = os::elapsedVTime();
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
102 while(!_should_terminate) {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
103 sample_young_list_rs_lengths();
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
104
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
105 if (os::supports_vtime()) {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
106 _vtime_accum = (os::elapsedVTime() - _vtime_start);
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
107 } else {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
108 _vtime_accum = 0.0;
794
315a5d70b295 6484957: G1: parallel concurrent refinement
iveresov
parents: 751
diff changeset
109 }
315a5d70b295 6484957: G1: parallel concurrent refinement
iveresov
parents: 751
diff changeset
110
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
111 MutexLockerEx x(_monitor, Mutex::_no_safepoint_check_flag);
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
112 if (_should_terminate) {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
113 break;
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
114 }
1282
b81f3572f355 6928059: G1: command line parameter renaming
tonyp
parents: 1111
diff changeset
115 _monitor->wait(Mutex::_no_safepoint_check_flag, G1ConcRefinementServiceIntervalMillis);
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
116 }
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
117 }
794
315a5d70b295 6484957: G1: parallel concurrent refinement
iveresov
parents: 751
diff changeset
118
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
119 void ConcurrentG1RefineThread::wait_for_completed_buffers() {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
120 DirtyCardQueueSet& dcqs = JavaThread::dirty_card_queue_set();
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
121 MutexLockerEx x(_monitor, Mutex::_no_safepoint_check_flag);
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
122 while (!_should_terminate && !is_active()) {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
123 _monitor->wait(Mutex::_no_safepoint_check_flag);
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
124 }
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
125 }
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
126
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
127 bool ConcurrentG1RefineThread::is_active() {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
128 DirtyCardQueueSet& dcqs = JavaThread::dirty_card_queue_set();
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
129 return _worker_id > 0 ? _active : dcqs.process_completed_buffers();
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
130 }
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
131
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
132 void ConcurrentG1RefineThread::activate() {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
133 MutexLockerEx x(_monitor, Mutex::_no_safepoint_check_flag);
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
134 if (_worker_id > 0) {
1282
b81f3572f355 6928059: G1: command line parameter renaming
tonyp
parents: 1111
diff changeset
135 if (G1TraceConcRefinement) {
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
136 DirtyCardQueueSet& dcqs = JavaThread::dirty_card_queue_set();
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
137 gclog_or_tty->print_cr("G1-Refine-activated worker %d, on threshold %d, current %d",
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
138 _worker_id, _threshold, (int)dcqs.completed_buffers_num());
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
139 }
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
140 set_active(true);
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
141 } else {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
142 DirtyCardQueueSet& dcqs = JavaThread::dirty_card_queue_set();
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
143 dcqs.set_process_completed(true);
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
144 }
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
145 _monitor->notify();
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
146 }
794
315a5d70b295 6484957: G1: parallel concurrent refinement
iveresov
parents: 751
diff changeset
147
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
148 void ConcurrentG1RefineThread::deactivate() {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
149 MutexLockerEx x(_monitor, Mutex::_no_safepoint_check_flag);
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
150 if (_worker_id > 0) {
1282
b81f3572f355 6928059: G1: command line parameter renaming
tonyp
parents: 1111
diff changeset
151 if (G1TraceConcRefinement) {
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
152 DirtyCardQueueSet& dcqs = JavaThread::dirty_card_queue_set();
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
153 gclog_or_tty->print_cr("G1-Refine-deactivated worker %d, off threshold %d, current %d",
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
154 _worker_id, _deactivation_threshold, (int)dcqs.completed_buffers_num());
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
155 }
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
156 set_active(false);
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
157 } else {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
158 DirtyCardQueueSet& dcqs = JavaThread::dirty_card_queue_set();
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
159 dcqs.set_process_completed(false);
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
160 }
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
161 }
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
162
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
163 void ConcurrentG1RefineThread::run() {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
164 initialize_in_thread();
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
165 wait_for_universe_init();
794
315a5d70b295 6484957: G1: parallel concurrent refinement
iveresov
parents: 751
diff changeset
166
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
167 if (_worker_id >= cg1r()->worker_thread_num()) {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
168 run_young_rs_sampling();
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
169 terminate();
1394
1316cec51b4d 6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents: 1282
diff changeset
170 return;
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
171 }
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
172
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
173 _vtime_start = os::elapsedVTime();
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
174 while (!_should_terminate) {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
175 DirtyCardQueueSet& dcqs = JavaThread::dirty_card_queue_set();
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
176
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
177 // Wait for work
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
178 wait_for_completed_buffers();
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
179
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
180 if (_should_terminate) {
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
181 break;
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
182 }
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
183
20192
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
184 {
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
185 SuspendibleThreadSetJoiner sts;
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
186
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
187 do {
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
188 int curr_buffer_num = (int)dcqs.completed_buffers_num();
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
189 // If the number of the buffers falls down into the yellow zone,
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
190 // that means that the transition period after the evacuation pause has ended.
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
191 if (dcqs.completed_queue_padding() > 0 && curr_buffer_num <= cg1r()->yellow_zone()) {
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
192 dcqs.set_completed_queue_padding(0);
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
193 }
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
194
20192
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
195 if (_worker_id > 0 && curr_buffer_num <= _deactivation_threshold) {
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
196 // If the number of the buffer has fallen below our threshold
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
197 // we should deactivate. The predecessor will reactivate this
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
198 // thread should the number of the buffers cross the threshold again.
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
199 deactivate();
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
200 break;
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
201 }
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
202
20192
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
203 // Check if we need to activate the next thread.
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
204 if (_next != NULL && !_next->is_active() && curr_buffer_num > _next->_threshold) {
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
205 _next->activate();
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
206 }
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
207 } while (dcqs.apply_closure_to_completed_buffer(_worker_id + _worker_id_offset, cg1r()->green_zone()));
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
208
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
209 // We can exit the loop above while being active if there was a yield request.
581e70386ec9 8039147: Cleanup SuspendibleThreadSet
pliden
parents: 17844
diff changeset
210 if (is_active()) {
794
315a5d70b295 6484957: G1: parallel concurrent refinement
iveresov
parents: 751
diff changeset
211 deactivate();
315a5d70b295 6484957: G1: parallel concurrent refinement
iveresov
parents: 751
diff changeset
212 }
315a5d70b295 6484957: G1: parallel concurrent refinement
iveresov
parents: 751
diff changeset
213 }
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
214
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
215 if (os::supports_vtime()) {
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
216 _vtime_accum = (os::elapsedVTime() - _vtime_start);
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
217 } else {
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
218 _vtime_accum = 0.0;
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
219 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
220 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
221 assert(_should_terminate, "just checking");
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
222 terminate();
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
223 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
224
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
225 void ConcurrentG1RefineThread::stop() {
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
226 // it is ok to take late safepoints here, if needed
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
227 {
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
228 MutexLockerEx mu(Terminator_lock);
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
229 _should_terminate = true;
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
230 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
231
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
232 {
1111
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
233 MutexLockerEx x(_monitor, Mutex::_no_safepoint_check_flag);
44f61c24ddab 6862387: tune concurrent refinement further
iveresov
parents: 1019
diff changeset
234 _monitor->notify();
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
235 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
236
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
237 {
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
238 MutexLockerEx mu(Terminator_lock);
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
239 while (!_has_terminated) {
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
240 Terminator_lock->wait();
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
241 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
242 }
1282
b81f3572f355 6928059: G1: command line parameter renaming
tonyp
parents: 1111
diff changeset
243 if (G1TraceConcRefinement) {
b81f3572f355 6928059: G1: command line parameter renaming
tonyp
parents: 1111
diff changeset
244 gclog_or_tty->print_cr("G1-Refine-stop");
b81f3572f355 6928059: G1: command line parameter renaming
tonyp
parents: 1111
diff changeset
245 }
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
246 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
247
1019
035d2e036a9b 6885041: G1: inconsistent thread dump
tonyp
parents: 936
diff changeset
248 void ConcurrentG1RefineThread::print() const {
035d2e036a9b 6885041: G1: inconsistent thread dump
tonyp
parents: 936
diff changeset
249 print_on(tty);
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents:
diff changeset
250 }
1019
035d2e036a9b 6885041: G1: inconsistent thread dump
tonyp
parents: 936
diff changeset
251
035d2e036a9b 6885041: G1: inconsistent thread dump
tonyp
parents: 936
diff changeset
252 void ConcurrentG1RefineThread::print_on(outputStream* st) const {
035d2e036a9b 6885041: G1: inconsistent thread dump
tonyp
parents: 936
diff changeset
253 st->print("\"G1 Concurrent Refinement Thread#%d\" ", _worker_id);
035d2e036a9b 6885041: G1: inconsistent thread dump
tonyp
parents: 936
diff changeset
254 Thread::print_on(st);
035d2e036a9b 6885041: G1: inconsistent thread dump
tonyp
parents: 936
diff changeset
255 st->cr();
035d2e036a9b 6885041: G1: inconsistent thread dump
tonyp
parents: 936
diff changeset
256 }