annotate src/share/vm/gc_implementation/parallelScavenge/gcTaskThread.cpp @ 10185:d50cc62e94ff

8012715: G1: GraphKit accesses PtrQueue::_index as int but is size_t Summary: In graphKit INT operations were generated to access PtrQueue::_index which has type size_t. This is 64 bit on 64-bit machines. No problems occur on little endian machines as long as the index fits into 32 bit, but on big endian machines the upper part is read, which is zero. This leads to unnecessary branches to the slow path in the runtime. Reviewed-by: twisti, johnc Contributed-by: Martin Doerr <martin.doerr@sap.com>
author johnc
date Wed, 24 Apr 2013 14:48:43 -0700
parents b9a9ed0f8eeb
children 746b070f5022
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 /*
6842
b9a9ed0f8eeb 7197424: update copyright year to match last edit in jdk8 hotspot repository
mikael
parents: 6197
diff changeset
3 * Copyright (c) 2002, 2012, 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) {
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 4132
diff changeset
49 _time_stamps = NEW_C_HEAP_ARRAY(GCTaskTimeStamp, GCTaskTimeStampEntries, mtGC);
0
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) {
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 4132
diff changeset
59 FREE_C_HEAP_ARRAY(GCTaskTimeStamp, _time_stamps, mtGC);
0
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
4095
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
96 // GC workers get tasks from the GCTaskManager and execute
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
97 // them in this method. If there are no tasks to execute,
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
98 // the GC workers wait in the GCTaskManager's get_task()
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
99 // for tasks to be enqueued for execution.
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
100
0
a61af66fc99e Initial load
duke
parents:
diff changeset
101 void GCTaskThread::run() {
a61af66fc99e Initial load
duke
parents:
diff changeset
102 // Set up the thread for stack overflow support
a61af66fc99e Initial load
duke
parents:
diff changeset
103 this->record_stack_base_and_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
104 this->initialize_thread_local_storage();
a61af66fc99e Initial load
duke
parents:
diff changeset
105 // Bind yourself to your processor.
a61af66fc99e Initial load
duke
parents:
diff changeset
106 if (processor_id() != GCTaskManager::sentinel_worker()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
107 if (TraceGCTaskThread) {
a61af66fc99e Initial load
duke
parents:
diff changeset
108 tty->print_cr("GCTaskThread::run: "
a61af66fc99e Initial load
duke
parents:
diff changeset
109 " binding to processor %u", processor_id());
a61af66fc99e Initial load
duke
parents:
diff changeset
110 }
a61af66fc99e Initial load
duke
parents:
diff changeset
111 if (!os::bind_to_processor(processor_id())) {
a61af66fc99e Initial load
duke
parents:
diff changeset
112 DEBUG_ONLY(
a61af66fc99e Initial load
duke
parents:
diff changeset
113 warning("Couldn't bind GCTaskThread %u to processor %u",
a61af66fc99e Initial load
duke
parents:
diff changeset
114 which(), processor_id());
a61af66fc99e Initial load
duke
parents:
diff changeset
115 )
a61af66fc99e Initial load
duke
parents:
diff changeset
116 }
a61af66fc99e Initial load
duke
parents:
diff changeset
117 }
a61af66fc99e Initial load
duke
parents:
diff changeset
118 // Part of thread setup.
a61af66fc99e Initial load
duke
parents:
diff changeset
119 // ??? Are these set up once here to make subsequent ones fast?
a61af66fc99e Initial load
duke
parents:
diff changeset
120 HandleMark hm_outer;
a61af66fc99e Initial load
duke
parents:
diff changeset
121 ResourceMark rm_outer;
a61af66fc99e Initial load
duke
parents:
diff changeset
122
a61af66fc99e Initial load
duke
parents:
diff changeset
123 TimeStamp timer;
a61af66fc99e Initial load
duke
parents:
diff changeset
124
a61af66fc99e Initial load
duke
parents:
diff changeset
125 for (;/* ever */;) {
a61af66fc99e Initial load
duke
parents:
diff changeset
126 // These are so we can flush the resources allocated in the inner loop.
a61af66fc99e Initial load
duke
parents:
diff changeset
127 HandleMark hm_inner;
a61af66fc99e Initial load
duke
parents:
diff changeset
128 ResourceMark rm_inner;
a61af66fc99e Initial load
duke
parents:
diff changeset
129 for (; /* break */; ) {
a61af66fc99e Initial load
duke
parents:
diff changeset
130 // This will block until there is a task to be gotten.
a61af66fc99e Initial load
duke
parents:
diff changeset
131 GCTask* task = manager()->get_task(which());
4132
6d7d0790074d 7119584: UseParallelGC barrier task can be overwritten.
jmasa
parents: 4095
diff changeset
132 // Record if this is an idle task for later use.
6d7d0790074d 7119584: UseParallelGC barrier task can be overwritten.
jmasa
parents: 4095
diff changeset
133 bool is_idle_task = task->is_idle_task();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
134 // In case the update is costly
a61af66fc99e Initial load
duke
parents:
diff changeset
135 if (PrintGCTaskTimeStamps) {
a61af66fc99e Initial load
duke
parents:
diff changeset
136 timer.update();
a61af66fc99e Initial load
duke
parents:
diff changeset
137 }
a61af66fc99e Initial load
duke
parents:
diff changeset
138
a61af66fc99e Initial load
duke
parents:
diff changeset
139 jlong entry_time = timer.ticks();
a61af66fc99e Initial load
duke
parents:
diff changeset
140 char* name = task->name();
a61af66fc99e Initial load
duke
parents:
diff changeset
141
4132
6d7d0790074d 7119584: UseParallelGC barrier task can be overwritten.
jmasa
parents: 4095
diff changeset
142 // If this is the barrier task, it can be destroyed
6d7d0790074d 7119584: UseParallelGC barrier task can be overwritten.
jmasa
parents: 4095
diff changeset
143 // by the GC task manager once the do_it() executes.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
144 task->do_it(manager(), which());
4095
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
145
4132
6d7d0790074d 7119584: UseParallelGC barrier task can be overwritten.
jmasa
parents: 4095
diff changeset
146 // Use the saved value of is_idle_task because references
6d7d0790074d 7119584: UseParallelGC barrier task can be overwritten.
jmasa
parents: 4095
diff changeset
147 // using "task" are not reliable for the barrier task.
6d7d0790074d 7119584: UseParallelGC barrier task can be overwritten.
jmasa
parents: 4095
diff changeset
148 if (!is_idle_task) {
4095
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
149 manager()->note_completion(which());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
150
4095
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
151 if (PrintGCTaskTimeStamps) {
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
152 assert(_time_stamps != NULL,
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
153 "Sanity (PrintGCTaskTimeStamps set late?)");
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
154
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
155 timer.update();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
156
4095
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
157 GCTaskTimeStamp* time_stamp = time_stamp_at(_time_stamp_index++);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
158
4095
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
159 time_stamp->set_name(name);
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
160 time_stamp->set_entry_time(entry_time);
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
161 time_stamp->set_exit_time(timer.ticks());
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
162 }
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
163 } else {
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
164 // idle tasks complete outside the normal accounting
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
165 // so that a task can complete without waiting for idle tasks.
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
166 // They have to be terminated separately.
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
167 IdleGCTask::destroy((IdleGCTask*)task);
bca17e38de00 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 1972
diff changeset
168 set_is_working(true);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
169 }
a61af66fc99e Initial load
duke
parents:
diff changeset
170
a61af66fc99e Initial load
duke
parents:
diff changeset
171 // Check if we should release our inner resources.
a61af66fc99e Initial load
duke
parents:
diff changeset
172 if (manager()->should_release_resources(which())) {
a61af66fc99e Initial load
duke
parents:
diff changeset
173 manager()->note_release(which());
a61af66fc99e Initial load
duke
parents:
diff changeset
174 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
175 }
a61af66fc99e Initial load
duke
parents:
diff changeset
176 }
a61af66fc99e Initial load
duke
parents:
diff changeset
177 }
a61af66fc99e Initial load
duke
parents:
diff changeset
178 }