annotate src/share/vm/gc_implementation/concurrentMarkSweep/cmsOopClosures.inline.hpp @ 3293:1f4413413144

7039089: G1: changeset for 7037276 broke heap verification, and related cleanups Summary: In G1 heap verification, we no longer scan perm to G1-collected heap refs as part of process_strong_roots() but rather in a separate explicit oop iteration over the perm gen. This preserves the original perm card-marks. Added a new assertion in younger_refs_iterate() to catch a simple subcase where the user may have forgotten a prior save_marks() call, as happened in the case of G1's attempt to iterate perm to G1 refs when verifying the heap before exit. The assert was deliberately weakened for ParNew+CMS and will be fixed for that combination in a future CR. Also made some (non-G1) cleanups related to code and comments obsoleted by the migration of Symbols to the native heap. Reviewed-by: iveresov, jmasa, tonyp
author ysr
date Tue, 26 Apr 2011 21:17:24 -0700
parents f95d63e2154a
children da91efe96a93
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
2 * Copyright (c) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
4 *
a61af66fc99e Initial load
duke
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
8 *
a61af66fc99e Initial load
duke
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
14 *
a61af66fc99e Initial load
duke
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
18 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 941
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 941
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: 941
diff changeset
21 * questions.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
22 *
a61af66fc99e Initial load
duke
parents:
diff changeset
23 */
a61af66fc99e Initial load
duke
parents:
diff changeset
24
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
25 #ifndef SHARE_VM_GC_IMPLEMENTATION_CONCURRENTMARKSWEEP_CMSOOPCLOSURES_INLINE_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
26 #define SHARE_VM_GC_IMPLEMENTATION_CONCURRENTMARKSWEEP_CMSOOPCLOSURES_INLINE_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
27
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
28 #include "gc_implementation/concurrentMarkSweep/cmsOopClosures.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
29 #include "gc_implementation/concurrentMarkSweep/concurrentMarkSweepGeneration.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
30
0
a61af66fc99e Initial load
duke
parents:
diff changeset
31 // Trim our work_queue so its length is below max at return
a61af66fc99e Initial load
duke
parents:
diff changeset
32 inline void Par_MarkRefsIntoAndScanClosure::trim_queue(uint max) {
a61af66fc99e Initial load
duke
parents:
diff changeset
33 while (_work_queue->size() > max) {
a61af66fc99e Initial load
duke
parents:
diff changeset
34 oop newOop;
a61af66fc99e Initial load
duke
parents:
diff changeset
35 if (_work_queue->pop_local(newOop)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
36 assert(newOop->is_oop(), "Expected an oop");
a61af66fc99e Initial load
duke
parents:
diff changeset
37 assert(_bit_map->isMarked((HeapWord*)newOop),
a61af66fc99e Initial load
duke
parents:
diff changeset
38 "only grey objects on this stack");
a61af66fc99e Initial load
duke
parents:
diff changeset
39 // iterate over the oops in this oop, marking and pushing
a61af66fc99e Initial load
duke
parents:
diff changeset
40 // the ones in CMS heap (i.e. in _span).
a61af66fc99e Initial load
duke
parents:
diff changeset
41 newOop->oop_iterate(&_par_pushAndMarkClosure);
a61af66fc99e Initial load
duke
parents:
diff changeset
42 }
a61af66fc99e Initial load
duke
parents:
diff changeset
43 }
a61af66fc99e Initial load
duke
parents:
diff changeset
44 }
a61af66fc99e Initial load
duke
parents:
diff changeset
45
935
05f89f00a864 6798898: CMS: bugs related to class unloading
jmasa
parents: 0
diff changeset
46 #ifndef PRODUCT
05f89f00a864 6798898: CMS: bugs related to class unloading
jmasa
parents: 0
diff changeset
47 void KlassRememberingOopClosure::check_remember_klasses() const {
05f89f00a864 6798898: CMS: bugs related to class unloading
jmasa
parents: 0
diff changeset
48 assert(_should_remember_klasses == must_remember_klasses(),
05f89f00a864 6798898: CMS: bugs related to class unloading
jmasa
parents: 0
diff changeset
49 "Should remember klasses in this context.");
05f89f00a864 6798898: CMS: bugs related to class unloading
jmasa
parents: 0
diff changeset
50 }
05f89f00a864 6798898: CMS: bugs related to class unloading
jmasa
parents: 0
diff changeset
51 #endif
05f89f00a864 6798898: CMS: bugs related to class unloading
jmasa
parents: 0
diff changeset
52
05f89f00a864 6798898: CMS: bugs related to class unloading
jmasa
parents: 0
diff changeset
53 void KlassRememberingOopClosure::remember_klass(Klass* k) {
05f89f00a864 6798898: CMS: bugs related to class unloading
jmasa
parents: 0
diff changeset
54 if (!_revisit_stack->push(oop(k))) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
55 fatal("Revisit stack overflow in PushOrMarkClosure");
a61af66fc99e Initial load
duke
parents:
diff changeset
56 }
935
05f89f00a864 6798898: CMS: bugs related to class unloading
jmasa
parents: 0
diff changeset
57 check_remember_klasses();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
58 }
a61af66fc99e Initial load
duke
parents:
diff changeset
59
941
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 935
diff changeset
60 inline void PushOrMarkClosure::remember_mdo(DataLayout* v) {
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 935
diff changeset
61 // TBD
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 935
diff changeset
62 }
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 935
diff changeset
63
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 935
diff changeset
64
935
05f89f00a864 6798898: CMS: bugs related to class unloading
jmasa
parents: 0
diff changeset
65 void Par_KlassRememberingOopClosure::remember_klass(Klass* k) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
66 if (!_revisit_stack->par_push(oop(k))) {
941
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 935
diff changeset
67 fatal("Revisit stack overflow in Par_KlassRememberingOopClosure");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
68 }
935
05f89f00a864 6798898: CMS: bugs related to class unloading
jmasa
parents: 0
diff changeset
69 check_remember_klasses();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
70 }
a61af66fc99e Initial load
duke
parents:
diff changeset
71
941
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 935
diff changeset
72 inline void Par_PushOrMarkClosure::remember_mdo(DataLayout* v) {
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 935
diff changeset
73 // TBD
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 935
diff changeset
74 }
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 935
diff changeset
75
0
a61af66fc99e Initial load
duke
parents:
diff changeset
76 inline void PushOrMarkClosure::do_yield_check() {
a61af66fc99e Initial load
duke
parents:
diff changeset
77 _parent->do_yield_check();
a61af66fc99e Initial load
duke
parents:
diff changeset
78 }
a61af66fc99e Initial load
duke
parents:
diff changeset
79
a61af66fc99e Initial load
duke
parents:
diff changeset
80 inline void Par_PushOrMarkClosure::do_yield_check() {
a61af66fc99e Initial load
duke
parents:
diff changeset
81 _parent->do_yield_check();
a61af66fc99e Initial load
duke
parents:
diff changeset
82 }
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
83
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
84 #endif // SHARE_VM_GC_IMPLEMENTATION_CONCURRENTMARKSWEEP_CMSOOPCLOSURES_INLINE_HPP