annotate src/share/vm/gc_implementation/parallelScavenge/gcTaskThread.cpp @ 3285:49a67202bc67

7011855: G1: non-product flag to artificially grow the heap Summary: It introduces non-product cmd line parameter G1DummyRegionsPerGC which indicates how many "dummy" regions to allocate at the end of each GC. This allows the G1 heap to grow artificially and makes concurrent marking cycles more frequent irrespective of what the application that is running is doing. The dummy regions will be found totally empty during cleanup so this parameter can also be used to stress the concurrent cleanup operation. Reviewed-by: brutisso, johnc
author tonyp
date Tue, 19 Apr 2011 15:46:59 -0400
parents f95d63e2154a
children bca17e38de00
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1
a61af66fc99e Initial load
duke
parents:
diff changeset
2 /*
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
3 * Copyright (c) 2002, 2010, Oracle and/or its affiliates. All rights reserved.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
4 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
5 *
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
8 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
9 *
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
14 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
15 *
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
18 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
19 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 0
diff changeset
20 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 0
diff changeset
21 * or visit www.oracle.com if you need additional information or have any
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 0
diff changeset
22 * questions.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
23 *
a61af66fc99e Initial load
duke
parents:
diff changeset
24 */
a61af66fc99e Initial load
duke
parents:
diff changeset
25
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
26 #include "precompiled.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
27 #include "gc_implementation/parallelScavenge/gcTaskManager.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
28 #include "gc_implementation/parallelScavenge/gcTaskThread.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
29 #include "memory/allocation.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
30 #include "memory/allocation.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
31 #include "memory/resourceArea.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
32 #include "runtime/handles.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
33 #include "runtime/handles.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
34 #include "runtime/os.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
35 #include "runtime/thread.hpp"
0
a61af66fc99e Initial load
duke
parents:
diff changeset
36
a61af66fc99e Initial load
duke
parents:
diff changeset
37 GCTaskThread::GCTaskThread(GCTaskManager* manager,
a61af66fc99e Initial load
duke
parents:
diff changeset
38 uint which,
a61af66fc99e Initial load
duke
parents:
diff changeset
39 uint processor_id) :
a61af66fc99e Initial load
duke
parents:
diff changeset
40 _manager(manager),
a61af66fc99e Initial load
duke
parents:
diff changeset
41 _processor_id(processor_id),
a61af66fc99e Initial load
duke
parents:
diff changeset
42 _time_stamps(NULL),
a61af66fc99e Initial load
duke
parents:
diff changeset
43 _time_stamp_index(0)
a61af66fc99e Initial load
duke
parents:
diff changeset
44 {
a61af66fc99e Initial load
duke
parents:
diff changeset
45 if (!os::create_thread(this, os::pgc_thread))
a61af66fc99e Initial load
duke
parents:
diff changeset
46 vm_exit_out_of_memory(0, "Cannot create GC thread. Out of system resources.");
a61af66fc99e Initial load
duke
parents:
diff changeset
47
a61af66fc99e Initial load
duke
parents:
diff changeset
48 if (PrintGCTaskTimeStamps) {
a61af66fc99e Initial load
duke
parents:
diff changeset
49 _time_stamps = NEW_C_HEAP_ARRAY(GCTaskTimeStamp, GCTaskTimeStampEntries );
a61af66fc99e Initial load
duke
parents:
diff changeset
50
a61af66fc99e Initial load
duke
parents:
diff changeset
51 guarantee(_time_stamps != NULL, "Sanity");
a61af66fc99e Initial load
duke
parents:
diff changeset
52 }
a61af66fc99e Initial load
duke
parents:
diff changeset
53 set_id(which);
a61af66fc99e Initial load
duke
parents:
diff changeset
54 set_name("GC task thread#%d (ParallelGC)", which);
a61af66fc99e Initial load
duke
parents:
diff changeset
55 }
a61af66fc99e Initial load
duke
parents:
diff changeset
56
a61af66fc99e Initial load
duke
parents:
diff changeset
57 GCTaskThread::~GCTaskThread() {
a61af66fc99e Initial load
duke
parents:
diff changeset
58 if (_time_stamps != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
59 FREE_C_HEAP_ARRAY(GCTaskTimeStamp, _time_stamps);
a61af66fc99e Initial load
duke
parents:
diff changeset
60 }
a61af66fc99e Initial load
duke
parents:
diff changeset
61 }
a61af66fc99e Initial load
duke
parents:
diff changeset
62
a61af66fc99e Initial load
duke
parents:
diff changeset
63 void GCTaskThread::start() {
a61af66fc99e Initial load
duke
parents:
diff changeset
64 os::start_thread(this);
a61af66fc99e Initial load
duke
parents:
diff changeset
65 }
a61af66fc99e Initial load
duke
parents:
diff changeset
66
a61af66fc99e Initial load
duke
parents:
diff changeset
67 GCTaskTimeStamp* GCTaskThread::time_stamp_at(uint index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
68 guarantee(index < GCTaskTimeStampEntries, "increase GCTaskTimeStampEntries");
a61af66fc99e Initial load
duke
parents:
diff changeset
69
a61af66fc99e Initial load
duke
parents:
diff changeset
70 return &(_time_stamps[index]);
a61af66fc99e Initial load
duke
parents:
diff changeset
71 }
a61af66fc99e Initial load
duke
parents:
diff changeset
72
a61af66fc99e Initial load
duke
parents:
diff changeset
73 void GCTaskThread::print_task_time_stamps() {
a61af66fc99e Initial load
duke
parents:
diff changeset
74 assert(PrintGCTaskTimeStamps, "Sanity");
a61af66fc99e Initial load
duke
parents:
diff changeset
75 assert(_time_stamps != NULL, "Sanity (Probably set PrintGCTaskTimeStamps late)");
a61af66fc99e Initial load
duke
parents:
diff changeset
76
a61af66fc99e Initial load
duke
parents:
diff changeset
77 tty->print_cr("GC-Thread %u entries: %d", id(), _time_stamp_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
78 for(uint i=0; i<_time_stamp_index; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
79 GCTaskTimeStamp* time_stamp = time_stamp_at(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
80 tty->print_cr("\t[ %s " INT64_FORMAT " " INT64_FORMAT " ]",
a61af66fc99e Initial load
duke
parents:
diff changeset
81 time_stamp->name(),
a61af66fc99e Initial load
duke
parents:
diff changeset
82 time_stamp->entry_time(),
a61af66fc99e Initial load
duke
parents:
diff changeset
83 time_stamp->exit_time());
a61af66fc99e Initial load
duke
parents:
diff changeset
84 }
a61af66fc99e Initial load
duke
parents:
diff changeset
85
a61af66fc99e Initial load
duke
parents:
diff changeset
86 // Reset after dumping the data
a61af66fc99e Initial load
duke
parents:
diff changeset
87 _time_stamp_index = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
88 }
a61af66fc99e Initial load
duke
parents:
diff changeset
89
a61af66fc99e Initial load
duke
parents:
diff changeset
90 void GCTaskThread::print_on(outputStream* st) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
91 st->print("\"%s\" ", name());
a61af66fc99e Initial load
duke
parents:
diff changeset
92 Thread::print_on(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
93 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
94 }
a61af66fc99e Initial load
duke
parents:
diff changeset
95
a61af66fc99e Initial load
duke
parents:
diff changeset
96 void GCTaskThread::run() {
a61af66fc99e Initial load
duke
parents:
diff changeset
97 // Set up the thread for stack overflow support
a61af66fc99e Initial load
duke
parents:
diff changeset
98 this->record_stack_base_and_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
99 this->initialize_thread_local_storage();
a61af66fc99e Initial load
duke
parents:
diff changeset
100 // Bind yourself to your processor.
a61af66fc99e Initial load
duke
parents:
diff changeset
101 if (processor_id() != GCTaskManager::sentinel_worker()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
102 if (TraceGCTaskThread) {
a61af66fc99e Initial load
duke
parents:
diff changeset
103 tty->print_cr("GCTaskThread::run: "
a61af66fc99e Initial load
duke
parents:
diff changeset
104 " binding to processor %u", processor_id());
a61af66fc99e Initial load
duke
parents:
diff changeset
105 }
a61af66fc99e Initial load
duke
parents:
diff changeset
106 if (!os::bind_to_processor(processor_id())) {
a61af66fc99e Initial load
duke
parents:
diff changeset
107 DEBUG_ONLY(
a61af66fc99e Initial load
duke
parents:
diff changeset
108 warning("Couldn't bind GCTaskThread %u to processor %u",
a61af66fc99e Initial load
duke
parents:
diff changeset
109 which(), processor_id());
a61af66fc99e Initial load
duke
parents:
diff changeset
110 )
a61af66fc99e Initial load
duke
parents:
diff changeset
111 }
a61af66fc99e Initial load
duke
parents:
diff changeset
112 }
a61af66fc99e Initial load
duke
parents:
diff changeset
113 // Part of thread setup.
a61af66fc99e Initial load
duke
parents:
diff changeset
114 // ??? Are these set up once here to make subsequent ones fast?
a61af66fc99e Initial load
duke
parents:
diff changeset
115 HandleMark hm_outer;
a61af66fc99e Initial load
duke
parents:
diff changeset
116 ResourceMark rm_outer;
a61af66fc99e Initial load
duke
parents:
diff changeset
117
a61af66fc99e Initial load
duke
parents:
diff changeset
118 TimeStamp timer;
a61af66fc99e Initial load
duke
parents:
diff changeset
119
a61af66fc99e Initial load
duke
parents:
diff changeset
120 for (;/* ever */;) {
a61af66fc99e Initial load
duke
parents:
diff changeset
121 // These are so we can flush the resources allocated in the inner loop.
a61af66fc99e Initial load
duke
parents:
diff changeset
122 HandleMark hm_inner;
a61af66fc99e Initial load
duke
parents:
diff changeset
123 ResourceMark rm_inner;
a61af66fc99e Initial load
duke
parents:
diff changeset
124 for (; /* break */; ) {
a61af66fc99e Initial load
duke
parents:
diff changeset
125 // This will block until there is a task to be gotten.
a61af66fc99e Initial load
duke
parents:
diff changeset
126 GCTask* task = manager()->get_task(which());
a61af66fc99e Initial load
duke
parents:
diff changeset
127
a61af66fc99e Initial load
duke
parents:
diff changeset
128 // In case the update is costly
a61af66fc99e Initial load
duke
parents:
diff changeset
129 if (PrintGCTaskTimeStamps) {
a61af66fc99e Initial load
duke
parents:
diff changeset
130 timer.update();
a61af66fc99e Initial load
duke
parents:
diff changeset
131 }
a61af66fc99e Initial load
duke
parents:
diff changeset
132
a61af66fc99e Initial load
duke
parents:
diff changeset
133 jlong entry_time = timer.ticks();
a61af66fc99e Initial load
duke
parents:
diff changeset
134 char* name = task->name();
a61af66fc99e Initial load
duke
parents:
diff changeset
135
a61af66fc99e Initial load
duke
parents:
diff changeset
136 task->do_it(manager(), which());
a61af66fc99e Initial load
duke
parents:
diff changeset
137 manager()->note_completion(which());
a61af66fc99e Initial load
duke
parents:
diff changeset
138
a61af66fc99e Initial load
duke
parents:
diff changeset
139 if (PrintGCTaskTimeStamps) {
a61af66fc99e Initial load
duke
parents:
diff changeset
140 assert(_time_stamps != NULL, "Sanity (PrintGCTaskTimeStamps set late?)");
a61af66fc99e Initial load
duke
parents:
diff changeset
141
a61af66fc99e Initial load
duke
parents:
diff changeset
142 timer.update();
a61af66fc99e Initial load
duke
parents:
diff changeset
143
a61af66fc99e Initial load
duke
parents:
diff changeset
144 GCTaskTimeStamp* time_stamp = time_stamp_at(_time_stamp_index++);
a61af66fc99e Initial load
duke
parents:
diff changeset
145
a61af66fc99e Initial load
duke
parents:
diff changeset
146 time_stamp->set_name(name);
a61af66fc99e Initial load
duke
parents:
diff changeset
147 time_stamp->set_entry_time(entry_time);
a61af66fc99e Initial load
duke
parents:
diff changeset
148 time_stamp->set_exit_time(timer.ticks());
a61af66fc99e Initial load
duke
parents:
diff changeset
149 }
a61af66fc99e Initial load
duke
parents:
diff changeset
150
a61af66fc99e Initial load
duke
parents:
diff changeset
151 // Check if we should release our inner resources.
a61af66fc99e Initial load
duke
parents:
diff changeset
152 if (manager()->should_release_resources(which())) {
a61af66fc99e Initial load
duke
parents:
diff changeset
153 manager()->note_release(which());
a61af66fc99e Initial load
duke
parents:
diff changeset
154 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
155 }
a61af66fc99e Initial load
duke
parents:
diff changeset
156 }
a61af66fc99e Initial load
duke
parents:
diff changeset
157 }
a61af66fc99e Initial load
duke
parents:
diff changeset
158 }