Mercurial > hg > graal-jvmci-8
comparison src/share/vm/memory/iterator.cpp @ 989:148e5441d916
6863023: need non-perm oops in code cache for JSR 292
Summary: Make a special root-list for those few nmethods which might contain non-perm oops.
Reviewed-by: twisti, kvn, never, jmasa, ysr
author | jrose |
---|---|
date | Tue, 15 Sep 2009 21:53:47 -0700 |
parents | a61af66fc99e |
children | 54b3b351d6f9 |
comparison
equal
deleted
inserted
replaced
987:00977607da34 | 989:148e5441d916 |
---|---|
30 } | 30 } |
31 | 31 |
32 void VoidClosure::do_void() { | 32 void VoidClosure::do_void() { |
33 ShouldNotCallThis(); | 33 ShouldNotCallThis(); |
34 } | 34 } |
35 | |
36 MarkingCodeBlobClosure::MarkScope::MarkScope(bool activate) | |
37 : _active(activate) | |
38 { | |
39 if (_active) nmethod::oops_do_marking_prologue(); | |
40 } | |
41 | |
42 MarkingCodeBlobClosure::MarkScope::~MarkScope() { | |
43 if (_active) nmethod::oops_do_marking_epilogue(); | |
44 } | |
45 | |
46 void MarkingCodeBlobClosure::do_code_blob(CodeBlob* cb) { | |
47 if (!cb->is_nmethod()) return; | |
48 nmethod* nm = (nmethod*) cb; | |
49 if (!nm->test_set_oops_do_mark()) { | |
50 NOT_PRODUCT(if (TraceScavenge) nm->print_on(tty, "oops_do, 1st visit\n")); | |
51 do_newly_marked_nmethod(nm); | |
52 } else { | |
53 NOT_PRODUCT(if (TraceScavenge) nm->print_on(tty, "oops_do, skipped on 2nd visit\n")); | |
54 } | |
55 } | |
56 | |
57 void CodeBlobToOopClosure::do_newly_marked_nmethod(CodeBlob* cb) { | |
58 cb->oops_do(_cl); | |
59 } | |
60 | |
61 void CodeBlobToOopClosure::do_code_blob(CodeBlob* cb) { | |
62 if (!_do_marking) { | |
63 NOT_PRODUCT(if (TraceScavenge && Verbose && cb->is_nmethod()) ((nmethod*)cb)->print_on(tty, "oops_do, unmarked visit\n")); | |
64 // This assert won't work, since there are lots of mini-passes | |
65 // (mostly in debug mode) that co-exist with marking phases. | |
66 //assert(!(cb->is_nmethod() && ((nmethod*)cb)->test_oops_do_mark()), "found marked nmethod during mark-free phase"); | |
67 cb->oops_do(_cl); | |
68 } else { | |
69 MarkingCodeBlobClosure::do_code_blob(cb); | |
70 } | |
71 } | |
72 | |
73 |