author | mdoerr |
Thu, 16 Nov 2017 10:20:18 +0100 | |
changeset 47911 | af1361361585 |
parent 47885 | 5caa1d5f74c1 |
child 49592 | 77fb0be7d19f |
permissions | -rw-r--r-- |
47885
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
1 |
/* |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
2 |
* Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
3 |
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
4 |
* |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
5 |
* This code is free software; you can redistribute it and/or modify it |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
6 |
* under the terms of the GNU General Public License version 2 only, as |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
7 |
* published by the Free Software Foundation. |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
8 |
* |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
9 |
* This code is distributed in the hope that it will be useful, but WITHOUT |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
10 |
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
11 |
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
12 |
* version 2 for more details (a copy is included in the LICENSE file that |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
13 |
* accompanied this code). |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
14 |
* |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
15 |
* You should have received a copy of the GNU General Public License version |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
16 |
* 2 along with this work; if not, write to the Free Software Foundation, |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
17 |
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
18 |
* |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
20 |
* or visit www.oracle.com if you need additional information or have any |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
21 |
* questions. |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
22 |
* |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
23 |
*/ |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
24 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
25 |
#include "precompiled.hpp" |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
26 |
#include "gc/g1/g1CollectedHeap.hpp" |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
27 |
#include "gc/g1/g1FullGCMarker.inline.hpp" |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
28 |
#include "gc/g1/g1FullGCOopClosures.inline.hpp" |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
29 |
#include "gc/g1/g1_specialized_oop_closures.hpp" |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
30 |
#include "logging/logStream.hpp" |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
31 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
32 |
void G1MarkAndPushClosure::do_oop(oop* p) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
33 |
do_oop_nv(p); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
34 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
35 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
36 |
void G1MarkAndPushClosure::do_oop(narrowOop* p) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
37 |
do_oop_nv(p); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
38 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
39 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
40 |
bool G1MarkAndPushClosure::do_metadata() { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
41 |
return do_metadata_nv(); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
42 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
43 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
44 |
void G1MarkAndPushClosure::do_klass(Klass* k) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
45 |
do_klass_nv(k); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
46 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
47 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
48 |
void G1MarkAndPushClosure::do_cld(ClassLoaderData* cld) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
49 |
do_cld_nv(cld); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
50 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
51 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
52 |
G1AdjustAndRebuildClosure::G1AdjustAndRebuildClosure(uint worker_id) : |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
53 |
_worker_id(worker_id), |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
54 |
_compaction_delta(0), |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
55 |
_g1h(G1CollectedHeap::heap()) { } |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
56 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
57 |
void G1AdjustAndRebuildClosure::update_compaction_delta(oop obj) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
58 |
if (G1ArchiveAllocator::is_open_archive_object(obj)) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
59 |
_compaction_delta = 0; |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
60 |
return; |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
61 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
62 |
oop forwardee = obj->forwardee(); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
63 |
if (forwardee == NULL) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
64 |
// Object not moved. |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
65 |
_compaction_delta = 0; |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
66 |
} else { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
67 |
// Object moved to forwardee, calculate delta. |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
68 |
_compaction_delta = calculate_compaction_delta(obj, forwardee); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
69 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
70 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
71 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
72 |
void G1AdjustClosure::do_oop(oop* p) { adjust_pointer(p); } |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
73 |
void G1AdjustClosure::do_oop(narrowOop* p) { adjust_pointer(p); } |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
74 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
75 |
void G1AdjustAndRebuildClosure::do_oop(oop* p) { do_oop_nv(p); } |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
76 |
void G1AdjustAndRebuildClosure::do_oop(narrowOop* p) { do_oop_nv(p); } |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
77 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
78 |
void G1FollowStackClosure::do_void() { _marker->drain_stack(); } |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
79 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
80 |
void G1FullKeepAliveClosure::do_oop(oop* p) { do_oop_work(p); } |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
81 |
void G1FullKeepAliveClosure::do_oop(narrowOop* p) { do_oop_work(p); } |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
82 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
83 |
G1VerifyOopClosure::G1VerifyOopClosure(VerifyOption option) : |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
84 |
_g1h(G1CollectedHeap::heap()), |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
85 |
_containing_obj(NULL), |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
86 |
_verify_option(option), |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
87 |
_cc(0), |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
88 |
_failures(false) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
89 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
90 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
91 |
void G1VerifyOopClosure::print_object(outputStream* out, oop obj) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
92 |
#ifdef PRODUCT |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
93 |
Klass* k = obj->klass(); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
94 |
const char* class_name = InstanceKlass::cast(k)->external_name(); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
95 |
out->print_cr("class name %s", class_name); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
96 |
#else // PRODUCT |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
97 |
obj->print_on(out); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
98 |
#endif // PRODUCT |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
99 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
100 |
|
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
101 |
template <class T> void G1VerifyOopClosure::do_oop_nv(T* p) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
102 |
T heap_oop = oopDesc::load_heap_oop(p); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
103 |
if (!oopDesc::is_null(heap_oop)) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
104 |
_cc++; |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
105 |
oop obj = oopDesc::decode_heap_oop_not_null(heap_oop); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
106 |
bool failed = false; |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
107 |
if (!_g1h->is_in_closed_subset(obj) || _g1h->is_obj_dead_cond(obj, _verify_option)) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
108 |
MutexLockerEx x(ParGCRareEvent_lock, |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
109 |
Mutex::_no_safepoint_check_flag); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
110 |
LogStreamHandle(Error, gc, verify) yy; |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
111 |
if (!_failures) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
112 |
yy.cr(); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
113 |
yy.print_cr("----------"); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
114 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
115 |
if (!_g1h->is_in_closed_subset(obj)) { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
116 |
HeapRegion* from = _g1h->heap_region_containing((HeapWord*)p); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
117 |
yy.print_cr("Field " PTR_FORMAT |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
118 |
" of live obj " PTR_FORMAT " in region " |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
119 |
"[" PTR_FORMAT ", " PTR_FORMAT ")", |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
120 |
p2i(p), p2i(_containing_obj), |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
121 |
p2i(from->bottom()), p2i(from->end())); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
122 |
print_object(&yy, _containing_obj); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
123 |
yy.print_cr("points to obj " PTR_FORMAT " not in the heap", |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
124 |
p2i(obj)); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
125 |
} else { |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
126 |
HeapRegion* from = _g1h->heap_region_containing((HeapWord*)p); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
127 |
HeapRegion* to = _g1h->heap_region_containing((HeapWord*)obj); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
128 |
yy.print_cr("Field " PTR_FORMAT |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
129 |
" of live obj " PTR_FORMAT " in region " |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
130 |
"[" PTR_FORMAT ", " PTR_FORMAT ")", |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
131 |
p2i(p), p2i(_containing_obj), |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
132 |
p2i(from->bottom()), p2i(from->end())); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
133 |
print_object(&yy, _containing_obj); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
134 |
yy.print_cr("points to dead obj " PTR_FORMAT " in region " |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
135 |
"[" PTR_FORMAT ", " PTR_FORMAT ")", |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
136 |
p2i(obj), p2i(to->bottom()), p2i(to->end())); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
137 |
print_object(&yy, obj); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
138 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
139 |
yy.print_cr("----------"); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
140 |
yy.flush(); |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
141 |
_failures = true; |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
142 |
failed = true; |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
143 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
144 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
145 |
} |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
146 |
|
47911 | 147 |
template void G1VerifyOopClosure::do_oop_nv(oop*); |
148 |
template void G1VerifyOopClosure::do_oop_nv(narrowOop*); |
|
149 |
||
47885
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
150 |
// Generate G1 full GC specialized oop_oop_iterate functions. |
5caa1d5f74c1
8186571: Implementation: JEP 307: Parallel Full GC for G1
sjohanss
parents:
diff
changeset
|
151 |
SPECIALIZED_OOP_OOP_ITERATE_CLOSURES_G1FULL(ALL_KLASS_OOP_OOP_ITERATE_DEFN) |