annotate src/share/vm/code/nmethod.cpp @ 20543:e7d0505c8a30

8059758: Footprint regressions with JDK-8038423 Summary: Changes in JDK-8038423 always initialize (zero out) virtual memory used for auxiliary data structures. This causes a footprint regression for G1 in startup benchmarks. This is because they do not touch that memory at all, so the operating system does not actually commit these pages. The fix is to, if the initialization value of the data structures matches the default value of just committed memory (=0), do not do anything. Reviewed-by: jwilhelm, brutisso
author tschatzl
date Fri, 10 Oct 2014 15:51:58 +0200
parents 2c6ef90f030a
children b12a2a9b05ca
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 17915
diff changeset
2 * Copyright (c) 1997, 2014, 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: 1538
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1538
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: 1538
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: 1845
diff changeset
25 #include "precompiled.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
26 #include "code/codeCache.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
27 #include "code/compiledIC.hpp"
3852
fdb992d83a87 7071653: JSR 292: call site change notification should be pushed not pulled
twisti
parents: 3784
diff changeset
28 #include "code/dependencies.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
29 #include "code/nmethod.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
30 #include "code/scopeDesc.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
31 #include "compiler/abstractCompiler.hpp"
2405
3d58a4983660 7022998: JSR 292 recursive method handle calls inline themselves infinitely
twisti
parents: 2376
diff changeset
32 #include "compiler/compileBroker.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
33 #include "compiler/compileLog.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
34 #include "compiler/compilerOracle.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
35 #include "compiler/disassembler.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
36 #include "interpreter/bytecode.hpp"
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
37 #include "oops/methodData.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
38 #include "prims/jvmtiRedefineClassesTrace.hpp"
2195
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
39 #include "prims/jvmtiImpl.hpp"
20197
ce8f6bb717c9 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 20191
diff changeset
40 #include "runtime/orderAccess.inline.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
41 #include "runtime/sharedRuntime.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
42 #include "runtime/sweeper.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
43 #include "utilities/dtrace.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
44 #include "utilities/events.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
45 #include "utilities/xmlstream.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
46 #ifdef SHARK
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
47 #include "shark/sharkCompiler.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1845
diff changeset
48 #endif
0
a61af66fc99e Initial load
duke
parents:
diff changeset
49
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 17915
diff changeset
50 PRAGMA_FORMAT_MUTE_WARNINGS_FOR_GCC
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 17915
diff changeset
51
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
52 unsigned char nmethod::_global_unloading_clock = 0;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
53
0
a61af66fc99e Initial load
duke
parents:
diff changeset
54 #ifdef DTRACE_ENABLED
a61af66fc99e Initial load
duke
parents:
diff changeset
55
a61af66fc99e Initial load
duke
parents:
diff changeset
56 // Only bother with this argument setup if dtrace is available
a61af66fc99e Initial load
duke
parents:
diff changeset
57
4006
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
58 #ifndef USDT2
0
a61af66fc99e Initial load
duke
parents:
diff changeset
59 HS_DTRACE_PROBE_DECL8(hotspot, compiled__method__load,
a61af66fc99e Initial load
duke
parents:
diff changeset
60 const char*, int, const char*, int, const char*, int, void*, size_t);
a61af66fc99e Initial load
duke
parents:
diff changeset
61
a61af66fc99e Initial load
duke
parents:
diff changeset
62 HS_DTRACE_PROBE_DECL6(hotspot, compiled__method__unload,
a61af66fc99e Initial load
duke
parents:
diff changeset
63 char*, int, char*, int, char*, int);
a61af66fc99e Initial load
duke
parents:
diff changeset
64
a61af66fc99e Initial load
duke
parents:
diff changeset
65 #define DTRACE_METHOD_UNLOAD_PROBE(method) \
a61af66fc99e Initial load
duke
parents:
diff changeset
66 { \
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
67 Method* m = (method); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
68 if (m != NULL) { \
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2142
diff changeset
69 Symbol* klass_name = m->klass_name(); \
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2142
diff changeset
70 Symbol* name = m->name(); \
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2142
diff changeset
71 Symbol* signature = m->signature(); \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
72 HS_DTRACE_PROBE6(hotspot, compiled__method__unload, \
a61af66fc99e Initial load
duke
parents:
diff changeset
73 klass_name->bytes(), klass_name->utf8_length(), \
a61af66fc99e Initial load
duke
parents:
diff changeset
74 name->bytes(), name->utf8_length(), \
a61af66fc99e Initial load
duke
parents:
diff changeset
75 signature->bytes(), signature->utf8_length()); \
a61af66fc99e Initial load
duke
parents:
diff changeset
76 } \
a61af66fc99e Initial load
duke
parents:
diff changeset
77 }
4006
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
78 #else /* USDT2 */
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
79 #define DTRACE_METHOD_UNLOAD_PROBE(method) \
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
80 { \
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
81 Method* m = (method); \
4006
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
82 if (m != NULL) { \
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
83 Symbol* klass_name = m->klass_name(); \
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
84 Symbol* name = m->name(); \
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
85 Symbol* signature = m->signature(); \
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
86 HOTSPOT_COMPILED_METHOD_UNLOAD( \
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
87 (char *) klass_name->bytes(), klass_name->utf8_length(), \
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
88 (char *) name->bytes(), name->utf8_length(), \
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
89 (char *) signature->bytes(), signature->utf8_length()); \
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
90 } \
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
91 }
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
92 #endif /* USDT2 */
0
a61af66fc99e Initial load
duke
parents:
diff changeset
93
a61af66fc99e Initial load
duke
parents:
diff changeset
94 #else // ndef DTRACE_ENABLED
a61af66fc99e Initial load
duke
parents:
diff changeset
95
a61af66fc99e Initial load
duke
parents:
diff changeset
96 #define DTRACE_METHOD_UNLOAD_PROBE(method)
a61af66fc99e Initial load
duke
parents:
diff changeset
97
a61af66fc99e Initial load
duke
parents:
diff changeset
98 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
99
a61af66fc99e Initial load
duke
parents:
diff changeset
100 bool nmethod::is_compiled_by_c1() const {
12161
e1fbb86b47e4 8016277: Crash in nmethod::is_compiled_by_c1() on x86
roland
parents: 12080
diff changeset
101 if (compiler() == NULL) {
e1fbb86b47e4 8016277: Crash in nmethod::is_compiled_by_c1() on x86
roland
parents: 12080
diff changeset
102 return false;
e1fbb86b47e4 8016277: Crash in nmethod::is_compiled_by_c1() on x86
roland
parents: 12080
diff changeset
103 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
104 return compiler()->is_c1();
a61af66fc99e Initial load
duke
parents:
diff changeset
105 }
a61af66fc99e Initial load
duke
parents:
diff changeset
106 bool nmethod::is_compiled_by_c2() const {
12161
e1fbb86b47e4 8016277: Crash in nmethod::is_compiled_by_c1() on x86
roland
parents: 12080
diff changeset
107 if (compiler() == NULL) {
e1fbb86b47e4 8016277: Crash in nmethod::is_compiled_by_c1() on x86
roland
parents: 12080
diff changeset
108 return false;
e1fbb86b47e4 8016277: Crash in nmethod::is_compiled_by_c1() on x86
roland
parents: 12080
diff changeset
109 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
110 return compiler()->is_c2();
a61af66fc99e Initial load
duke
parents:
diff changeset
111 }
1692
d2ede61b7a12 6976186: integrate Shark HotSpot changes
twisti
parents: 1691
diff changeset
112 bool nmethod::is_compiled_by_shark() const {
12161
e1fbb86b47e4 8016277: Crash in nmethod::is_compiled_by_c1() on x86
roland
parents: 12080
diff changeset
113 if (compiler() == NULL) {
e1fbb86b47e4 8016277: Crash in nmethod::is_compiled_by_c1() on x86
roland
parents: 12080
diff changeset
114 return false;
e1fbb86b47e4 8016277: Crash in nmethod::is_compiled_by_c1() on x86
roland
parents: 12080
diff changeset
115 }
1692
d2ede61b7a12 6976186: integrate Shark HotSpot changes
twisti
parents: 1691
diff changeset
116 return compiler()->is_shark();
d2ede61b7a12 6976186: integrate Shark HotSpot changes
twisti
parents: 1691
diff changeset
117 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
118
a61af66fc99e Initial load
duke
parents:
diff changeset
119
a61af66fc99e Initial load
duke
parents:
diff changeset
120
a61af66fc99e Initial load
duke
parents:
diff changeset
121 //---------------------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
122 // NMethod statistics
a61af66fc99e Initial load
duke
parents:
diff changeset
123 // They are printed under various flags, including:
a61af66fc99e Initial load
duke
parents:
diff changeset
124 // PrintC1Statistics, PrintOptoStatistics, LogVMOutput, and LogCompilation.
a61af66fc99e Initial load
duke
parents:
diff changeset
125 // (In the latter two cases, they like other stats are printed to the log only.)
a61af66fc99e Initial load
duke
parents:
diff changeset
126
a61af66fc99e Initial load
duke
parents:
diff changeset
127 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
128 // These variables are put into one block to reduce relocations
a61af66fc99e Initial load
duke
parents:
diff changeset
129 // and make it simpler to print from the debugger.
a61af66fc99e Initial load
duke
parents:
diff changeset
130 static
a61af66fc99e Initial load
duke
parents:
diff changeset
131 struct nmethod_stats_struct {
a61af66fc99e Initial load
duke
parents:
diff changeset
132 int nmethod_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
133 int total_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
134 int relocation_size;
1762
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
135 int consts_size;
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
136 int insts_size;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
137 int stub_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
138 int scopes_data_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
139 int scopes_pcs_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
140 int dependencies_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
141 int handler_table_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
142 int nul_chk_table_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
143 int oops_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
144
a61af66fc99e Initial load
duke
parents:
diff changeset
145 void note_nmethod(nmethod* nm) {
a61af66fc99e Initial load
duke
parents:
diff changeset
146 nmethod_count += 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
147 total_size += nm->size();
a61af66fc99e Initial load
duke
parents:
diff changeset
148 relocation_size += nm->relocation_size();
1762
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
149 consts_size += nm->consts_size();
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
150 insts_size += nm->insts_size();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
151 stub_size += nm->stub_size();
1563
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
152 oops_size += nm->oops_size();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
153 scopes_data_size += nm->scopes_data_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
154 scopes_pcs_size += nm->scopes_pcs_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
155 dependencies_size += nm->dependencies_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
156 handler_table_size += nm->handler_table_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
157 nul_chk_table_size += nm->nul_chk_table_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
158 }
a61af66fc99e Initial load
duke
parents:
diff changeset
159 void print_nmethod_stats() {
a61af66fc99e Initial load
duke
parents:
diff changeset
160 if (nmethod_count == 0) return;
a61af66fc99e Initial load
duke
parents:
diff changeset
161 tty->print_cr("Statistics for %d bytecoded nmethods:", nmethod_count);
a61af66fc99e Initial load
duke
parents:
diff changeset
162 if (total_size != 0) tty->print_cr(" total in heap = %d", total_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
163 if (relocation_size != 0) tty->print_cr(" relocation = %d", relocation_size);
1762
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
164 if (consts_size != 0) tty->print_cr(" constants = %d", consts_size);
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
165 if (insts_size != 0) tty->print_cr(" main code = %d", insts_size);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
166 if (stub_size != 0) tty->print_cr(" stub code = %d", stub_size);
1563
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
167 if (oops_size != 0) tty->print_cr(" oops = %d", oops_size);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
168 if (scopes_data_size != 0) tty->print_cr(" scopes data = %d", scopes_data_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
169 if (scopes_pcs_size != 0) tty->print_cr(" scopes pcs = %d", scopes_pcs_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
170 if (dependencies_size != 0) tty->print_cr(" dependencies = %d", dependencies_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
171 if (handler_table_size != 0) tty->print_cr(" handler table = %d", handler_table_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
172 if (nul_chk_table_size != 0) tty->print_cr(" nul chk table = %d", nul_chk_table_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
173 }
a61af66fc99e Initial load
duke
parents:
diff changeset
174
a61af66fc99e Initial load
duke
parents:
diff changeset
175 int native_nmethod_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
176 int native_total_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
177 int native_relocation_size;
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
178 int native_insts_size;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
179 int native_oops_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
180 void note_native_nmethod(nmethod* nm) {
a61af66fc99e Initial load
duke
parents:
diff changeset
181 native_nmethod_count += 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
182 native_total_size += nm->size();
a61af66fc99e Initial load
duke
parents:
diff changeset
183 native_relocation_size += nm->relocation_size();
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
184 native_insts_size += nm->insts_size();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
185 native_oops_size += nm->oops_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
186 }
a61af66fc99e Initial load
duke
parents:
diff changeset
187 void print_native_nmethod_stats() {
a61af66fc99e Initial load
duke
parents:
diff changeset
188 if (native_nmethod_count == 0) return;
a61af66fc99e Initial load
duke
parents:
diff changeset
189 tty->print_cr("Statistics for %d native nmethods:", native_nmethod_count);
a61af66fc99e Initial load
duke
parents:
diff changeset
190 if (native_total_size != 0) tty->print_cr(" N. total size = %d", native_total_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
191 if (native_relocation_size != 0) tty->print_cr(" N. relocation = %d", native_relocation_size);
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
192 if (native_insts_size != 0) tty->print_cr(" N. main code = %d", native_insts_size);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
193 if (native_oops_size != 0) tty->print_cr(" N. oops = %d", native_oops_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
194 }
a61af66fc99e Initial load
duke
parents:
diff changeset
195
a61af66fc99e Initial load
duke
parents:
diff changeset
196 int pc_desc_resets; // number of resets (= number of caches)
a61af66fc99e Initial load
duke
parents:
diff changeset
197 int pc_desc_queries; // queries to nmethod::find_pc_desc
a61af66fc99e Initial load
duke
parents:
diff changeset
198 int pc_desc_approx; // number of those which have approximate true
2339
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
199 int pc_desc_repeats; // number of _pc_descs[0] hits
0
a61af66fc99e Initial load
duke
parents:
diff changeset
200 int pc_desc_hits; // number of LRU cache hits
a61af66fc99e Initial load
duke
parents:
diff changeset
201 int pc_desc_tests; // total number of PcDesc examinations
a61af66fc99e Initial load
duke
parents:
diff changeset
202 int pc_desc_searches; // total number of quasi-binary search steps
a61af66fc99e Initial load
duke
parents:
diff changeset
203 int pc_desc_adds; // number of LUR cache insertions
a61af66fc99e Initial load
duke
parents:
diff changeset
204
a61af66fc99e Initial load
duke
parents:
diff changeset
205 void print_pc_stats() {
a61af66fc99e Initial load
duke
parents:
diff changeset
206 tty->print_cr("PcDesc Statistics: %d queries, %.2f comparisons per query",
a61af66fc99e Initial load
duke
parents:
diff changeset
207 pc_desc_queries,
a61af66fc99e Initial load
duke
parents:
diff changeset
208 (double)(pc_desc_tests + pc_desc_searches)
a61af66fc99e Initial load
duke
parents:
diff changeset
209 / pc_desc_queries);
a61af66fc99e Initial load
duke
parents:
diff changeset
210 tty->print_cr(" caches=%d queries=%d/%d, hits=%d+%d, tests=%d+%d, adds=%d",
a61af66fc99e Initial load
duke
parents:
diff changeset
211 pc_desc_resets,
a61af66fc99e Initial load
duke
parents:
diff changeset
212 pc_desc_queries, pc_desc_approx,
a61af66fc99e Initial load
duke
parents:
diff changeset
213 pc_desc_repeats, pc_desc_hits,
a61af66fc99e Initial load
duke
parents:
diff changeset
214 pc_desc_tests, pc_desc_searches, pc_desc_adds);
a61af66fc99e Initial load
duke
parents:
diff changeset
215 }
a61af66fc99e Initial load
duke
parents:
diff changeset
216 } nmethod_stats;
a61af66fc99e Initial load
duke
parents:
diff changeset
217 #endif //PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
218
2321
1b4e6a5d98e0 7012914: JSR 292 MethodHandlesTest C1: frame::verify_return_pc(return_address) failed: must be a return pc
twisti
parents: 2195
diff changeset
219
0
a61af66fc99e Initial load
duke
parents:
diff changeset
220 //---------------------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
221
a61af66fc99e Initial load
duke
parents:
diff changeset
222
a61af66fc99e Initial load
duke
parents:
diff changeset
223 ExceptionCache::ExceptionCache(Handle exception, address pc, address handler) {
a61af66fc99e Initial load
duke
parents:
diff changeset
224 assert(pc != NULL, "Must be non null");
a61af66fc99e Initial load
duke
parents:
diff changeset
225 assert(exception.not_null(), "Must be non null");
a61af66fc99e Initial load
duke
parents:
diff changeset
226 assert(handler != NULL, "Must be non null");
a61af66fc99e Initial load
duke
parents:
diff changeset
227
a61af66fc99e Initial load
duke
parents:
diff changeset
228 _count = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
229 _exception_type = exception->klass();
a61af66fc99e Initial load
duke
parents:
diff changeset
230 _next = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
231
a61af66fc99e Initial load
duke
parents:
diff changeset
232 add_address_and_handler(pc,handler);
a61af66fc99e Initial load
duke
parents:
diff changeset
233 }
a61af66fc99e Initial load
duke
parents:
diff changeset
234
a61af66fc99e Initial load
duke
parents:
diff changeset
235
a61af66fc99e Initial load
duke
parents:
diff changeset
236 address ExceptionCache::match(Handle exception, address pc) {
a61af66fc99e Initial load
duke
parents:
diff changeset
237 assert(pc != NULL,"Must be non null");
a61af66fc99e Initial load
duke
parents:
diff changeset
238 assert(exception.not_null(),"Must be non null");
a61af66fc99e Initial load
duke
parents:
diff changeset
239 if (exception->klass() == exception_type()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
240 return (test_address(pc));
a61af66fc99e Initial load
duke
parents:
diff changeset
241 }
a61af66fc99e Initial load
duke
parents:
diff changeset
242
a61af66fc99e Initial load
duke
parents:
diff changeset
243 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
244 }
a61af66fc99e Initial load
duke
parents:
diff changeset
245
a61af66fc99e Initial load
duke
parents:
diff changeset
246
a61af66fc99e Initial load
duke
parents:
diff changeset
247 bool ExceptionCache::match_exception_with_space(Handle exception) {
a61af66fc99e Initial load
duke
parents:
diff changeset
248 assert(exception.not_null(),"Must be non null");
a61af66fc99e Initial load
duke
parents:
diff changeset
249 if (exception->klass() == exception_type() && count() < cache_size) {
a61af66fc99e Initial load
duke
parents:
diff changeset
250 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
251 }
a61af66fc99e Initial load
duke
parents:
diff changeset
252 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
253 }
a61af66fc99e Initial load
duke
parents:
diff changeset
254
a61af66fc99e Initial load
duke
parents:
diff changeset
255
a61af66fc99e Initial load
duke
parents:
diff changeset
256 address ExceptionCache::test_address(address addr) {
a61af66fc99e Initial load
duke
parents:
diff changeset
257 for (int i=0; i<count(); i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
258 if (pc_at(i) == addr) {
a61af66fc99e Initial load
duke
parents:
diff changeset
259 return handler_at(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
260 }
a61af66fc99e Initial load
duke
parents:
diff changeset
261 }
a61af66fc99e Initial load
duke
parents:
diff changeset
262 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
263 }
a61af66fc99e Initial load
duke
parents:
diff changeset
264
a61af66fc99e Initial load
duke
parents:
diff changeset
265
a61af66fc99e Initial load
duke
parents:
diff changeset
266 bool ExceptionCache::add_address_and_handler(address addr, address handler) {
a61af66fc99e Initial load
duke
parents:
diff changeset
267 if (test_address(addr) == handler) return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
268 if (count() < cache_size) {
a61af66fc99e Initial load
duke
parents:
diff changeset
269 set_pc_at(count(),addr);
a61af66fc99e Initial load
duke
parents:
diff changeset
270 set_handler_at(count(), handler);
a61af66fc99e Initial load
duke
parents:
diff changeset
271 increment_count();
a61af66fc99e Initial load
duke
parents:
diff changeset
272 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
273 }
a61af66fc99e Initial load
duke
parents:
diff changeset
274 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
275 }
a61af66fc99e Initial load
duke
parents:
diff changeset
276
a61af66fc99e Initial load
duke
parents:
diff changeset
277
a61af66fc99e Initial load
duke
parents:
diff changeset
278 // private method for handling exception cache
a61af66fc99e Initial load
duke
parents:
diff changeset
279 // These methods are private, and used to manipulate the exception cache
a61af66fc99e Initial load
duke
parents:
diff changeset
280 // directly.
a61af66fc99e Initial load
duke
parents:
diff changeset
281 ExceptionCache* nmethod::exception_cache_entry_for_exception(Handle exception) {
a61af66fc99e Initial load
duke
parents:
diff changeset
282 ExceptionCache* ec = exception_cache();
a61af66fc99e Initial load
duke
parents:
diff changeset
283 while (ec != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
284 if (ec->match_exception_with_space(exception)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
285 return ec;
a61af66fc99e Initial load
duke
parents:
diff changeset
286 }
a61af66fc99e Initial load
duke
parents:
diff changeset
287 ec = ec->next();
a61af66fc99e Initial load
duke
parents:
diff changeset
288 }
a61af66fc99e Initial load
duke
parents:
diff changeset
289 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
290 }
a61af66fc99e Initial load
duke
parents:
diff changeset
291
a61af66fc99e Initial load
duke
parents:
diff changeset
292
a61af66fc99e Initial load
duke
parents:
diff changeset
293 //-----------------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
294
a61af66fc99e Initial load
duke
parents:
diff changeset
295
a61af66fc99e Initial load
duke
parents:
diff changeset
296 // Helper used by both find_pc_desc methods.
a61af66fc99e Initial load
duke
parents:
diff changeset
297 static inline bool match_desc(PcDesc* pc, int pc_offset, bool approximate) {
a61af66fc99e Initial load
duke
parents:
diff changeset
298 NOT_PRODUCT(++nmethod_stats.pc_desc_tests);
a61af66fc99e Initial load
duke
parents:
diff changeset
299 if (!approximate)
a61af66fc99e Initial load
duke
parents:
diff changeset
300 return pc->pc_offset() == pc_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
301 else
a61af66fc99e Initial load
duke
parents:
diff changeset
302 return (pc-1)->pc_offset() < pc_offset && pc_offset <= pc->pc_offset();
a61af66fc99e Initial load
duke
parents:
diff changeset
303 }
a61af66fc99e Initial load
duke
parents:
diff changeset
304
a61af66fc99e Initial load
duke
parents:
diff changeset
305 void PcDescCache::reset_to(PcDesc* initial_pc_desc) {
a61af66fc99e Initial load
duke
parents:
diff changeset
306 if (initial_pc_desc == NULL) {
2339
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
307 _pc_descs[0] = NULL; // native method; no PcDescs at all
0
a61af66fc99e Initial load
duke
parents:
diff changeset
308 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
309 }
a61af66fc99e Initial load
duke
parents:
diff changeset
310 NOT_PRODUCT(++nmethod_stats.pc_desc_resets);
a61af66fc99e Initial load
duke
parents:
diff changeset
311 // reset the cache by filling it with benign (non-null) values
a61af66fc99e Initial load
duke
parents:
diff changeset
312 assert(initial_pc_desc->pc_offset() < 0, "must be sentinel");
a61af66fc99e Initial load
duke
parents:
diff changeset
313 for (int i = 0; i < cache_size; i++)
a61af66fc99e Initial load
duke
parents:
diff changeset
314 _pc_descs[i] = initial_pc_desc;
a61af66fc99e Initial load
duke
parents:
diff changeset
315 }
a61af66fc99e Initial load
duke
parents:
diff changeset
316
a61af66fc99e Initial load
duke
parents:
diff changeset
317 PcDesc* PcDescCache::find_pc_desc(int pc_offset, bool approximate) {
a61af66fc99e Initial load
duke
parents:
diff changeset
318 NOT_PRODUCT(++nmethod_stats.pc_desc_queries);
2339
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
319 NOT_PRODUCT(if (approximate) ++nmethod_stats.pc_desc_approx);
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
320
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
321 // Note: one might think that caching the most recently
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
322 // read value separately would be a win, but one would be
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
323 // wrong. When many threads are updating it, the cache
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
324 // line it's in would bounce between caches, negating
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
325 // any benefit.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
326
a61af66fc99e Initial load
duke
parents:
diff changeset
327 // In order to prevent race conditions do not load cache elements
a61af66fc99e Initial load
duke
parents:
diff changeset
328 // repeatedly, but use a local copy:
a61af66fc99e Initial load
duke
parents:
diff changeset
329 PcDesc* res;
a61af66fc99e Initial load
duke
parents:
diff changeset
330
2339
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
331 // Step one: Check the most recently added value.
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
332 res = _pc_descs[0];
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
333 if (res == NULL) return NULL; // native method; no PcDescs at all
0
a61af66fc99e Initial load
duke
parents:
diff changeset
334 if (match_desc(res, pc_offset, approximate)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
335 NOT_PRODUCT(++nmethod_stats.pc_desc_repeats);
a61af66fc99e Initial load
duke
parents:
diff changeset
336 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
337 }
a61af66fc99e Initial load
duke
parents:
diff changeset
338
2339
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
339 // Step two: Check the rest of the LRU cache.
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
340 for (int i = 1; i < cache_size; ++i) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
341 res = _pc_descs[i];
2339
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
342 if (res->pc_offset() < 0) break; // optimization: skip empty cache
0
a61af66fc99e Initial load
duke
parents:
diff changeset
343 if (match_desc(res, pc_offset, approximate)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
344 NOT_PRODUCT(++nmethod_stats.pc_desc_hits);
a61af66fc99e Initial load
duke
parents:
diff changeset
345 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
346 }
a61af66fc99e Initial load
duke
parents:
diff changeset
347 }
a61af66fc99e Initial load
duke
parents:
diff changeset
348
a61af66fc99e Initial load
duke
parents:
diff changeset
349 // Report failure.
a61af66fc99e Initial load
duke
parents:
diff changeset
350 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
351 }
a61af66fc99e Initial load
duke
parents:
diff changeset
352
a61af66fc99e Initial load
duke
parents:
diff changeset
353 void PcDescCache::add_pc_desc(PcDesc* pc_desc) {
a61af66fc99e Initial load
duke
parents:
diff changeset
354 NOT_PRODUCT(++nmethod_stats.pc_desc_adds);
2339
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
355 // Update the LRU cache by shifting pc_desc forward.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
356 for (int i = 0; i < cache_size; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
357 PcDesc* next = _pc_descs[i];
a61af66fc99e Initial load
duke
parents:
diff changeset
358 _pc_descs[i] = pc_desc;
a61af66fc99e Initial load
duke
parents:
diff changeset
359 pc_desc = next;
a61af66fc99e Initial load
duke
parents:
diff changeset
360 }
a61af66fc99e Initial load
duke
parents:
diff changeset
361 }
a61af66fc99e Initial load
duke
parents:
diff changeset
362
a61af66fc99e Initial load
duke
parents:
diff changeset
363 // adjust pcs_size so that it is a multiple of both oopSize and
a61af66fc99e Initial load
duke
parents:
diff changeset
364 // sizeof(PcDesc) (assumes that if sizeof(PcDesc) is not a multiple
a61af66fc99e Initial load
duke
parents:
diff changeset
365 // of oopSize, then 2*sizeof(PcDesc) is)
2339
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
366 static int adjust_pcs_size(int pcs_size) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
367 int nsize = round_to(pcs_size, oopSize);
a61af66fc99e Initial load
duke
parents:
diff changeset
368 if ((nsize % sizeof(PcDesc)) != 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
369 nsize = pcs_size + sizeof(PcDesc);
a61af66fc99e Initial load
duke
parents:
diff changeset
370 }
2339
3d5a546351ef 7023931: PcDescCache::find_pc_desc should not write _last_pc_desc
phh
parents: 2321
diff changeset
371 assert((nsize % oopSize) == 0, "correct alignment");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
372 return nsize;
a61af66fc99e Initial load
duke
parents:
diff changeset
373 }
a61af66fc99e Initial load
duke
parents:
diff changeset
374
a61af66fc99e Initial load
duke
parents:
diff changeset
375 //-----------------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
376
a61af66fc99e Initial load
duke
parents:
diff changeset
377
a61af66fc99e Initial load
duke
parents:
diff changeset
378 void nmethod::add_exception_cache_entry(ExceptionCache* new_entry) {
a61af66fc99e Initial load
duke
parents:
diff changeset
379 assert(ExceptionCache_lock->owned_by_self(),"Must hold the ExceptionCache_lock");
a61af66fc99e Initial load
duke
parents:
diff changeset
380 assert(new_entry != NULL,"Must be non null");
a61af66fc99e Initial load
duke
parents:
diff changeset
381 assert(new_entry->next() == NULL, "Must be null");
a61af66fc99e Initial load
duke
parents:
diff changeset
382
a61af66fc99e Initial load
duke
parents:
diff changeset
383 if (exception_cache() != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
384 new_entry->set_next(exception_cache());
a61af66fc99e Initial load
duke
parents:
diff changeset
385 }
a61af66fc99e Initial load
duke
parents:
diff changeset
386 set_exception_cache(new_entry);
a61af66fc99e Initial load
duke
parents:
diff changeset
387 }
a61af66fc99e Initial load
duke
parents:
diff changeset
388
20269
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
389 void nmethod::clean_exception_cache(BoolObjectClosure* is_alive) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
390 ExceptionCache* prev = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
391 ExceptionCache* curr = exception_cache();
20269
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
392
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
393 while (curr != NULL) {
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
394 ExceptionCache* next = curr->next();
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
395
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
396 Klass* ex_klass = curr->exception_type();
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
397 if (ex_klass != NULL && !ex_klass->is_loader_alive(is_alive)) {
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
398 if (prev == NULL) {
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
399 set_exception_cache(next);
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
400 } else {
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
401 prev->set_next(next);
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
402 }
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
403 delete curr;
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
404 // prev stays the same.
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
405 } else {
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
406 prev = curr;
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
407 }
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
408
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
409 curr = next;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
410 }
a61af66fc99e Initial load
duke
parents:
diff changeset
411 }
a61af66fc99e Initial load
duke
parents:
diff changeset
412
a61af66fc99e Initial load
duke
parents:
diff changeset
413 // public method for accessing the exception cache
a61af66fc99e Initial load
duke
parents:
diff changeset
414 // These are the public access methods.
a61af66fc99e Initial load
duke
parents:
diff changeset
415 address nmethod::handler_for_exception_and_pc(Handle exception, address pc) {
a61af66fc99e Initial load
duke
parents:
diff changeset
416 // We never grab a lock to read the exception cache, so we may
a61af66fc99e Initial load
duke
parents:
diff changeset
417 // have false negatives. This is okay, as it can only happen during
a61af66fc99e Initial load
duke
parents:
diff changeset
418 // the first few exception lookups for a given nmethod.
a61af66fc99e Initial load
duke
parents:
diff changeset
419 ExceptionCache* ec = exception_cache();
a61af66fc99e Initial load
duke
parents:
diff changeset
420 while (ec != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
421 address ret_val;
a61af66fc99e Initial load
duke
parents:
diff changeset
422 if ((ret_val = ec->match(exception,pc)) != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
423 return ret_val;
a61af66fc99e Initial load
duke
parents:
diff changeset
424 }
a61af66fc99e Initial load
duke
parents:
diff changeset
425 ec = ec->next();
a61af66fc99e Initial load
duke
parents:
diff changeset
426 }
a61af66fc99e Initial load
duke
parents:
diff changeset
427 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
428 }
a61af66fc99e Initial load
duke
parents:
diff changeset
429
a61af66fc99e Initial load
duke
parents:
diff changeset
430
a61af66fc99e Initial load
duke
parents:
diff changeset
431 void nmethod::add_handler_for_exception_and_pc(Handle exception, address pc, address handler) {
a61af66fc99e Initial load
duke
parents:
diff changeset
432 // There are potential race conditions during exception cache updates, so we
a61af66fc99e Initial load
duke
parents:
diff changeset
433 // must own the ExceptionCache_lock before doing ANY modifications. Because
605
98cb887364d3 6810672: Comment typos
twisti
parents: 374
diff changeset
434 // we don't lock during reads, it is possible to have several threads attempt
0
a61af66fc99e Initial load
duke
parents:
diff changeset
435 // to update the cache with the same data. We need to check for already inserted
a61af66fc99e Initial load
duke
parents:
diff changeset
436 // copies of the current data before adding it.
a61af66fc99e Initial load
duke
parents:
diff changeset
437
a61af66fc99e Initial load
duke
parents:
diff changeset
438 MutexLocker ml(ExceptionCache_lock);
a61af66fc99e Initial load
duke
parents:
diff changeset
439 ExceptionCache* target_entry = exception_cache_entry_for_exception(exception);
a61af66fc99e Initial load
duke
parents:
diff changeset
440
a61af66fc99e Initial load
duke
parents:
diff changeset
441 if (target_entry == NULL || !target_entry->add_address_and_handler(pc,handler)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
442 target_entry = new ExceptionCache(exception,pc,handler);
a61af66fc99e Initial load
duke
parents:
diff changeset
443 add_exception_cache_entry(target_entry);
a61af66fc99e Initial load
duke
parents:
diff changeset
444 }
a61af66fc99e Initial load
duke
parents:
diff changeset
445 }
a61af66fc99e Initial load
duke
parents:
diff changeset
446
a61af66fc99e Initial load
duke
parents:
diff changeset
447
a61af66fc99e Initial load
duke
parents:
diff changeset
448 //-------------end of code for ExceptionCache--------------
a61af66fc99e Initial load
duke
parents:
diff changeset
449
a61af66fc99e Initial load
duke
parents:
diff changeset
450
a61af66fc99e Initial load
duke
parents:
diff changeset
451 int nmethod::total_size() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
452 return
1762
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
453 consts_size() +
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
454 insts_size() +
0
a61af66fc99e Initial load
duke
parents:
diff changeset
455 stub_size() +
a61af66fc99e Initial load
duke
parents:
diff changeset
456 scopes_data_size() +
a61af66fc99e Initial load
duke
parents:
diff changeset
457 scopes_pcs_size() +
a61af66fc99e Initial load
duke
parents:
diff changeset
458 handler_table_size() +
a61af66fc99e Initial load
duke
parents:
diff changeset
459 nul_chk_table_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
460 }
a61af66fc99e Initial load
duke
parents:
diff changeset
461
a61af66fc99e Initial load
duke
parents:
diff changeset
462 const char* nmethod::compile_kind() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
463 if (is_osr_method()) return "osr";
1109
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
464 if (method() != NULL && is_native_method()) return "c2n";
0
a61af66fc99e Initial load
duke
parents:
diff changeset
465 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
466 }
a61af66fc99e Initial load
duke
parents:
diff changeset
467
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
468 // Fill in default values for various flag fields
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
469 void nmethod::init_defaults() {
13441
df832bd8edb9 8028107: Kitchensink crashed with EAV
kvn
parents: 13074
diff changeset
470 _state = in_use;
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
471 _unloading_clock = 0;
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
472 _marked_for_reclamation = 0;
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
473 _has_flushed_dependencies = 0;
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
474 _has_unsafe_access = 0;
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
475 _has_method_handle_invokes = 0;
4873
0382d2b469b2 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 4872
diff changeset
476 _lazy_critical_native = 0;
6792
137868b7aa6f 7196199: java/text/Bidi/Bug6665028.java failed: Bidi run count incorrect
kvn
parents: 6790
diff changeset
477 _has_wide_vectors = 0;
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
478 _marked_for_deoptimization = 0;
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
479 _lock_count = 0;
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
480 _stack_traversal_mark = 0;
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
481 _unload_reported = false; // jvmti state
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
482
1726
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
483 #ifdef ASSERT
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
484 _oops_are_stale = false;
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
485 #endif
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
486
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
487 _oops_do_mark_link = NULL;
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
488 _jmethod_id = NULL;
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
489 _osr_link = NULL;
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
490 if (UseG1GC) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
491 _unloading_next = NULL;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
492 } else {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
493 _scavenge_root_link = NULL;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
494 }
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
495 _scavenge_root_state = 0;
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
496 _compiler = NULL;
17780
606acabe7b5c 8031320: Use Intel RTM instructions for locks
kvn
parents: 13441
diff changeset
497 #if INCLUDE_RTM_OPT
606acabe7b5c 8031320: Use Intel RTM instructions for locks
kvn
parents: 13441
diff changeset
498 _rtm_state = NoRTM;
606acabe7b5c 8031320: Use Intel RTM instructions for locks
kvn
parents: 13441
diff changeset
499 #endif
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
500 #ifdef HAVE_DTRACE_H
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
501 _trap_offset = 0;
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
502 #endif // def HAVE_DTRACE_H
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
503 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
504
a61af66fc99e Initial load
duke
parents:
diff changeset
505 nmethod* nmethod::new_native_nmethod(methodHandle method,
2405
3d58a4983660 7022998: JSR 292 recursive method handle calls inline themselves infinitely
twisti
parents: 2376
diff changeset
506 int compile_id,
0
a61af66fc99e Initial load
duke
parents:
diff changeset
507 CodeBuffer *code_buffer,
a61af66fc99e Initial load
duke
parents:
diff changeset
508 int vep_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
509 int frame_complete,
a61af66fc99e Initial load
duke
parents:
diff changeset
510 int frame_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
511 ByteSize basic_lock_owner_sp_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
512 ByteSize basic_lock_sp_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
513 OopMapSet* oop_maps) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
514 code_buffer->finalize_oop_references(method);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
515 // create nmethod
a61af66fc99e Initial load
duke
parents:
diff changeset
516 nmethod* nm = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
517 {
a61af66fc99e Initial load
duke
parents:
diff changeset
518 MutexLockerEx mu(CodeCache_lock, Mutex::_no_safepoint_check_flag);
a61af66fc99e Initial load
duke
parents:
diff changeset
519 int native_nmethod_size = allocation_size(code_buffer, sizeof(nmethod));
10114
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
520 CodeOffsets offsets;
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
521 offsets.set_value(CodeOffsets::Verified_Entry, vep_offset);
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
522 offsets.set_value(CodeOffsets::Frame_Complete, frame_complete);
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
523 nm = new (native_nmethod_size) nmethod(method(), native_nmethod_size,
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
524 compile_id, &offsets,
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
525 code_buffer, frame_size,
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
526 basic_lock_owner_sp_offset,
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
527 basic_lock_sp_offset, oop_maps);
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
528 NOT_PRODUCT(if (nm != NULL) nmethod_stats.note_native_nmethod(nm));
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
529 if (PrintAssembly && nm != NULL) {
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
530 Disassembler::decode(nm);
8864
3c786355ffb4 8009026: [parfait] Null pointer deference in hotspot/src/share/vm/code/nmethod.cpp
morris
parents: 6983
diff changeset
531 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
532 }
a61af66fc99e Initial load
duke
parents:
diff changeset
533 // verify nmethod
a61af66fc99e Initial load
duke
parents:
diff changeset
534 debug_only(if (nm) nm->verify();) // might block
a61af66fc99e Initial load
duke
parents:
diff changeset
535
a61af66fc99e Initial load
duke
parents:
diff changeset
536 if (nm != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
537 nm->log_new_nmethod();
a61af66fc99e Initial load
duke
parents:
diff changeset
538 }
a61af66fc99e Initial load
duke
parents:
diff changeset
539
a61af66fc99e Initial load
duke
parents:
diff changeset
540 return nm;
a61af66fc99e Initial load
duke
parents:
diff changeset
541 }
a61af66fc99e Initial load
duke
parents:
diff changeset
542
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
543 #ifdef HAVE_DTRACE_H
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
544 nmethod* nmethod::new_dtrace_nmethod(methodHandle method,
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
545 CodeBuffer *code_buffer,
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
546 int vep_offset,
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
547 int trap_offset,
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
548 int frame_complete,
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
549 int frame_size) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
550 code_buffer->finalize_oop_references(method);
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
551 // create nmethod
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
552 nmethod* nm = NULL;
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
553 {
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
554 MutexLockerEx mu(CodeCache_lock, Mutex::_no_safepoint_check_flag);
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
555 int nmethod_size = allocation_size(code_buffer, sizeof(nmethod));
10114
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
556 CodeOffsets offsets;
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
557 offsets.set_value(CodeOffsets::Verified_Entry, vep_offset);
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
558 offsets.set_value(CodeOffsets::Dtrace_trap, trap_offset);
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
559 offsets.set_value(CodeOffsets::Frame_Complete, frame_complete);
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
560
10114
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
561 nm = new (nmethod_size) nmethod(method(), nmethod_size,
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
562 &offsets, code_buffer, frame_size);
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
563
10114
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
564 NOT_PRODUCT(if (nm != NULL) nmethod_stats.note_nmethod(nm));
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
565 if (PrintAssembly && nm != NULL) {
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
566 Disassembler::decode(nm);
8864
3c786355ffb4 8009026: [parfait] Null pointer deference in hotspot/src/share/vm/code/nmethod.cpp
morris
parents: 6983
diff changeset
567 }
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
568 }
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
569 // verify nmethod
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
570 debug_only(if (nm) nm->verify();) // might block
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
571
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
572 if (nm != NULL) {
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
573 nm->log_new_nmethod();
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
574 }
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
575
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
576 return nm;
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
577 }
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
578
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
579 #endif // def HAVE_DTRACE_H
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
580
0
a61af66fc99e Initial load
duke
parents:
diff changeset
581 nmethod* nmethod::new_nmethod(methodHandle method,
a61af66fc99e Initial load
duke
parents:
diff changeset
582 int compile_id,
a61af66fc99e Initial load
duke
parents:
diff changeset
583 int entry_bci,
a61af66fc99e Initial load
duke
parents:
diff changeset
584 CodeOffsets* offsets,
a61af66fc99e Initial load
duke
parents:
diff changeset
585 int orig_pc_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
586 DebugInformationRecorder* debug_info,
a61af66fc99e Initial load
duke
parents:
diff changeset
587 Dependencies* dependencies,
a61af66fc99e Initial load
duke
parents:
diff changeset
588 CodeBuffer* code_buffer, int frame_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
589 OopMapSet* oop_maps,
a61af66fc99e Initial load
duke
parents:
diff changeset
590 ExceptionHandlerTable* handler_table,
a61af66fc99e Initial load
duke
parents:
diff changeset
591 ImplicitExceptionTable* nul_chk_table,
a61af66fc99e Initial load
duke
parents:
diff changeset
592 AbstractCompiler* compiler,
a61af66fc99e Initial load
duke
parents:
diff changeset
593 int comp_level
a61af66fc99e Initial load
duke
parents:
diff changeset
594 )
a61af66fc99e Initial load
duke
parents:
diff changeset
595 {
a61af66fc99e Initial load
duke
parents:
diff changeset
596 assert(debug_info->oop_recorder() == code_buffer->oop_recorder(), "shared OR");
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
597 code_buffer->finalize_oop_references(method);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
598 // create nmethod
a61af66fc99e Initial load
duke
parents:
diff changeset
599 nmethod* nm = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
600 { MutexLockerEx mu(CodeCache_lock, Mutex::_no_safepoint_check_flag);
a61af66fc99e Initial load
duke
parents:
diff changeset
601 int nmethod_size =
a61af66fc99e Initial load
duke
parents:
diff changeset
602 allocation_size(code_buffer, sizeof(nmethod))
a61af66fc99e Initial load
duke
parents:
diff changeset
603 + adjust_pcs_size(debug_info->pcs_size())
a61af66fc99e Initial load
duke
parents:
diff changeset
604 + round_to(dependencies->size_in_bytes() , oopSize)
a61af66fc99e Initial load
duke
parents:
diff changeset
605 + round_to(handler_table->size_in_bytes(), oopSize)
a61af66fc99e Initial load
duke
parents:
diff changeset
606 + round_to(nul_chk_table->size_in_bytes(), oopSize)
a61af66fc99e Initial load
duke
parents:
diff changeset
607 + round_to(debug_info->data_size() , oopSize);
10114
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
608
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
609 nm = new (nmethod_size)
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
610 nmethod(method(), nmethod_size, compile_id, entry_bci, offsets,
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
611 orig_pc_offset, debug_info, dependencies, code_buffer, frame_size,
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
612 oop_maps,
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
613 handler_table,
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
614 nul_chk_table,
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
615 compiler,
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
616 comp_level);
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
617
0
a61af66fc99e Initial load
duke
parents:
diff changeset
618 if (nm != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
619 // To make dependency checking during class loading fast, record
a61af66fc99e Initial load
duke
parents:
diff changeset
620 // the nmethod dependencies in the classes it is dependent on.
a61af66fc99e Initial load
duke
parents:
diff changeset
621 // This allows the dependency checking code to simply walk the
a61af66fc99e Initial load
duke
parents:
diff changeset
622 // class hierarchy above the loaded class, checking only nmethods
a61af66fc99e Initial load
duke
parents:
diff changeset
623 // which are dependent on those classes. The slow way is to
a61af66fc99e Initial load
duke
parents:
diff changeset
624 // check every nmethod for dependencies which makes it linear in
a61af66fc99e Initial load
duke
parents:
diff changeset
625 // the number of methods compiled. For applications with a lot
a61af66fc99e Initial load
duke
parents:
diff changeset
626 // classes the slow way is too slow.
a61af66fc99e Initial load
duke
parents:
diff changeset
627 for (Dependencies::DepStream deps(nm); deps.next(); ) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
628 Klass* klass = deps.context_type();
10114
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
629 if (klass == NULL) {
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
630 continue; // ignore things like evol_method
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
631 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
632
a61af66fc99e Initial load
duke
parents:
diff changeset
633 // record this nmethod as dependent on this klass
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
634 InstanceKlass::cast(klass)->add_dependent_nmethod(nm);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
635 }
13071
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
636 NOT_PRODUCT(nmethod_stats.note_nmethod(nm));
14438
4cdf4f71177d 8029025: PPC64 (part 203): opto: Move static _in_dump_cnt to Compile object.
goetz
parents: 14435
diff changeset
637 if (PrintAssembly || CompilerOracle::has_option_string(method, "PrintAssembly")) {
13071
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
638 Disassembler::decode(nm);
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
639 }
10114
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
640 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
641 }
13071
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
642 // Do verification and logging outside CodeCache_lock.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
643 if (nm != NULL) {
13071
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
644 // Safepoints in nmethod::verify aren't allowed because nm hasn't been installed yet.
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
645 DEBUG_ONLY(nm->verify();)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
646 nm->log_new_nmethod();
a61af66fc99e Initial load
duke
parents:
diff changeset
647 }
a61af66fc99e Initial load
duke
parents:
diff changeset
648 return nm;
a61af66fc99e Initial load
duke
parents:
diff changeset
649 }
a61af66fc99e Initial load
duke
parents:
diff changeset
650
a61af66fc99e Initial load
duke
parents:
diff changeset
651
a61af66fc99e Initial load
duke
parents:
diff changeset
652 // For native wrappers
a61af66fc99e Initial load
duke
parents:
diff changeset
653 nmethod::nmethod(
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
654 Method* method,
0
a61af66fc99e Initial load
duke
parents:
diff changeset
655 int nmethod_size,
2405
3d58a4983660 7022998: JSR 292 recursive method handle calls inline themselves infinitely
twisti
parents: 2376
diff changeset
656 int compile_id,
0
a61af66fc99e Initial load
duke
parents:
diff changeset
657 CodeOffsets* offsets,
a61af66fc99e Initial load
duke
parents:
diff changeset
658 CodeBuffer* code_buffer,
a61af66fc99e Initial load
duke
parents:
diff changeset
659 int frame_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
660 ByteSize basic_lock_owner_sp_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
661 ByteSize basic_lock_sp_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
662 OopMapSet* oop_maps )
a61af66fc99e Initial load
duke
parents:
diff changeset
663 : CodeBlob("native nmethod", code_buffer, sizeof(nmethod),
a61af66fc99e Initial load
duke
parents:
diff changeset
664 nmethod_size, offsets->value(CodeOffsets::Frame_Complete), frame_size, oop_maps),
2019
09b4dd4f152b 7004582: Add GetThisObject() function to JVMTI 1.2
kamg
parents: 1972
diff changeset
665 _native_receiver_sp_offset(basic_lock_owner_sp_offset),
09b4dd4f152b 7004582: Add GetThisObject() function to JVMTI 1.2
kamg
parents: 1972
diff changeset
666 _native_basic_lock_sp_offset(basic_lock_sp_offset)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
667 {
a61af66fc99e Initial load
duke
parents:
diff changeset
668 {
a61af66fc99e Initial load
duke
parents:
diff changeset
669 debug_only(No_Safepoint_Verifier nsv;)
a61af66fc99e Initial load
duke
parents:
diff changeset
670 assert_locked_or_safepoint(CodeCache_lock);
a61af66fc99e Initial load
duke
parents:
diff changeset
671
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
672 init_defaults();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
673 _method = method;
a61af66fc99e Initial load
duke
parents:
diff changeset
674 _entry_bci = InvocationEntryBci;
a61af66fc99e Initial load
duke
parents:
diff changeset
675 // We have no exception handler or deopt handler make the
a61af66fc99e Initial load
duke
parents:
diff changeset
676 // values something that will never match a pc like the nmethod vtable entry
a61af66fc99e Initial load
duke
parents:
diff changeset
677 _exception_offset = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
678 _deoptimize_offset = 0;
1204
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
679 _deoptimize_mh_offset = 0;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
680 _orig_pc_offset = 0;
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
681
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
682 _consts_offset = data_offset();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
683 _stub_offset = data_offset();
1563
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
684 _oops_offset = data_offset();
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
685 _metadata_offset = _oops_offset + round_to(code_buffer->total_oop_size(), oopSize);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
686 _scopes_data_offset = _metadata_offset + round_to(code_buffer->total_metadata_size(), wordSize);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
687 _scopes_pcs_offset = _scopes_data_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
688 _dependencies_offset = _scopes_pcs_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
689 _handler_table_offset = _dependencies_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
690 _nul_chk_table_offset = _handler_table_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
691 _nmethod_end_offset = _nul_chk_table_offset;
2405
3d58a4983660 7022998: JSR 292 recursive method handle calls inline themselves infinitely
twisti
parents: 2376
diff changeset
692 _compile_id = compile_id;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
693 _comp_level = CompLevel_none;
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
694 _entry_point = code_begin() + offsets->value(CodeOffsets::Entry);
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
695 _verified_entry_point = code_begin() + offsets->value(CodeOffsets::Verified_Entry);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
696 _osr_entry_point = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
697 _exception_cache = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
698 _pc_desc_cache.reset_to(NULL);
12324
510fbd28919c 8020151: PSR:PERF Large performance regressions when code cache is filled
anoll
parents: 12175
diff changeset
699 _hotness_counter = NMethodSweeper::hotness_counter_reset_val();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
700
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
701 code_buffer->copy_values_to(this);
20191
fd81a5764900 8046231: G1: Code root location ... from nmethod ... not in strong code roots for region
pliden
parents: 17937
diff changeset
702 if (ScavengeRootsInCode) {
fd81a5764900 8046231: G1: Code root location ... from nmethod ... not in strong code roots for region
pliden
parents: 17937
diff changeset
703 if (detect_scavenge_root_oops()) {
fd81a5764900 8046231: G1: Code root location ... from nmethod ... not in strong code roots for region
pliden
parents: 17937
diff changeset
704 CodeCache::add_scavenge_root_nmethod(this);
fd81a5764900 8046231: G1: Code root location ... from nmethod ... not in strong code roots for region
pliden
parents: 17937
diff changeset
705 }
12080
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
706 Universe::heap()->register_nmethod(this);
2376
c7f3d0b4570f 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 2375
diff changeset
707 }
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
708 debug_only(verify_scavenge_root_oops());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
709 CodeCache::commit(this);
a61af66fc99e Initial load
duke
parents:
diff changeset
710 }
a61af66fc99e Initial load
duke
parents:
diff changeset
711
a61af66fc99e Initial load
duke
parents:
diff changeset
712 if (PrintNativeNMethods || PrintDebugInfo || PrintRelocations || PrintDependencies) {
a61af66fc99e Initial load
duke
parents:
diff changeset
713 ttyLocker ttyl; // keep the following output all in one block
a61af66fc99e Initial load
duke
parents:
diff changeset
714 // This output goes directly to the tty, not the compiler log.
a61af66fc99e Initial load
duke
parents:
diff changeset
715 // To enable tools to match it up with the compilation activity,
a61af66fc99e Initial load
duke
parents:
diff changeset
716 // be sure to tag this tty output with the compile ID.
a61af66fc99e Initial load
duke
parents:
diff changeset
717 if (xtty != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
718 xtty->begin_head("print_native_nmethod");
a61af66fc99e Initial load
duke
parents:
diff changeset
719 xtty->method(_method);
a61af66fc99e Initial load
duke
parents:
diff changeset
720 xtty->stamp();
a61af66fc99e Initial load
duke
parents:
diff changeset
721 xtty->end_head(" address='" INTPTR_FORMAT "'", (intptr_t) this);
a61af66fc99e Initial load
duke
parents:
diff changeset
722 }
a61af66fc99e Initial load
duke
parents:
diff changeset
723 // print the header part first
a61af66fc99e Initial load
duke
parents:
diff changeset
724 print();
a61af66fc99e Initial load
duke
parents:
diff changeset
725 // then print the requested information
a61af66fc99e Initial load
duke
parents:
diff changeset
726 if (PrintNativeNMethods) {
a61af66fc99e Initial load
duke
parents:
diff changeset
727 print_code();
6790
2cb2f30450c7 7196262: JSR 292: java/lang/invoke/PrivateInvokeTest.java fails on solaris-sparc
twisti
parents: 6725
diff changeset
728 if (oop_maps != NULL) {
2cb2f30450c7 7196262: JSR 292: java/lang/invoke/PrivateInvokeTest.java fails on solaris-sparc
twisti
parents: 6725
diff changeset
729 oop_maps->print();
2cb2f30450c7 7196262: JSR 292: java/lang/invoke/PrivateInvokeTest.java fails on solaris-sparc
twisti
parents: 6725
diff changeset
730 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
731 }
a61af66fc99e Initial load
duke
parents:
diff changeset
732 if (PrintRelocations) {
a61af66fc99e Initial load
duke
parents:
diff changeset
733 print_relocations();
a61af66fc99e Initial load
duke
parents:
diff changeset
734 }
a61af66fc99e Initial load
duke
parents:
diff changeset
735 if (xtty != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
736 xtty->tail("print_native_nmethod");
a61af66fc99e Initial load
duke
parents:
diff changeset
737 }
a61af66fc99e Initial load
duke
parents:
diff changeset
738 }
a61af66fc99e Initial load
duke
parents:
diff changeset
739 }
a61af66fc99e Initial load
duke
parents:
diff changeset
740
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
741 // For dtrace wrappers
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
742 #ifdef HAVE_DTRACE_H
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
743 nmethod::nmethod(
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
744 Method* method,
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
745 int nmethod_size,
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
746 CodeOffsets* offsets,
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
747 CodeBuffer* code_buffer,
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
748 int frame_size)
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
749 : CodeBlob("dtrace nmethod", code_buffer, sizeof(nmethod),
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
750 nmethod_size, offsets->value(CodeOffsets::Frame_Complete), frame_size, NULL),
2019
09b4dd4f152b 7004582: Add GetThisObject() function to JVMTI 1.2
kamg
parents: 1972
diff changeset
751 _native_receiver_sp_offset(in_ByteSize(-1)),
09b4dd4f152b 7004582: Add GetThisObject() function to JVMTI 1.2
kamg
parents: 1972
diff changeset
752 _native_basic_lock_sp_offset(in_ByteSize(-1))
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
753 {
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
754 {
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
755 debug_only(No_Safepoint_Verifier nsv;)
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
756 assert_locked_or_safepoint(CodeCache_lock);
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
757
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
758 init_defaults();
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
759 _method = method;
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
760 _entry_bci = InvocationEntryBci;
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
761 // We have no exception handler or deopt handler make the
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
762 // values something that will never match a pc like the nmethod vtable entry
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
763 _exception_offset = 0;
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
764 _deoptimize_offset = 0;
1204
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
765 _deoptimize_mh_offset = 0;
1378
9f5b60a14736 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 1253
diff changeset
766 _unwind_handler_offset = -1;
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
767 _trap_offset = offsets->value(CodeOffsets::Dtrace_trap);
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
768 _orig_pc_offset = 0;
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
769 _consts_offset = data_offset();
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
770 _stub_offset = data_offset();
1563
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
771 _oops_offset = data_offset();
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
772 _metadata_offset = _oops_offset + round_to(code_buffer->total_oop_size(), oopSize);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
773 _scopes_data_offset = _metadata_offset + round_to(code_buffer->total_metadata_size(), wordSize);
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
774 _scopes_pcs_offset = _scopes_data_offset;
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
775 _dependencies_offset = _scopes_pcs_offset;
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
776 _handler_table_offset = _dependencies_offset;
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
777 _nul_chk_table_offset = _handler_table_offset;
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
778 _nmethod_end_offset = _nul_chk_table_offset;
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
779 _compile_id = 0; // default
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
780 _comp_level = CompLevel_none;
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
781 _entry_point = code_begin() + offsets->value(CodeOffsets::Entry);
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
782 _verified_entry_point = code_begin() + offsets->value(CodeOffsets::Verified_Entry);
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
783 _osr_entry_point = NULL;
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
784 _exception_cache = NULL;
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
785 _pc_desc_cache.reset_to(NULL);
12324
510fbd28919c 8020151: PSR:PERF Large performance regressions when code cache is filled
anoll
parents: 12175
diff changeset
786 _hotness_counter = NMethodSweeper::hotness_counter_reset_val();
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
787
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
788 code_buffer->copy_values_to(this);
20191
fd81a5764900 8046231: G1: Code root location ... from nmethod ... not in strong code roots for region
pliden
parents: 17937
diff changeset
789 if (ScavengeRootsInCode) {
fd81a5764900 8046231: G1: Code root location ... from nmethod ... not in strong code roots for region
pliden
parents: 17937
diff changeset
790 if (detect_scavenge_root_oops()) {
fd81a5764900 8046231: G1: Code root location ... from nmethod ... not in strong code roots for region
pliden
parents: 17937
diff changeset
791 CodeCache::add_scavenge_root_nmethod(this);
fd81a5764900 8046231: G1: Code root location ... from nmethod ... not in strong code roots for region
pliden
parents: 17937
diff changeset
792 }
17915
e0a77b91da68 8040085: dtrace/jsdt tests crash on solaris. found an unadvertised bad scavengable oop in the code cache
anoll
parents: 17810
diff changeset
793 Universe::heap()->register_nmethod(this);
e0a77b91da68 8040085: dtrace/jsdt tests crash on solaris. found an unadvertised bad scavengable oop in the code cache
anoll
parents: 17810
diff changeset
794 }
e0a77b91da68 8040085: dtrace/jsdt tests crash on solaris. found an unadvertised bad scavengable oop in the code cache
anoll
parents: 17810
diff changeset
795 DEBUG_ONLY(verify_scavenge_root_oops();)
116
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
796 CodeCache::commit(this);
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
797 }
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
798
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
799 if (PrintNMethods || PrintDebugInfo || PrintRelocations || PrintDependencies) {
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
800 ttyLocker ttyl; // keep the following output all in one block
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
801 // This output goes directly to the tty, not the compiler log.
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
802 // To enable tools to match it up with the compilation activity,
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
803 // be sure to tag this tty output with the compile ID.
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
804 if (xtty != NULL) {
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
805 xtty->begin_head("print_dtrace_nmethod");
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
806 xtty->method(_method);
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
807 xtty->stamp();
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
808 xtty->end_head(" address='" INTPTR_FORMAT "'", (intptr_t) this);
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
809 }
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
810 // print the header part first
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
811 print();
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
812 // then print the requested information
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
813 if (PrintNMethods) {
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
814 print_code();
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
815 }
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
816 if (PrintRelocations) {
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
817 print_relocations();
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
818 }
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
819 if (xtty != NULL) {
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
820 xtty->tail("print_dtrace_nmethod");
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
821 }
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
822 }
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
823 }
018d5b58dd4f 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 100
diff changeset
824 #endif // def HAVE_DTRACE_H
0
a61af66fc99e Initial load
duke
parents:
diff changeset
825
12146
9758d9f36299 8021954: VM SIGSEGV during classloading on MacOS; hs_err_pid file produced
coleenp
parents: 12080
diff changeset
826 void* nmethod::operator new(size_t size, int nmethod_size) throw() {
10114
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
827 // Not critical, may return null if there is too little continuous memory
a7fb14888912 8006952: Slow VM due to excessive code cache freelist iteration
neliasso
parents: 8864
diff changeset
828 return CodeCache::allocate(nmethod_size);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
829 }
a61af66fc99e Initial load
duke
parents:
diff changeset
830
a61af66fc99e Initial load
duke
parents:
diff changeset
831 nmethod::nmethod(
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
832 Method* method,
0
a61af66fc99e Initial load
duke
parents:
diff changeset
833 int nmethod_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
834 int compile_id,
a61af66fc99e Initial load
duke
parents:
diff changeset
835 int entry_bci,
a61af66fc99e Initial load
duke
parents:
diff changeset
836 CodeOffsets* offsets,
a61af66fc99e Initial load
duke
parents:
diff changeset
837 int orig_pc_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
838 DebugInformationRecorder* debug_info,
a61af66fc99e Initial load
duke
parents:
diff changeset
839 Dependencies* dependencies,
a61af66fc99e Initial load
duke
parents:
diff changeset
840 CodeBuffer *code_buffer,
a61af66fc99e Initial load
duke
parents:
diff changeset
841 int frame_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
842 OopMapSet* oop_maps,
a61af66fc99e Initial load
duke
parents:
diff changeset
843 ExceptionHandlerTable* handler_table,
a61af66fc99e Initial load
duke
parents:
diff changeset
844 ImplicitExceptionTable* nul_chk_table,
a61af66fc99e Initial load
duke
parents:
diff changeset
845 AbstractCompiler* compiler,
a61af66fc99e Initial load
duke
parents:
diff changeset
846 int comp_level
a61af66fc99e Initial load
duke
parents:
diff changeset
847 )
a61af66fc99e Initial load
duke
parents:
diff changeset
848 : CodeBlob("nmethod", code_buffer, sizeof(nmethod),
a61af66fc99e Initial load
duke
parents:
diff changeset
849 nmethod_size, offsets->value(CodeOffsets::Frame_Complete), frame_size, oop_maps),
2019
09b4dd4f152b 7004582: Add GetThisObject() function to JVMTI 1.2
kamg
parents: 1972
diff changeset
850 _native_receiver_sp_offset(in_ByteSize(-1)),
09b4dd4f152b 7004582: Add GetThisObject() function to JVMTI 1.2
kamg
parents: 1972
diff changeset
851 _native_basic_lock_sp_offset(in_ByteSize(-1))
0
a61af66fc99e Initial load
duke
parents:
diff changeset
852 {
a61af66fc99e Initial load
duke
parents:
diff changeset
853 assert(debug_info->oop_recorder() == code_buffer->oop_recorder(), "shared OR");
a61af66fc99e Initial load
duke
parents:
diff changeset
854 {
a61af66fc99e Initial load
duke
parents:
diff changeset
855 debug_only(No_Safepoint_Verifier nsv;)
a61af66fc99e Initial load
duke
parents:
diff changeset
856 assert_locked_or_safepoint(CodeCache_lock);
a61af66fc99e Initial load
duke
parents:
diff changeset
857
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
858 init_defaults();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
859 _method = method;
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
860 _entry_bci = entry_bci;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
861 _compile_id = compile_id;
a61af66fc99e Initial load
duke
parents:
diff changeset
862 _comp_level = comp_level;
a61af66fc99e Initial load
duke
parents:
diff changeset
863 _compiler = compiler;
a61af66fc99e Initial load
duke
parents:
diff changeset
864 _orig_pc_offset = orig_pc_offset;
12324
510fbd28919c 8020151: PSR:PERF Large performance regressions when code cache is filled
anoll
parents: 12175
diff changeset
865 _hotness_counter = NMethodSweeper::hotness_counter_reset_val();
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
866
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
867 // Section offsets
1762
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
868 _consts_offset = content_offset() + code_buffer->total_offset_of(code_buffer->consts());
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
869 _stub_offset = content_offset() + code_buffer->total_offset_of(code_buffer->stubs());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
870
a61af66fc99e Initial load
duke
parents:
diff changeset
871 // Exception handler and deopt handler are in the stub section
2083
7d9caaedafce 6990933: assert(sender_cb) failed: sanity in frame::sender_for_interpreter_frame
twisti
parents: 1972
diff changeset
872 assert(offsets->value(CodeOffsets::Exceptions) != -1, "must be set");
7d9caaedafce 6990933: assert(sender_cb) failed: sanity in frame::sender_for_interpreter_frame
twisti
parents: 1972
diff changeset
873 assert(offsets->value(CodeOffsets::Deopt ) != -1, "must be set");
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
874 _exception_offset = _stub_offset + offsets->value(CodeOffsets::Exceptions);
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
875 _deoptimize_offset = _stub_offset + offsets->value(CodeOffsets::Deopt);
2083
7d9caaedafce 6990933: assert(sender_cb) failed: sanity in frame::sender_for_interpreter_frame
twisti
parents: 1972
diff changeset
876 if (offsets->value(CodeOffsets::DeoptMH) != -1) {
1762
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
877 _deoptimize_mh_offset = _stub_offset + offsets->value(CodeOffsets::DeoptMH);
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
878 } else {
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
879 _deoptimize_mh_offset = -1;
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
880 }
1378
9f5b60a14736 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 1253
diff changeset
881 if (offsets->value(CodeOffsets::UnwindHandler) != -1) {
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
882 _unwind_handler_offset = code_offset() + offsets->value(CodeOffsets::UnwindHandler);
1378
9f5b60a14736 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 1253
diff changeset
883 } else {
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
884 _unwind_handler_offset = -1;
1378
9f5b60a14736 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 1253
diff changeset
885 }
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
886
1563
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
887 _oops_offset = data_offset();
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
888 _metadata_offset = _oops_offset + round_to(code_buffer->total_oop_size(), oopSize);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
889 _scopes_data_offset = _metadata_offset + round_to(code_buffer->total_metadata_size(), wordSize);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
890
1563
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
891 _scopes_pcs_offset = _scopes_data_offset + round_to(debug_info->data_size (), oopSize);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
892 _dependencies_offset = _scopes_pcs_offset + adjust_pcs_size(debug_info->pcs_size());
a61af66fc99e Initial load
duke
parents:
diff changeset
893 _handler_table_offset = _dependencies_offset + round_to(dependencies->size_in_bytes (), oopSize);
a61af66fc99e Initial load
duke
parents:
diff changeset
894 _nul_chk_table_offset = _handler_table_offset + round_to(handler_table->size_in_bytes(), oopSize);
a61af66fc99e Initial load
duke
parents:
diff changeset
895 _nmethod_end_offset = _nul_chk_table_offset + round_to(nul_chk_table->size_in_bytes(), oopSize);
a61af66fc99e Initial load
duke
parents:
diff changeset
896
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
897 _entry_point = code_begin() + offsets->value(CodeOffsets::Entry);
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
898 _verified_entry_point = code_begin() + offsets->value(CodeOffsets::Verified_Entry);
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
899 _osr_entry_point = code_begin() + offsets->value(CodeOffsets::OSR_Entry);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
900 _exception_cache = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
901 _pc_desc_cache.reset_to(scopes_pcs_begin());
a61af66fc99e Initial load
duke
parents:
diff changeset
902
a61af66fc99e Initial load
duke
parents:
diff changeset
903 // Copy contents of ScopeDescRecorder to nmethod
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
904 code_buffer->copy_values_to(this);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
905 debug_info->copy_to(this);
a61af66fc99e Initial load
duke
parents:
diff changeset
906 dependencies->copy_to(this);
20191
fd81a5764900 8046231: G1: Code root location ... from nmethod ... not in strong code roots for region
pliden
parents: 17937
diff changeset
907 if (ScavengeRootsInCode) {
fd81a5764900 8046231: G1: Code root location ... from nmethod ... not in strong code roots for region
pliden
parents: 17937
diff changeset
908 if (detect_scavenge_root_oops()) {
fd81a5764900 8046231: G1: Code root location ... from nmethod ... not in strong code roots for region
pliden
parents: 17937
diff changeset
909 CodeCache::add_scavenge_root_nmethod(this);
fd81a5764900 8046231: G1: Code root location ... from nmethod ... not in strong code roots for region
pliden
parents: 17937
diff changeset
910 }
12080
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
911 Universe::heap()->register_nmethod(this);
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
912 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
913 debug_only(verify_scavenge_root_oops());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
914
a61af66fc99e Initial load
duke
parents:
diff changeset
915 CodeCache::commit(this);
a61af66fc99e Initial load
duke
parents:
diff changeset
916
a61af66fc99e Initial load
duke
parents:
diff changeset
917 // Copy contents of ExceptionHandlerTable to nmethod
a61af66fc99e Initial load
duke
parents:
diff changeset
918 handler_table->copy_to(this);
a61af66fc99e Initial load
duke
parents:
diff changeset
919 nul_chk_table->copy_to(this);
a61af66fc99e Initial load
duke
parents:
diff changeset
920
a61af66fc99e Initial load
duke
parents:
diff changeset
921 // we use the information of entry points to find out if a method is
a61af66fc99e Initial load
duke
parents:
diff changeset
922 // static or non static
a61af66fc99e Initial load
duke
parents:
diff changeset
923 assert(compiler->is_c2() ||
a61af66fc99e Initial load
duke
parents:
diff changeset
924 _method->is_static() == (entry_point() == _verified_entry_point),
a61af66fc99e Initial load
duke
parents:
diff changeset
925 " entry points must be same for static methods and vice versa");
a61af66fc99e Initial load
duke
parents:
diff changeset
926 }
a61af66fc99e Initial load
duke
parents:
diff changeset
927
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
928 bool printnmethods = PrintNMethods
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
929 || CompilerOracle::should_print(_method)
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
930 || CompilerOracle::has_option_string(_method, "PrintNMethods");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
931 if (printnmethods || PrintDebugInfo || PrintRelocations || PrintDependencies || PrintExceptionHandlers) {
a61af66fc99e Initial load
duke
parents:
diff changeset
932 print_nmethod(printnmethods);
a61af66fc99e Initial load
duke
parents:
diff changeset
933 }
a61af66fc99e Initial load
duke
parents:
diff changeset
934 }
a61af66fc99e Initial load
duke
parents:
diff changeset
935
a61af66fc99e Initial load
duke
parents:
diff changeset
936
a61af66fc99e Initial load
duke
parents:
diff changeset
937 // Print a short set of xml attributes to identify this nmethod. The
a61af66fc99e Initial load
duke
parents:
diff changeset
938 // output should be embedded in some other element.
a61af66fc99e Initial load
duke
parents:
diff changeset
939 void nmethod::log_identity(xmlStream* log) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
940 log->print(" compile_id='%d'", compile_id());
a61af66fc99e Initial load
duke
parents:
diff changeset
941 const char* nm_kind = compile_kind();
a61af66fc99e Initial load
duke
parents:
diff changeset
942 if (nm_kind != NULL) log->print(" compile_kind='%s'", nm_kind);
a61af66fc99e Initial load
duke
parents:
diff changeset
943 if (compiler() != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
944 log->print(" compiler='%s'", compiler()->name());
a61af66fc99e Initial load
duke
parents:
diff changeset
945 }
1783
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1762
diff changeset
946 if (TieredCompilation) {
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1762
diff changeset
947 log->print(" level='%d'", comp_level());
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1762
diff changeset
948 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
949 }
a61af66fc99e Initial load
duke
parents:
diff changeset
950
a61af66fc99e Initial load
duke
parents:
diff changeset
951
a61af66fc99e Initial load
duke
parents:
diff changeset
952 #define LOG_OFFSET(log, name) \
a61af66fc99e Initial load
duke
parents:
diff changeset
953 if ((intptr_t)name##_end() - (intptr_t)name##_begin()) \
a61af66fc99e Initial load
duke
parents:
diff changeset
954 log->print(" " XSTR(name) "_offset='%d'" , \
a61af66fc99e Initial load
duke
parents:
diff changeset
955 (intptr_t)name##_begin() - (intptr_t)this)
a61af66fc99e Initial load
duke
parents:
diff changeset
956
a61af66fc99e Initial load
duke
parents:
diff changeset
957
a61af66fc99e Initial load
duke
parents:
diff changeset
958 void nmethod::log_new_nmethod() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
959 if (LogCompilation && xtty != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
960 ttyLocker ttyl;
a61af66fc99e Initial load
duke
parents:
diff changeset
961 HandleMark hm;
a61af66fc99e Initial load
duke
parents:
diff changeset
962 xtty->begin_elem("nmethod");
a61af66fc99e Initial load
duke
parents:
diff changeset
963 log_identity(xtty);
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
964 xtty->print(" entry='" INTPTR_FORMAT "' size='%d'", code_begin(), size());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
965 xtty->print(" address='" INTPTR_FORMAT "'", (intptr_t) this);
a61af66fc99e Initial load
duke
parents:
diff changeset
966
a61af66fc99e Initial load
duke
parents:
diff changeset
967 LOG_OFFSET(xtty, relocation);
1762
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
968 LOG_OFFSET(xtty, consts);
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
969 LOG_OFFSET(xtty, insts);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
970 LOG_OFFSET(xtty, stub);
a61af66fc99e Initial load
duke
parents:
diff changeset
971 LOG_OFFSET(xtty, scopes_data);
a61af66fc99e Initial load
duke
parents:
diff changeset
972 LOG_OFFSET(xtty, scopes_pcs);
a61af66fc99e Initial load
duke
parents:
diff changeset
973 LOG_OFFSET(xtty, dependencies);
a61af66fc99e Initial load
duke
parents:
diff changeset
974 LOG_OFFSET(xtty, handler_table);
a61af66fc99e Initial load
duke
parents:
diff changeset
975 LOG_OFFSET(xtty, nul_chk_table);
a61af66fc99e Initial load
duke
parents:
diff changeset
976 LOG_OFFSET(xtty, oops);
a61af66fc99e Initial load
duke
parents:
diff changeset
977
a61af66fc99e Initial load
duke
parents:
diff changeset
978 xtty->method(method());
a61af66fc99e Initial load
duke
parents:
diff changeset
979 xtty->stamp();
a61af66fc99e Initial load
duke
parents:
diff changeset
980 xtty->end_elem();
a61af66fc99e Initial load
duke
parents:
diff changeset
981 }
a61af66fc99e Initial load
duke
parents:
diff changeset
982 }
a61af66fc99e Initial load
duke
parents:
diff changeset
983
a61af66fc99e Initial load
duke
parents:
diff changeset
984 #undef LOG_OFFSET
a61af66fc99e Initial load
duke
parents:
diff changeset
985
a61af66fc99e Initial load
duke
parents:
diff changeset
986
a61af66fc99e Initial load
duke
parents:
diff changeset
987 // Print out more verbose output usually for a newly created nmethod.
2405
3d58a4983660 7022998: JSR 292 recursive method handle calls inline themselves infinitely
twisti
parents: 2376
diff changeset
988 void nmethod::print_on(outputStream* st, const char* msg) const {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
989 if (st != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
990 ttyLocker ttyl;
6266
1d7922586cf6 7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents: 4873
diff changeset
991 if (WizardMode) {
1d7922586cf6 7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents: 4873
diff changeset
992 CompileTask::print_compilation(st, this, msg, /*short_form:*/ true);
1d7922586cf6 7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents: 4873
diff changeset
993 st->print_cr(" (" INTPTR_FORMAT ")", this);
1d7922586cf6 7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents: 4873
diff changeset
994 } else {
1d7922586cf6 7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents: 4873
diff changeset
995 CompileTask::print_compilation(st, this, msg, /*short_form:*/ false);
1d7922586cf6 7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents: 4873
diff changeset
996 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
997 }
a61af66fc99e Initial load
duke
parents:
diff changeset
998 }
a61af66fc99e Initial load
duke
parents:
diff changeset
999
a61af66fc99e Initial load
duke
parents:
diff changeset
1000
a61af66fc99e Initial load
duke
parents:
diff changeset
1001 void nmethod::print_nmethod(bool printmethod) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1002 ttyLocker ttyl; // keep the following output all in one block
a61af66fc99e Initial load
duke
parents:
diff changeset
1003 if (xtty != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1004 xtty->begin_head("print_nmethod");
a61af66fc99e Initial load
duke
parents:
diff changeset
1005 xtty->stamp();
a61af66fc99e Initial load
duke
parents:
diff changeset
1006 xtty->end_head();
a61af66fc99e Initial load
duke
parents:
diff changeset
1007 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1008 // print the header part first
a61af66fc99e Initial load
duke
parents:
diff changeset
1009 print();
a61af66fc99e Initial load
duke
parents:
diff changeset
1010 // then print the requested information
a61af66fc99e Initial load
duke
parents:
diff changeset
1011 if (printmethod) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1012 print_code();
a61af66fc99e Initial load
duke
parents:
diff changeset
1013 print_pcs();
6266
1d7922586cf6 7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents: 4873
diff changeset
1014 if (oop_maps()) {
1d7922586cf6 7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents: 4873
diff changeset
1015 oop_maps()->print();
1d7922586cf6 7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents: 4873
diff changeset
1016 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1017 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1018 if (PrintDebugInfo) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1019 print_scopes();
a61af66fc99e Initial load
duke
parents:
diff changeset
1020 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1021 if (PrintRelocations) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1022 print_relocations();
a61af66fc99e Initial load
duke
parents:
diff changeset
1023 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1024 if (PrintDependencies) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1025 print_dependencies();
a61af66fc99e Initial load
duke
parents:
diff changeset
1026 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1027 if (PrintExceptionHandlers) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1028 print_handler_table();
a61af66fc99e Initial load
duke
parents:
diff changeset
1029 print_nul_chk_table();
a61af66fc99e Initial load
duke
parents:
diff changeset
1030 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1031 if (xtty != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1032 xtty->tail("print_nmethod");
a61af66fc99e Initial load
duke
parents:
diff changeset
1033 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1034 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1035
a61af66fc99e Initial load
duke
parents:
diff changeset
1036
1563
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1037 // Promote one word from an assembly-time handle to a live embedded oop.
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1038 inline void nmethod::initialize_immediate_oop(oop* dest, jobject handle) {
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1039 if (handle == NULL ||
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1040 // As a special case, IC oops are initialized to 1 or -1.
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1041 handle == (jobject) Universe::non_oop_word()) {
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1042 (*dest) = (oop) handle;
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1043 } else {
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1044 (*dest) = JNIHandles::resolve_non_null(handle);
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1045 }
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1046 }
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1047
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1048
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1049 // Have to have the same name because it's called by a template
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1050 void nmethod::copy_values(GrowableArray<jobject>* array) {
1563
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1051 int length = array->length();
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1052 assert((address)(oops_begin() + length) <= (address)oops_end(), "oops big enough");
1563
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1053 oop* dest = oops_begin();
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1054 for (int index = 0 ; index < length; index++) {
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1055 initialize_immediate_oop(&dest[index], array->at(index));
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1056 }
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1057
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1058 // Now we can fix up all the oops in the code. We need to do this
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1059 // in the code because the assembler uses jobjects as placeholders.
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1060 // The code and relocations have already been initialized by the
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1061 // CodeBlob constructor, so it is valid even at this early point to
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1062 // iterate over relocations and patch the code.
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1063 fix_oop_relocations(NULL, NULL, /*initialize_immediates=*/ true);
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1064 }
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1065
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1066 void nmethod::copy_values(GrowableArray<Metadata*>* array) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1067 int length = array->length();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1068 assert((address)(metadata_begin() + length) <= (address)metadata_end(), "big enough");
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1069 Metadata** dest = metadata_begin();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1070 for (int index = 0 ; index < length; index++) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1071 dest[index] = array->at(index);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1072 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1073 }
1563
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1074
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1075 bool nmethod::is_at_poll_return(address pc) {
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1076 RelocIterator iter(this, pc, pc+1);
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1077 while (iter.next()) {
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1078 if (iter.type() == relocInfo::poll_return_type)
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1079 return true;
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1080 }
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1081 return false;
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1082 }
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1083
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1084
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1085 bool nmethod::is_at_poll_or_poll_return(address pc) {
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1086 RelocIterator iter(this, pc, pc+1);
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1087 while (iter.next()) {
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1088 relocInfo::relocType t = iter.type();
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1089 if (t == relocInfo::poll_return_type || t == relocInfo::poll_type)
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1090 return true;
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1091 }
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1092 return false;
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1093 }
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1094
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1095
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1096 void nmethod::fix_oop_relocations(address begin, address end, bool initialize_immediates) {
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1097 // re-patch all oop-bearing instructions, just in case some oops moved
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1098 RelocIterator iter(this, begin, end);
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1099 while (iter.next()) {
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1100 if (iter.type() == relocInfo::oop_type) {
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1101 oop_Relocation* reloc = iter.oop_reloc();
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1102 if (initialize_immediates && reloc->oop_is_immediate()) {
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1103 oop* dest = reloc->oop_addr();
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1104 initialize_immediate_oop(dest, (jobject) *dest);
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1105 }
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1106 // Refresh the oop-related bits of this instruction.
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1107 reloc->fix_oop_relocation();
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1108 } else if (iter.type() == relocInfo::metadata_type) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1109 metadata_Relocation* reloc = iter.metadata_reloc();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1110 reloc->fix_metadata_relocation();
1563
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1111 }
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1112 }
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1113 }
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1114
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
1115
2375
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1116 void nmethod::verify_oop_relocations() {
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1117 // Ensure sure that the code matches the current oop values
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1118 RelocIterator iter(this, NULL, NULL);
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1119 while (iter.next()) {
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1120 if (iter.type() == relocInfo::oop_type) {
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1121 oop_Relocation* reloc = iter.oop_reloc();
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1122 if (!reloc->oop_is_immediate()) {
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1123 reloc->verify_oop_relocation();
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1124 }
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1125 }
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1126 }
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1127 }
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1128
d673ef06fe96 7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents: 2360
diff changeset
1129
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1130 ScopeDesc* nmethod::scope_desc_at(address pc) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1131 PcDesc* pd = pc_desc_at(pc);
a61af66fc99e Initial load
duke
parents:
diff changeset
1132 guarantee(pd != NULL, "scope must be present");
a61af66fc99e Initial load
duke
parents:
diff changeset
1133 return new ScopeDesc(this, pd->scope_decode_offset(),
1253
f70b0d9ab095 6910618: C2: Error: assert(d->is_oop(),"JVM_ArrayCopy: dst not an oop")
kvn
parents: 1250
diff changeset
1134 pd->obj_decode_offset(), pd->should_reexecute(),
f70b0d9ab095 6910618: C2: Error: assert(d->is_oop(),"JVM_ArrayCopy: dst not an oop")
kvn
parents: 1250
diff changeset
1135 pd->return_oop());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1136 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1137
a61af66fc99e Initial load
duke
parents:
diff changeset
1138
a61af66fc99e Initial load
duke
parents:
diff changeset
1139 void nmethod::clear_inline_caches() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1140 assert(SafepointSynchronize::is_at_safepoint(), "cleaning of IC's only allowed at safepoint");
a61af66fc99e Initial load
duke
parents:
diff changeset
1141 if (is_zombie()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1142 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
1143 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1144
a61af66fc99e Initial load
duke
parents:
diff changeset
1145 RelocIterator iter(this);
a61af66fc99e Initial load
duke
parents:
diff changeset
1146 while (iter.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1147 iter.reloc()->clear_inline_cache();
a61af66fc99e Initial load
duke
parents:
diff changeset
1148 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1149 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1150
a61af66fc99e Initial load
duke
parents:
diff changeset
1151
a61af66fc99e Initial load
duke
parents:
diff changeset
1152 void nmethod::cleanup_inline_caches() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1153
1538
bfe29ec02863 6950075: nmethod sweeper should operate concurrently
never
parents: 1490
diff changeset
1154 assert_locked_or_safepoint(CompiledIC_lock);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1155
a61af66fc99e Initial load
duke
parents:
diff changeset
1156 // If the method is not entrant or zombie then a JMP is plastered over the
a61af66fc99e Initial load
duke
parents:
diff changeset
1157 // first few bytes. If an oop in the old code was there, that oop
a61af66fc99e Initial load
duke
parents:
diff changeset
1158 // should not get GC'd. Skip the first few bytes of oops on
a61af66fc99e Initial load
duke
parents:
diff changeset
1159 // not-entrant methods.
a61af66fc99e Initial load
duke
parents:
diff changeset
1160 address low_boundary = verified_entry_point();
a61af66fc99e Initial load
duke
parents:
diff changeset
1161 if (!is_in_use()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1162 low_boundary += NativeJump::instruction_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
1163 // %%% Note: On SPARC we patch only a 4-byte trap, not a full NativeJump.
a61af66fc99e Initial load
duke
parents:
diff changeset
1164 // This means that the low_boundary is going to be a little too high.
a61af66fc99e Initial load
duke
parents:
diff changeset
1165 // This shouldn't matter, since oops of non-entrant methods are never used.
a61af66fc99e Initial load
duke
parents:
diff changeset
1166 // In fact, why are we bothering to look at oops in a non-entrant method??
a61af66fc99e Initial load
duke
parents:
diff changeset
1167 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1168
a61af66fc99e Initial load
duke
parents:
diff changeset
1169 // Find all calls in an nmethod, and clear the ones that points to zombie methods
a61af66fc99e Initial load
duke
parents:
diff changeset
1170 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
1171 RelocIterator iter(this, low_boundary);
a61af66fc99e Initial load
duke
parents:
diff changeset
1172 while(iter.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1173 switch(iter.type()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1174 case relocInfo::virtual_call_type:
a61af66fc99e Initial load
duke
parents:
diff changeset
1175 case relocInfo::opt_virtual_call_type: {
20277
882004b9e7e1 8047362: Add a version of CompiledIC_at that doesn't create a new RelocIterator
stefank
parents: 20269
diff changeset
1176 CompiledIC *ic = CompiledIC_at(&iter);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1177 // Ok, to lookup references to zombies here
a61af66fc99e Initial load
duke
parents:
diff changeset
1178 CodeBlob *cb = CodeCache::find_blob_unsafe(ic->ic_destination());
a61af66fc99e Initial load
duke
parents:
diff changeset
1179 if( cb != NULL && cb->is_nmethod() ) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1180 nmethod* nm = (nmethod*)cb;
a61af66fc99e Initial load
duke
parents:
diff changeset
1181 // Clean inline caches pointing to both zombie and not_entrant methods
1202
5f24d0319e54 4360113: Evict nmethods when code cache gets full
kvn
parents: 1201
diff changeset
1182 if (!nm->is_in_use() || (nm->method()->code() != nm)) ic->set_to_clean();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1183 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1184 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
1185 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1186 case relocInfo::static_call_type: {
a61af66fc99e Initial load
duke
parents:
diff changeset
1187 CompiledStaticCall *csc = compiledStaticCall_at(iter.reloc());
a61af66fc99e Initial load
duke
parents:
diff changeset
1188 CodeBlob *cb = CodeCache::find_blob_unsafe(csc->destination());
a61af66fc99e Initial load
duke
parents:
diff changeset
1189 if( cb != NULL && cb->is_nmethod() ) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1190 nmethod* nm = (nmethod*)cb;
a61af66fc99e Initial load
duke
parents:
diff changeset
1191 // Clean inline caches pointing to both zombie and not_entrant methods
1202
5f24d0319e54 4360113: Evict nmethods when code cache gets full
kvn
parents: 1201
diff changeset
1192 if (!nm->is_in_use() || (nm->method()->code() != nm)) csc->set_to_clean();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1193 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1194 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
1195 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1196 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1197 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1198 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1199
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1200 void nmethod::verify_clean_inline_caches() {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1201 assert_locked_or_safepoint(CompiledIC_lock);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1202
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1203 // If the method is not entrant or zombie then a JMP is plastered over the
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1204 // first few bytes. If an oop in the old code was there, that oop
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1205 // should not get GC'd. Skip the first few bytes of oops on
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1206 // not-entrant methods.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1207 address low_boundary = verified_entry_point();
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1208 if (!is_in_use()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1209 low_boundary += NativeJump::instruction_size;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1210 // %%% Note: On SPARC we patch only a 4-byte trap, not a full NativeJump.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1211 // This means that the low_boundary is going to be a little too high.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1212 // This shouldn't matter, since oops of non-entrant methods are never used.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1213 // In fact, why are we bothering to look at oops in a non-entrant method??
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1214 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1215
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1216 ResourceMark rm;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1217 RelocIterator iter(this, low_boundary);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1218 while(iter.next()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1219 switch(iter.type()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1220 case relocInfo::virtual_call_type:
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1221 case relocInfo::opt_virtual_call_type: {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1222 CompiledIC *ic = CompiledIC_at(&iter);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1223 // Ok, to lookup references to zombies here
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1224 CodeBlob *cb = CodeCache::find_blob_unsafe(ic->ic_destination());
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1225 if( cb != NULL && cb->is_nmethod() ) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1226 nmethod* nm = (nmethod*)cb;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1227 // Verify that inline caches pointing to both zombie and not_entrant methods are clean
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1228 if (!nm->is_in_use() || (nm->method()->code() != nm)) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1229 assert(ic->is_clean(), "IC should be clean");
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1230 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1231 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1232 break;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1233 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1234 case relocInfo::static_call_type: {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1235 CompiledStaticCall *csc = compiledStaticCall_at(iter.reloc());
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1236 CodeBlob *cb = CodeCache::find_blob_unsafe(csc->destination());
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1237 if( cb != NULL && cb->is_nmethod() ) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1238 nmethod* nm = (nmethod*)cb;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1239 // Verify that inline caches pointing to both zombie and not_entrant methods are clean
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1240 if (!nm->is_in_use() || (nm->method()->code() != nm)) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1241 assert(csc->is_clean(), "IC should be clean");
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1242 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1243 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1244 break;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1245 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1246 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1247 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1248 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1249
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1250 int nmethod::verify_icholder_relocations() {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1251 int count = 0;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1252
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1253 RelocIterator iter(this);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1254 while(iter.next()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1255 if (iter.type() == relocInfo::virtual_call_type) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1256 if (CompiledIC::is_icholder_call_site(iter.virtual_call_reloc())) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1257 CompiledIC *ic = CompiledIC_at(&iter);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1258 if (TraceCompiledIC) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1259 tty->print("noticed icholder " INTPTR_FORMAT " ", p2i(ic->cached_icholder()));
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1260 ic->print();
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1261 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1262 assert(ic->cached_icholder() != NULL, "must be non-NULL");
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1263 count++;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1264 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1265 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1266 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1267
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1268 return count;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1269 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1270
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
1271 // This is a private interface with the sweeper.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1272 void nmethod::mark_as_seen_on_stack() {
12324
510fbd28919c 8020151: PSR:PERF Large performance regressions when code cache is filled
anoll
parents: 12175
diff changeset
1273 assert(is_alive(), "Must be an alive method");
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1274 // Set the traversal mark to ensure that the sweeper does 2
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1275 // cleaning passes before moving to zombie.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1276 set_stack_traversal_mark(NMethodSweeper::traversal_count());
a61af66fc99e Initial load
duke
parents:
diff changeset
1277 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1278
2342
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
1279 // Tell if a non-entrant method can be converted to a zombie (i.e.,
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
1280 // there are no activations on the stack, not in use by the VM,
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
1281 // and not in use by the ServiceThread)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1282 bool nmethod::can_not_entrant_be_converted() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1283 assert(is_not_entrant(), "must be a non-entrant method");
a61af66fc99e Initial load
duke
parents:
diff changeset
1284
a61af66fc99e Initial load
duke
parents:
diff changeset
1285 // Since the nmethod sweeper only does partial sweep the sweeper's traversal
a61af66fc99e Initial load
duke
parents:
diff changeset
1286 // count can be greater than the stack traversal count before it hits the
a61af66fc99e Initial load
duke
parents:
diff changeset
1287 // nmethod for the second time.
2342
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
1288 return stack_traversal_mark()+1 < NMethodSweeper::traversal_count() &&
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
1289 !is_locked_by_vm();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1290 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1291
a61af66fc99e Initial load
duke
parents:
diff changeset
1292 void nmethod::inc_decompile_count() {
1783
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1762
diff changeset
1293 if (!is_compiled_by_c2()) return;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1294 // Could be gated by ProfileTraps, but do not bother...
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1295 Method* m = method();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1296 if (m == NULL) return;
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1297 MethodData* mdo = m->method_data();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1298 if (mdo == NULL) return;
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1299 // There is a benign race here. See comments in methodData.hpp.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1300 mdo->inc_decompile_count();
a61af66fc99e Initial load
duke
parents:
diff changeset
1301 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1302
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1303 void nmethod::increase_unloading_clock() {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1304 _global_unloading_clock++;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1305 if (_global_unloading_clock == 0) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1306 // _nmethods are allocated with _unloading_clock == 0,
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1307 // so 0 is never used as a clock value.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1308 _global_unloading_clock = 1;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1309 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1310 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1311
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1312 void nmethod::set_unloading_clock(unsigned char unloading_clock) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1313 OrderAccess::release_store((volatile jubyte*)&_unloading_clock, unloading_clock);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1314 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1315
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1316 unsigned char nmethod::unloading_clock() {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1317 return (unsigned char)OrderAccess::load_acquire((volatile jubyte*)&_unloading_clock);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1318 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1319
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1320 void nmethod::make_unloaded(BoolObjectClosure* is_alive, oop cause) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1321
a61af66fc99e Initial load
duke
parents:
diff changeset
1322 post_compiled_method_unload();
a61af66fc99e Initial load
duke
parents:
diff changeset
1323
a61af66fc99e Initial load
duke
parents:
diff changeset
1324 // Since this nmethod is being unloaded, make sure that dependencies
a61af66fc99e Initial load
duke
parents:
diff changeset
1325 // recorded in instanceKlasses get flushed and pass non-NULL closure to
a61af66fc99e Initial load
duke
parents:
diff changeset
1326 // indicate that this work is being done during a GC.
a61af66fc99e Initial load
duke
parents:
diff changeset
1327 assert(Universe::heap()->is_gc_active(), "should only be called during gc");
a61af66fc99e Initial load
duke
parents:
diff changeset
1328 assert(is_alive != NULL, "Should be non-NULL");
a61af66fc99e Initial load
duke
parents:
diff changeset
1329 // A non-NULL is_alive closure indicates that this is being called during GC.
a61af66fc99e Initial load
duke
parents:
diff changeset
1330 flush_dependencies(is_alive);
a61af66fc99e Initial load
duke
parents:
diff changeset
1331
a61af66fc99e Initial load
duke
parents:
diff changeset
1332 // Break cycle between nmethod & method
a61af66fc99e Initial load
duke
parents:
diff changeset
1333 if (TraceClassUnloading && WizardMode) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1334 tty->print_cr("[Class unloading: Making nmethod " INTPTR_FORMAT
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1335 " unloadable], Method*(" INTPTR_FORMAT
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1336 "), cause(" INTPTR_FORMAT ")",
a61af66fc99e Initial load
duke
parents:
diff changeset
1337 this, (address)_method, (address)cause);
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
1338 if (!Universe::heap()->is_gc_active())
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
1339 cause->klass()->print();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1340 }
941
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 605
diff changeset
1341 // Unlink the osr method, so we do not look this up again
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 605
diff changeset
1342 if (is_osr_method()) {
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 605
diff changeset
1343 invalidate_osr_method();
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 605
diff changeset
1344 }
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1345 // If _method is already NULL the Method* is about to be unloaded,
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1346 // so we don't have to break the cycle. Note that it is possible to
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1347 // have the Method* live here, in case we unload the nmethod because
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1348 // it is pointing to some oop (other than the Method*) being unloaded.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1349 if (_method != NULL) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1350 // OSR methods point to the Method*, but the Method* does not
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1351 // point back!
a61af66fc99e Initial load
duke
parents:
diff changeset
1352 if (_method->code() == this) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1353 _method->clear_code(); // Break a cycle
a61af66fc99e Initial load
duke
parents:
diff changeset
1354 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1355 _method = NULL; // Clear the method of this dead nmethod
a61af66fc99e Initial load
duke
parents:
diff changeset
1356 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1357 // Make the class unloaded - i.e., change state and notify sweeper
1538
bfe29ec02863 6950075: nmethod sweeper should operate concurrently
never
parents: 1490
diff changeset
1358 assert(SafepointSynchronize::is_at_safepoint(), "must be at safepoint");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1359 if (is_in_use()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1360 // Transitioning directly from live to unloaded -- so
a61af66fc99e Initial load
duke
parents:
diff changeset
1361 // we need to force a cache clean-up; remember this
a61af66fc99e Initial load
duke
parents:
diff changeset
1362 // for later on.
a61af66fc99e Initial load
duke
parents:
diff changeset
1363 CodeCache::set_needs_cache_clean(true);
a61af66fc99e Initial load
duke
parents:
diff changeset
1364 }
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1365
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1366 // Unregister must be done before the state change
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1367 Universe::heap()->unregister_nmethod(this);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1368
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1369 _state = unloaded;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1370
1109
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1371 // Log the unloading.
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1372 log_state_change();
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1373
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1374 // The Method* is gone at this point
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1375 assert(_method == NULL, "Tautology");
a61af66fc99e Initial load
duke
parents:
diff changeset
1376
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
1377 set_osr_link(NULL);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
1378 //set_scavenge_root_link(NULL); // done by prune_scavenge_root_nmethods
13074
78da3894b86f 8027593: performance drop with constrained codecache starting with hs25 b111
anoll
parents: 13071
diff changeset
1379 NMethodSweeper::report_state_change(this);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1380 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1381
a61af66fc99e Initial load
duke
parents:
diff changeset
1382 void nmethod::invalidate_osr_method() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1383 assert(_entry_bci != InvocationEntryBci, "wrong kind of nmethod");
a61af66fc99e Initial load
duke
parents:
diff changeset
1384 // Remove from list of active nmethods
a61af66fc99e Initial load
duke
parents:
diff changeset
1385 if (method() != NULL)
6940
18fb7da42534 8000725: NPG: method_holder() and pool_holder() and pool_holder field should be InstanceKlass
coleenp
parents: 6806
diff changeset
1386 method()->method_holder()->remove_osr_nmethod(this);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1387 // Set entry as invalid
a61af66fc99e Initial load
duke
parents:
diff changeset
1388 _entry_bci = InvalidOSREntryBci;
a61af66fc99e Initial load
duke
parents:
diff changeset
1389 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1390
1109
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1391 void nmethod::log_state_change() const {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1392 if (LogCompilation) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1393 if (xtty != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1394 ttyLocker ttyl; // keep the following output all in one block
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1395 if (_state == unloaded) {
1109
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1396 xtty->begin_elem("make_unloaded thread='" UINTX_FORMAT "'",
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1397 os::current_thread_id());
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1398 } else {
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1399 xtty->begin_elem("make_not_entrant thread='" UINTX_FORMAT "'%s",
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1400 os::current_thread_id(),
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1401 (_state == zombie ? " zombie='1'" : ""));
1109
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1402 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1403 log_identity(xtty);
a61af66fc99e Initial load
duke
parents:
diff changeset
1404 xtty->stamp();
a61af66fc99e Initial load
duke
parents:
diff changeset
1405 xtty->end_elem();
a61af66fc99e Initial load
duke
parents:
diff changeset
1406 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1407 }
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1408 if (PrintCompilation && _state != unloaded) {
2405
3d58a4983660 7022998: JSR 292 recursive method handle calls inline themselves infinitely
twisti
parents: 2376
diff changeset
1409 print_on(tty, _state == zombie ? "made zombie" : "made not entrant");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1410 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1411 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1412
13074
78da3894b86f 8027593: performance drop with constrained codecache starting with hs25 b111
anoll
parents: 13071
diff changeset
1413 /**
78da3894b86f 8027593: performance drop with constrained codecache starting with hs25 b111
anoll
parents: 13071
diff changeset
1414 * Common functionality for both make_not_entrant and make_zombie
78da3894b86f 8027593: performance drop with constrained codecache starting with hs25 b111
anoll
parents: 13071
diff changeset
1415 */
1141
b1f619d38249 6914002: unsigned compare problem after 5057818
never
parents: 1138
diff changeset
1416 bool nmethod::make_not_entrant_or_zombie(unsigned int state) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1417 assert(state == zombie || state == not_entrant, "must be zombie or not_entrant");
2342
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
1418 assert(!is_zombie(), "should not already be a zombie");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1419
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1420 // Make sure neither the nmethod nor the method is flushed in case of a safepoint in code below.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1421 nmethodLocker nml(this);
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1422 methodHandle the_method(method());
1726
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1423 No_Safepoint_Verifier nsv;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1424
12080
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1425 // during patching, depending on the nmethod state we must notify the GC that
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1426 // code has been unloaded, unregistering it. We cannot do this right while
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1427 // holding the Patching_lock because we need to use the CodeCache_lock. This
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1428 // would be prone to deadlocks.
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1429 // This flag is used to remember whether we need to later lock and unregister.
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1430 bool nmethod_needs_unregister = false;
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1431
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1432 {
1109
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1433 // invalidate osr nmethod before acquiring the patching lock since
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1434 // they both acquire leaf locks and we don't want a deadlock.
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1435 // This logic is equivalent to the logic below for patching the
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1436 // verified entry point of regular methods.
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1437 if (is_osr_method()) {
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1438 // this effectively makes the osr nmethod not entrant
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1439 invalidate_osr_method();
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1440 }
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1441
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1442 // Enter critical section. Does not block for safepoint.
a61af66fc99e Initial load
duke
parents:
diff changeset
1443 MutexLockerEx pl(Patching_lock, Mutex::_no_safepoint_check_flag);
1109
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1444
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1445 if (_state == state) {
1109
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1446 // another thread already performed this transition so nothing
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1447 // to do, but return false to indicate this.
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1448 return false;
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1449 }
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1450
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1451 // The caller can be calling the method statically or through an inline
a61af66fc99e Initial load
duke
parents:
diff changeset
1452 // cache call.
1109
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1453 if (!is_osr_method() && !is_not_entrant()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1454 NativeJump::patch_verified_entry(entry_point(), verified_entry_point(),
a61af66fc99e Initial load
duke
parents:
diff changeset
1455 SharedRuntime::get_handle_wrong_method_stub());
a61af66fc99e Initial load
duke
parents:
diff changeset
1456 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1457
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1458 if (is_in_use()) {
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1459 // It's a true state change, so mark the method as decompiled.
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1460 // Do it only for transition from alive.
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1461 inc_decompile_count();
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1462 }
1206
87684f1a88b5 6614597: Performance variability in jvm2008 xml.validation
kvn
parents: 1204
diff changeset
1463
12080
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1464 // If the state is becoming a zombie, signal to unregister the nmethod with
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1465 // the heap.
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1466 // This nmethod may have already been unloaded during a full GC.
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1467 if ((state == zombie) && !is_unloaded()) {
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1468 nmethod_needs_unregister = true;
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1469 }
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1470
12324
510fbd28919c 8020151: PSR:PERF Large performance regressions when code cache is filled
anoll
parents: 12175
diff changeset
1471 // Must happen before state change. Otherwise we have a race condition in
510fbd28919c 8020151: PSR:PERF Large performance regressions when code cache is filled
anoll
parents: 12175
diff changeset
1472 // nmethod::can_not_entrant_be_converted(). I.e., a method can immediately
510fbd28919c 8020151: PSR:PERF Large performance regressions when code cache is filled
anoll
parents: 12175
diff changeset
1473 // transition its state from 'not_entrant' to 'zombie' without having to wait
510fbd28919c 8020151: PSR:PERF Large performance regressions when code cache is filled
anoll
parents: 12175
diff changeset
1474 // for stack scanning.
510fbd28919c 8020151: PSR:PERF Large performance regressions when code cache is filled
anoll
parents: 12175
diff changeset
1475 if (state == not_entrant) {
510fbd28919c 8020151: PSR:PERF Large performance regressions when code cache is filled
anoll
parents: 12175
diff changeset
1476 mark_as_seen_on_stack();
510fbd28919c 8020151: PSR:PERF Large performance regressions when code cache is filled
anoll
parents: 12175
diff changeset
1477 OrderAccess::storestore();
510fbd28919c 8020151: PSR:PERF Large performance regressions when code cache is filled
anoll
parents: 12175
diff changeset
1478 }
510fbd28919c 8020151: PSR:PERF Large performance regressions when code cache is filled
anoll
parents: 12175
diff changeset
1479
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1480 // Change state
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1481 _state = state;
1109
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1482
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1483 // Log the transition once
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1484 log_state_change();
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1485
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1486 // Remove nmethod from method.
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1487 // We need to check if both the _code and _from_compiled_code_entry_point
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1488 // refer to this nmethod because there is a race in setting these two fields
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1489 // in Method* as seen in bugid 4947125.
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1490 // If the vep() points to the zombie nmethod, the memory for the nmethod
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1491 // could be flushed and the compiler and vtable stubs could still call
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1492 // through it.
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1493 if (method() != NULL && (method()->code() == this ||
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1494 method()->from_compiled_entry() == verified_entry_point())) {
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1495 HandleMark hm;
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1496 method()->clear_code();
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1497 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1498 } // leave critical region under Patching_lock
a61af66fc99e Initial load
duke
parents:
diff changeset
1499
1538
bfe29ec02863 6950075: nmethod sweeper should operate concurrently
never
parents: 1490
diff changeset
1500 // When the nmethod becomes zombie it is no longer alive so the
bfe29ec02863 6950075: nmethod sweeper should operate concurrently
never
parents: 1490
diff changeset
1501 // dependencies must be flushed. nmethods in the not_entrant
bfe29ec02863 6950075: nmethod sweeper should operate concurrently
never
parents: 1490
diff changeset
1502 // state will be flushed later when the transition to zombie
bfe29ec02863 6950075: nmethod sweeper should operate concurrently
never
parents: 1490
diff changeset
1503 // happens or they get unloaded.
bfe29ec02863 6950075: nmethod sweeper should operate concurrently
never
parents: 1490
diff changeset
1504 if (state == zombie) {
1726
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1505 {
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1506 // Flushing dependecies must be done before any possible
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1507 // safepoint can sneak in, otherwise the oops used by the
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1508 // dependency logic could have become stale.
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1509 MutexLockerEx mu(CodeCache_lock, Mutex::_no_safepoint_check_flag);
12080
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1510 if (nmethod_needs_unregister) {
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1511 Universe::heap()->unregister_nmethod(this);
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
1512 }
1726
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1513 flush_dependencies(NULL);
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1514 }
1644
2a47bd84841f 6965184: possible races in make_not_entrant_or_zombie
never
parents: 1616
diff changeset
1515
2342
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
1516 // zombie only - if a JVMTI agent has enabled the CompiledMethodUnload
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
1517 // event and it hasn't already been reported for this nmethod then
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
1518 // report it now. The event may have been reported earilier if the GC
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
1519 // marked it for unloading). JvmtiDeferredEventQueue support means
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
1520 // we no longer go to a safepoint here.
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
1521 post_compiled_method_unload();
1726
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1522
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1523 #ifdef ASSERT
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1524 // It's no longer safe to access the oops section since zombie
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1525 // nmethods aren't scanned for GC.
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1526 _oops_are_stale = true;
71faaa8e3ccc 6974176: ShouldNotReachHere, instanceKlass.cpp:1426
never
parents: 1692
diff changeset
1527 #endif
12161
e1fbb86b47e4 8016277: Crash in nmethod::is_compiled_by_c1() on x86
roland
parents: 12080
diff changeset
1528 // the Method may be reclaimed by class unloading now that the
e1fbb86b47e4 8016277: Crash in nmethod::is_compiled_by_c1() on x86
roland
parents: 12080
diff changeset
1529 // nmethod is in zombie state
e1fbb86b47e4 8016277: Crash in nmethod::is_compiled_by_c1() on x86
roland
parents: 12080
diff changeset
1530 set_method(NULL);
1538
bfe29ec02863 6950075: nmethod sweeper should operate concurrently
never
parents: 1490
diff changeset
1531 } else {
bfe29ec02863 6950075: nmethod sweeper should operate concurrently
never
parents: 1490
diff changeset
1532 assert(state == not_entrant, "other cases may need to be handled differently");
bfe29ec02863 6950075: nmethod sweeper should operate concurrently
never
parents: 1490
diff changeset
1533 }
bfe29ec02863 6950075: nmethod sweeper should operate concurrently
never
parents: 1490
diff changeset
1534
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1535 if (TraceCreateZombies) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1536 tty->print_cr("nmethod <" INTPTR_FORMAT "> code made %s", this, (state == not_entrant) ? "not entrant" : "zombie");
a61af66fc99e Initial load
duke
parents:
diff changeset
1537 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1538
13074
78da3894b86f 8027593: performance drop with constrained codecache starting with hs25 b111
anoll
parents: 13071
diff changeset
1539 NMethodSweeper::report_state_change(this);
1109
032260830071 5057818: codecache full and compiler disabled in bigapps fastdebug run
never
parents: 994
diff changeset
1540 return true;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1541 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1542
a61af66fc99e Initial load
duke
parents:
diff changeset
1543 void nmethod::flush() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1544 // Note that there are no valid oops in the nmethod anymore.
a61af66fc99e Initial load
duke
parents:
diff changeset
1545 assert(is_zombie() || (is_osr_method() && is_unloaded()), "must be a zombie method");
a61af66fc99e Initial load
duke
parents:
diff changeset
1546 assert(is_marked_for_reclamation() || (is_osr_method() && is_unloaded()), "must be marked for reclamation");
a61af66fc99e Initial load
duke
parents:
diff changeset
1547
a61af66fc99e Initial load
duke
parents:
diff changeset
1548 assert (!is_locked_by_vm(), "locked methods shouldn't be flushed");
1538
bfe29ec02863 6950075: nmethod sweeper should operate concurrently
never
parents: 1490
diff changeset
1549 assert_locked_or_safepoint(CodeCache_lock);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1550
a61af66fc99e Initial load
duke
parents:
diff changeset
1551 // completely deallocate this method
4872
aa3d708d67c4 7141200: log some interesting information in ring buffers for crashes
never
parents: 4006
diff changeset
1552 Events::log(JavaThread::current(), "flushing nmethod " INTPTR_FORMAT, this);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1553 if (PrintMethodFlushing) {
1202
5f24d0319e54 4360113: Evict nmethods when code cache gets full
kvn
parents: 1201
diff changeset
1554 tty->print_cr("*flushing nmethod %3d/" INTPTR_FORMAT ". Live blobs:" UINT32_FORMAT "/Free CodeCache:" SIZE_FORMAT "Kb",
5f24d0319e54 4360113: Evict nmethods when code cache gets full
kvn
parents: 1201
diff changeset
1555 _compile_id, this, CodeCache::nof_blobs(), CodeCache::unallocated_capacity()/1024);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1556 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1557
a61af66fc99e Initial load
duke
parents:
diff changeset
1558 // We need to deallocate any ExceptionCache data.
a61af66fc99e Initial load
duke
parents:
diff changeset
1559 // Note that we do not need to grab the nmethod lock for this, it
a61af66fc99e Initial load
duke
parents:
diff changeset
1560 // better be thread safe if we're disposing of it!
a61af66fc99e Initial load
duke
parents:
diff changeset
1561 ExceptionCache* ec = exception_cache();
a61af66fc99e Initial load
duke
parents:
diff changeset
1562 set_exception_cache(NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
1563 while(ec != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1564 ExceptionCache* next = ec->next();
a61af66fc99e Initial load
duke
parents:
diff changeset
1565 delete ec;
a61af66fc99e Initial load
duke
parents:
diff changeset
1566 ec = next;
a61af66fc99e Initial load
duke
parents:
diff changeset
1567 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1568
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
1569 if (on_scavenge_root_list()) {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
1570 CodeCache::drop_scavenge_root_nmethod(this);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
1571 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
1572
1692
d2ede61b7a12 6976186: integrate Shark HotSpot changes
twisti
parents: 1691
diff changeset
1573 #ifdef SHARK
1845
a222fcfba398 6990549: Zero and Shark fixes after 6978355 and 6953144
twisti
parents: 1784
diff changeset
1574 ((SharkCompiler *) compiler())->free_compiled_method(insts_begin());
1692
d2ede61b7a12 6976186: integrate Shark HotSpot changes
twisti
parents: 1691
diff changeset
1575 #endif // SHARK
d2ede61b7a12 6976186: integrate Shark HotSpot changes
twisti
parents: 1691
diff changeset
1576
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1577 ((CodeBlob*)(this))->flush();
a61af66fc99e Initial load
duke
parents:
diff changeset
1578
a61af66fc99e Initial load
duke
parents:
diff changeset
1579 CodeCache::free(this);
a61af66fc99e Initial load
duke
parents:
diff changeset
1580 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1581
a61af66fc99e Initial load
duke
parents:
diff changeset
1582
a61af66fc99e Initial load
duke
parents:
diff changeset
1583 //
a61af66fc99e Initial load
duke
parents:
diff changeset
1584 // Notify all classes this nmethod is dependent on that it is no
a61af66fc99e Initial load
duke
parents:
diff changeset
1585 // longer dependent. This should only be called in two situations.
a61af66fc99e Initial load
duke
parents:
diff changeset
1586 // First, when a nmethod transitions to a zombie all dependents need
a61af66fc99e Initial load
duke
parents:
diff changeset
1587 // to be clear. Since zombification happens at a safepoint there's no
a61af66fc99e Initial load
duke
parents:
diff changeset
1588 // synchronization issues. The second place is a little more tricky.
a61af66fc99e Initial load
duke
parents:
diff changeset
1589 // During phase 1 of mark sweep class unloading may happen and as a
a61af66fc99e Initial load
duke
parents:
diff changeset
1590 // result some nmethods may get unloaded. In this case the flushing
a61af66fc99e Initial load
duke
parents:
diff changeset
1591 // of dependencies must happen during phase 1 since after GC any
a61af66fc99e Initial load
duke
parents:
diff changeset
1592 // dependencies in the unloaded nmethod won't be updated, so
a61af66fc99e Initial load
duke
parents:
diff changeset
1593 // traversing the dependency information in unsafe. In that case this
a61af66fc99e Initial load
duke
parents:
diff changeset
1594 // function is called with a non-NULL argument and this function only
a61af66fc99e Initial load
duke
parents:
diff changeset
1595 // notifies instanceKlasses that are reachable
a61af66fc99e Initial load
duke
parents:
diff changeset
1596
a61af66fc99e Initial load
duke
parents:
diff changeset
1597 void nmethod::flush_dependencies(BoolObjectClosure* is_alive) {
1538
bfe29ec02863 6950075: nmethod sweeper should operate concurrently
never
parents: 1490
diff changeset
1598 assert_locked_or_safepoint(CodeCache_lock);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1599 assert(Universe::heap()->is_gc_active() == (is_alive != NULL),
a61af66fc99e Initial load
duke
parents:
diff changeset
1600 "is_alive is non-NULL if and only if we are called during GC");
a61af66fc99e Initial load
duke
parents:
diff changeset
1601 if (!has_flushed_dependencies()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1602 set_has_flushed_dependencies();
a61af66fc99e Initial load
duke
parents:
diff changeset
1603 for (Dependencies::DepStream deps(this); deps.next(); ) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1604 Klass* klass = deps.context_type();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1605 if (klass == NULL) continue; // ignore things like evol_method
a61af66fc99e Initial load
duke
parents:
diff changeset
1606
a61af66fc99e Initial load
duke
parents:
diff changeset
1607 // During GC the is_alive closure is non-NULL, and is used to
a61af66fc99e Initial load
duke
parents:
diff changeset
1608 // determine liveness of dependees that need to be updated.
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1609 if (is_alive == NULL || klass->is_loader_alive(is_alive)) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1610 InstanceKlass::cast(klass)->remove_dependent_nmethod(this);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1611 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1612 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1613 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1614 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1615
a61af66fc99e Initial load
duke
parents:
diff changeset
1616
a61af66fc99e Initial load
duke
parents:
diff changeset
1617 // If this oop is not live, the nmethod can be unloaded.
6787
8966c2d65d96 7200470: KeepAliveClosure not needed in CodeCache::do_unloading
brutisso
parents: 6725
diff changeset
1618 bool nmethod::can_unload(BoolObjectClosure* is_alive, oop* root, bool unloading_occurred) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1619 assert(root != NULL, "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
1620 oop obj = *root;
a61af66fc99e Initial load
duke
parents:
diff changeset
1621 if (obj == NULL || is_alive->do_object_b(obj)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1622 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
1623 }
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1624
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
1625 // If ScavengeRootsInCode is true, an nmethod might be unloaded
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
1626 // simply because one of its constant oops has gone dead.
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
1627 // No actual classes need to be unloaded in order for this to occur.
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
1628 assert(unloading_occurred || ScavengeRootsInCode, "Inconsistency in unloading");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1629 make_unloaded(is_alive, obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
1630 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
1631 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1632
a61af66fc99e Initial load
duke
parents:
diff changeset
1633 // ------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
1634 // post_compiled_method_load_event
a61af66fc99e Initial load
duke
parents:
diff changeset
1635 // new method for install_code() path
a61af66fc99e Initial load
duke
parents:
diff changeset
1636 // Transfer information from compilation to jvmti
a61af66fc99e Initial load
duke
parents:
diff changeset
1637 void nmethod::post_compiled_method_load_event() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1638
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1639 Method* moop = method();
4006
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
1640 #ifndef USDT2
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1641 HS_DTRACE_PROBE8(hotspot, compiled__method__load,
a61af66fc99e Initial load
duke
parents:
diff changeset
1642 moop->klass_name()->bytes(),
a61af66fc99e Initial load
duke
parents:
diff changeset
1643 moop->klass_name()->utf8_length(),
a61af66fc99e Initial load
duke
parents:
diff changeset
1644 moop->name()->bytes(),
a61af66fc99e Initial load
duke
parents:
diff changeset
1645 moop->name()->utf8_length(),
a61af66fc99e Initial load
duke
parents:
diff changeset
1646 moop->signature()->bytes(),
a61af66fc99e Initial load
duke
parents:
diff changeset
1647 moop->signature()->utf8_length(),
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
1648 insts_begin(), insts_size());
4006
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
1649 #else /* USDT2 */
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
1650 HOTSPOT_COMPILED_METHOD_LOAD(
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
1651 (char *) moop->klass_name()->bytes(),
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
1652 moop->klass_name()->utf8_length(),
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
1653 (char *) moop->name()->bytes(),
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
1654 moop->name()->utf8_length(),
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
1655 (char *) moop->signature()->bytes(),
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
1656 moop->signature()->utf8_length(),
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
1657 insts_begin(), insts_size());
436b4a3231bf 7098194: integrate macosx-port changes
dcubed
parents: 3899
diff changeset
1658 #endif /* USDT2 */
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1659
1616
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1660 if (JvmtiExport::should_post_compiled_method_load() ||
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1661 JvmtiExport::should_post_compiled_method_unload()) {
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1662 get_and_cache_jmethod_id();
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1663 }
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1664
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1665 if (JvmtiExport::should_post_compiled_method_load()) {
2195
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1666 // Let the Service thread (which is a real Java thread) post the event
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1667 MutexLockerEx ml(Service_lock, Mutex::_no_safepoint_check_flag);
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1668 JvmtiDeferredEventQueue::enqueue(
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1669 JvmtiDeferredEvent::compiled_method_load_event(this));
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1670 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1671 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1672
1616
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1673 jmethodID nmethod::get_and_cache_jmethod_id() {
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1674 if (_jmethod_id == NULL) {
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1675 // Cache the jmethod_id since it can no longer be looked up once the
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1676 // method itself has been marked for unloading.
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1677 _jmethod_id = method()->jmethod_id();
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1678 }
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1679 return _jmethod_id;
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1680 }
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1681
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1682 void nmethod::post_compiled_method_unload() {
1577
852d0157c696 6956931: assert(SafepointSynchronize::is_at_safepoint()) failed: must be executed at a safepoint
never
parents: 1563
diff changeset
1683 if (unload_reported()) {
852d0157c696 6956931: assert(SafepointSynchronize::is_at_safepoint()) failed: must be executed at a safepoint
never
parents: 1563
diff changeset
1684 // During unloading we transition to unloaded and then to zombie
852d0157c696 6956931: assert(SafepointSynchronize::is_at_safepoint()) failed: must be executed at a safepoint
never
parents: 1563
diff changeset
1685 // and the unloading is reported during the first transition.
852d0157c696 6956931: assert(SafepointSynchronize::is_at_safepoint()) failed: must be executed at a safepoint
never
parents: 1563
diff changeset
1686 return;
852d0157c696 6956931: assert(SafepointSynchronize::is_at_safepoint()) failed: must be executed at a safepoint
never
parents: 1563
diff changeset
1687 }
852d0157c696 6956931: assert(SafepointSynchronize::is_at_safepoint()) failed: must be executed at a safepoint
never
parents: 1563
diff changeset
1688
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1689 assert(_method != NULL && !is_unloaded(), "just checking");
a61af66fc99e Initial load
duke
parents:
diff changeset
1690 DTRACE_METHOD_UNLOAD_PROBE(method());
a61af66fc99e Initial load
duke
parents:
diff changeset
1691
a61af66fc99e Initial load
duke
parents:
diff changeset
1692 // If a JVMTI agent has enabled the CompiledMethodUnload event then
1616
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1693 // post the event. Sometime later this nmethod will be made a zombie
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1694 // by the sweeper but the Method* will not be valid at that point.
1616
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1695 // If the _jmethod_id is null then no load event was ever requested
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1696 // so don't bother posting the unload. The main reason for this is
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1697 // that the jmethodID is a weak reference to the Method* so if
1616
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1698 // it's being unloaded there's no way to look it up since the weak
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1699 // ref will have been cleared.
38e8278318ca 6656830: assert((*p)->is_oop(),"expected an oop while scanning weak refs")
never
parents: 1602
diff changeset
1700 if (_jmethod_id != NULL && JvmtiExport::should_post_compiled_method_unload()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1701 assert(!unload_reported(), "already unloaded");
2195
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1702 JvmtiDeferredEvent event =
2342
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
1703 JvmtiDeferredEvent::compiled_method_unload_event(this,
2195
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1704 _jmethod_id, insts_begin());
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1705 if (SafepointSynchronize::is_at_safepoint()) {
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1706 // Don't want to take the queueing lock. Add it as pending and
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1707 // it will get enqueued later.
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1708 JvmtiDeferredEventQueue::add_pending_event(event);
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1709 } else {
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1710 MutexLockerEx ml(Service_lock, Mutex::_no_safepoint_check_flag);
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1711 JvmtiDeferredEventQueue::enqueue(event);
bf8517f4e4d0 6766644: Redefinition of compiled method fails with assertion "Can not load classes with the Compiler thread"
kamg
parents: 2177
diff changeset
1712 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1713 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1714
a61af66fc99e Initial load
duke
parents:
diff changeset
1715 // The JVMTI CompiledMethodUnload event can be enabled or disabled at
a61af66fc99e Initial load
duke
parents:
diff changeset
1716 // any time. As the nmethod is being unloaded now we mark it has
a61af66fc99e Initial load
duke
parents:
diff changeset
1717 // having the unload event reported - this will ensure that we don't
a61af66fc99e Initial load
duke
parents:
diff changeset
1718 // attempt to report the event in the unlikely scenario where the
a61af66fc99e Initial load
duke
parents:
diff changeset
1719 // event is enabled at the time the nmethod is made a zombie.
a61af66fc99e Initial load
duke
parents:
diff changeset
1720 set_unload_reported();
a61af66fc99e Initial load
duke
parents:
diff changeset
1721 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1722
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1723 void static clean_ic_if_metadata_is_dead(CompiledIC *ic, BoolObjectClosure *is_alive) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1724 if (ic->is_icholder_call()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1725 // The only exception is compiledICHolder oops which may
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1726 // yet be marked below. (We check this further below).
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1727 CompiledICHolder* cichk_oop = ic->cached_icholder();
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1728 if (cichk_oop->holder_method()->method_holder()->is_loader_alive(is_alive) &&
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1729 cichk_oop->holder_klass()->is_loader_alive(is_alive)) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1730 return;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1731 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1732 } else {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1733 Metadata* ic_oop = ic->cached_metadata();
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1734 if (ic_oop != NULL) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1735 if (ic_oop->is_klass()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1736 if (((Klass*)ic_oop)->is_loader_alive(is_alive)) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1737 return;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1738 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1739 } else if (ic_oop->is_method()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1740 if (((Method*)ic_oop)->method_holder()->is_loader_alive(is_alive)) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1741 return;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1742 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1743 } else {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1744 ShouldNotReachHere();
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1745 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1746 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1747 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1748
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1749 ic->set_to_clean();
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1750 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1751
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1752 // This is called at the end of the strong tracing/marking phase of a
a61af66fc99e Initial load
duke
parents:
diff changeset
1753 // GC to unload an nmethod if it contains otherwise unreachable
a61af66fc99e Initial load
duke
parents:
diff changeset
1754 // oops.
a61af66fc99e Initial load
duke
parents:
diff changeset
1755
6787
8966c2d65d96 7200470: KeepAliveClosure not needed in CodeCache::do_unloading
brutisso
parents: 6725
diff changeset
1756 void nmethod::do_unloading(BoolObjectClosure* is_alive, bool unloading_occurred) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1757 // Make sure the oop's ready to receive visitors
a61af66fc99e Initial load
duke
parents:
diff changeset
1758 assert(!is_zombie() && !is_unloaded(),
a61af66fc99e Initial load
duke
parents:
diff changeset
1759 "should not call follow on zombie or unloaded nmethod");
a61af66fc99e Initial load
duke
parents:
diff changeset
1760
a61af66fc99e Initial load
duke
parents:
diff changeset
1761 // If the method is not entrant then a JMP is plastered over the
a61af66fc99e Initial load
duke
parents:
diff changeset
1762 // first few bytes. If an oop in the old code was there, that oop
a61af66fc99e Initial load
duke
parents:
diff changeset
1763 // should not get GC'd. Skip the first few bytes of oops on
a61af66fc99e Initial load
duke
parents:
diff changeset
1764 // not-entrant methods.
a61af66fc99e Initial load
duke
parents:
diff changeset
1765 address low_boundary = verified_entry_point();
a61af66fc99e Initial load
duke
parents:
diff changeset
1766 if (is_not_entrant()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1767 low_boundary += NativeJump::instruction_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
1768 // %%% Note: On SPARC we patch only a 4-byte trap, not a full NativeJump.
a61af66fc99e Initial load
duke
parents:
diff changeset
1769 // (See comment above.)
a61af66fc99e Initial load
duke
parents:
diff changeset
1770 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1771
a61af66fc99e Initial load
duke
parents:
diff changeset
1772 // The RedefineClasses() API can cause the class unloading invariant
a61af66fc99e Initial load
duke
parents:
diff changeset
1773 // to no longer be true. See jvmtiExport.hpp for details.
a61af66fc99e Initial load
duke
parents:
diff changeset
1774 // Also, leave a debugging breadcrumb in local flag.
a61af66fc99e Initial load
duke
parents:
diff changeset
1775 bool a_class_was_redefined = JvmtiExport::has_redefined_a_class();
a61af66fc99e Initial load
duke
parents:
diff changeset
1776 if (a_class_was_redefined) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1777 // This set of the unloading_occurred flag is done before the
a61af66fc99e Initial load
duke
parents:
diff changeset
1778 // call to post_compiled_method_unload() so that the unloading
a61af66fc99e Initial load
duke
parents:
diff changeset
1779 // of this nmethod is reported.
a61af66fc99e Initial load
duke
parents:
diff changeset
1780 unloading_occurred = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
1781 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1782
a61af66fc99e Initial load
duke
parents:
diff changeset
1783 // Exception cache
20269
9717199cb8de 8047373: Clean the ExceptionCache in one pass
stefank
parents: 20197
diff changeset
1784 clean_exception_cache(is_alive);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1785
a61af66fc99e Initial load
duke
parents:
diff changeset
1786 // If class unloading occurred we first iterate over all inline caches and
a61af66fc99e Initial load
duke
parents:
diff changeset
1787 // clear ICs where the cached oop is referring to an unloaded klass or method.
a61af66fc99e Initial load
duke
parents:
diff changeset
1788 // The remaining live cached oops will be traversed in the relocInfo::oop_type
a61af66fc99e Initial load
duke
parents:
diff changeset
1789 // iteration below.
a61af66fc99e Initial load
duke
parents:
diff changeset
1790 if (unloading_occurred) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1791 RelocIterator iter(this, low_boundary);
a61af66fc99e Initial load
duke
parents:
diff changeset
1792 while(iter.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1793 if (iter.type() == relocInfo::virtual_call_type) {
20277
882004b9e7e1 8047362: Add a version of CompiledIC_at that doesn't create a new RelocIterator
stefank
parents: 20269
diff changeset
1794 CompiledIC *ic = CompiledIC_at(&iter);
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1795 clean_ic_if_metadata_is_dead(ic, is_alive);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1796 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1797 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1798 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1799
a61af66fc99e Initial load
duke
parents:
diff changeset
1800 // Compiled code
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1801 {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1802 RelocIterator iter(this, low_boundary);
a61af66fc99e Initial load
duke
parents:
diff changeset
1803 while (iter.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1804 if (iter.type() == relocInfo::oop_type) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1805 oop_Relocation* r = iter.oop_reloc();
a61af66fc99e Initial load
duke
parents:
diff changeset
1806 // In this loop, we must only traverse those oops directly embedded in
a61af66fc99e Initial load
duke
parents:
diff changeset
1807 // the code. Other oops (oop_index>0) are seen as part of scopes_oops.
a61af66fc99e Initial load
duke
parents:
diff changeset
1808 assert(1 == (r->oop_is_immediate()) +
a61af66fc99e Initial load
duke
parents:
diff changeset
1809 (r->oop_addr() >= oops_begin() && r->oop_addr() < oops_end()),
a61af66fc99e Initial load
duke
parents:
diff changeset
1810 "oop must be found in exactly one place");
a61af66fc99e Initial load
duke
parents:
diff changeset
1811 if (r->oop_is_immediate() && r->oop_value() != NULL) {
6787
8966c2d65d96 7200470: KeepAliveClosure not needed in CodeCache::do_unloading
brutisso
parents: 6725
diff changeset
1812 if (can_unload(is_alive, r->oop_addr(), unloading_occurred)) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1813 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
1814 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1815 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1816 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1817 }
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1818 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1819
a61af66fc99e Initial load
duke
parents:
diff changeset
1820
a61af66fc99e Initial load
duke
parents:
diff changeset
1821 // Scopes
a61af66fc99e Initial load
duke
parents:
diff changeset
1822 for (oop* p = oops_begin(); p < oops_end(); p++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1823 if (*p == Universe::non_oop_word()) continue; // skip non-oops
6787
8966c2d65d96 7200470: KeepAliveClosure not needed in CodeCache::do_unloading
brutisso
parents: 6725
diff changeset
1824 if (can_unload(is_alive, p, unloading_occurred)) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1825 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
1826 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1827 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1828
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1829 // Ensure that all metadata is still alive
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1830 verify_metadata_loaders(low_boundary, is_alive);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1831 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
1832
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1833 template <class CompiledICorStaticCall>
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1834 static bool clean_if_nmethod_is_unloaded(CompiledICorStaticCall *ic, address addr, BoolObjectClosure *is_alive, nmethod* from) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1835 // Ok, to lookup references to zombies here
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1836 CodeBlob *cb = CodeCache::find_blob_unsafe(addr);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1837 if (cb != NULL && cb->is_nmethod()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1838 nmethod* nm = (nmethod*)cb;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1839
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1840 if (nm->unloading_clock() != nmethod::global_unloading_clock()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1841 // The nmethod has not been processed yet.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1842 return true;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1843 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1844
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1845 // Clean inline caches pointing to both zombie and not_entrant methods
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1846 if (!nm->is_in_use() || (nm->method()->code() != nm)) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1847 ic->set_to_clean();
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1848 assert(ic->is_clean(), err_msg("nmethod " PTR_FORMAT "not clean %s", from, from->method()->name_and_sig_as_C_string()));
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1849 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1850 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1851
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1852 return false;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1853 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1854
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1855 static bool clean_if_nmethod_is_unloaded(CompiledIC *ic, BoolObjectClosure *is_alive, nmethod* from) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1856 return clean_if_nmethod_is_unloaded(ic, ic->ic_destination(), is_alive, from);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1857 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1858
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1859 static bool clean_if_nmethod_is_unloaded(CompiledStaticCall *csc, BoolObjectClosure *is_alive, nmethod* from) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1860 return clean_if_nmethod_is_unloaded(csc, csc->destination(), is_alive, from);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1861 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1862
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1863 bool nmethod::do_unloading_parallel(BoolObjectClosure* is_alive, bool unloading_occurred) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1864 ResourceMark rm;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1865
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1866 // Make sure the oop's ready to receive visitors
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1867 assert(!is_zombie() && !is_unloaded(),
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1868 "should not call follow on zombie or unloaded nmethod");
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1869
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1870 // If the method is not entrant then a JMP is plastered over the
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1871 // first few bytes. If an oop in the old code was there, that oop
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1872 // should not get GC'd. Skip the first few bytes of oops on
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1873 // not-entrant methods.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1874 address low_boundary = verified_entry_point();
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1875 if (is_not_entrant()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1876 low_boundary += NativeJump::instruction_size;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1877 // %%% Note: On SPARC we patch only a 4-byte trap, not a full NativeJump.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1878 // (See comment above.)
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1879 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1880
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1881 // The RedefineClasses() API can cause the class unloading invariant
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1882 // to no longer be true. See jvmtiExport.hpp for details.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1883 // Also, leave a debugging breadcrumb in local flag.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1884 bool a_class_was_redefined = JvmtiExport::has_redefined_a_class();
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1885 if (a_class_was_redefined) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1886 // This set of the unloading_occurred flag is done before the
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1887 // call to post_compiled_method_unload() so that the unloading
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1888 // of this nmethod is reported.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1889 unloading_occurred = true;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1890 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1891
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1892 // Exception cache
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1893 clean_exception_cache(is_alive);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1894
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1895 bool is_unloaded = false;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1896 bool postponed = false;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1897
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1898 RelocIterator iter(this, low_boundary);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1899 while(iter.next()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1900
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1901 switch (iter.type()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1902
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1903 case relocInfo::virtual_call_type:
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1904 if (unloading_occurred) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1905 // If class unloading occurred we first iterate over all inline caches and
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1906 // clear ICs where the cached oop is referring to an unloaded klass or method.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1907 clean_ic_if_metadata_is_dead(CompiledIC_at(&iter), is_alive);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1908 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1909
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1910 postponed |= clean_if_nmethod_is_unloaded(CompiledIC_at(&iter), is_alive, this);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1911 break;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1912
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1913 case relocInfo::opt_virtual_call_type:
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1914 postponed |= clean_if_nmethod_is_unloaded(CompiledIC_at(&iter), is_alive, this);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1915 break;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1916
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1917 case relocInfo::static_call_type:
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1918 postponed |= clean_if_nmethod_is_unloaded(compiledStaticCall_at(iter.reloc()), is_alive, this);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1919 break;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1920
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1921 case relocInfo::oop_type:
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1922 if (!is_unloaded) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1923 // Unload check
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1924 oop_Relocation* r = iter.oop_reloc();
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1925 // Traverse those oops directly embedded in the code.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1926 // Other oops (oop_index>0) are seen as part of scopes_oops.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1927 assert(1 == (r->oop_is_immediate()) +
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1928 (r->oop_addr() >= oops_begin() && r->oop_addr() < oops_end()),
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1929 "oop must be found in exactly one place");
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1930 if (r->oop_is_immediate() && r->oop_value() != NULL) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1931 if (can_unload(is_alive, r->oop_addr(), unloading_occurred)) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1932 is_unloaded = true;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1933 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1934 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1935 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1936 break;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1937
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1938 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1939 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1940
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1941 if (is_unloaded) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1942 return postponed;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1943 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1944
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1945 // Scopes
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1946 for (oop* p = oops_begin(); p < oops_end(); p++) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1947 if (*p == Universe::non_oop_word()) continue; // skip non-oops
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1948 if (can_unload(is_alive, p, unloading_occurred)) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1949 is_unloaded = true;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1950 break;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1951 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1952 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1953
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1954 if (is_unloaded) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1955 return postponed;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1956 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1957
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1958 // Ensure that all metadata is still alive
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1959 verify_metadata_loaders(low_boundary, is_alive);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1960
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1961 return postponed;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1962 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1963
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1964 void nmethod::do_unloading_parallel_postponed(BoolObjectClosure* is_alive, bool unloading_occurred) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1965 ResourceMark rm;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1966
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1967 // Make sure the oop's ready to receive visitors
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1968 assert(!is_zombie(),
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1969 "should not call follow on zombie nmethod");
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1970
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1971 // If the method is not entrant then a JMP is plastered over the
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1972 // first few bytes. If an oop in the old code was there, that oop
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1973 // should not get GC'd. Skip the first few bytes of oops on
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1974 // not-entrant methods.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1975 address low_boundary = verified_entry_point();
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1976 if (is_not_entrant()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1977 low_boundary += NativeJump::instruction_size;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1978 // %%% Note: On SPARC we patch only a 4-byte trap, not a full NativeJump.
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1979 // (See comment above.)
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1980 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1981
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1982 RelocIterator iter(this, low_boundary);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1983 while(iter.next()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1984
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1985 switch (iter.type()) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1986
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1987 case relocInfo::virtual_call_type:
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1988 clean_if_nmethod_is_unloaded(CompiledIC_at(&iter), is_alive, this);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1989 break;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1990
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1991 case relocInfo::opt_virtual_call_type:
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1992 clean_if_nmethod_is_unloaded(CompiledIC_at(&iter), is_alive, this);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1993 break;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1994
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1995 case relocInfo::static_call_type:
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1996 clean_if_nmethod_is_unloaded(compiledStaticCall_at(iter.reloc()), is_alive, this);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1997 break;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1998 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
1999 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
2000 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
2001
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2002 #ifdef ASSERT
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2003
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2004 class CheckClass : AllStatic {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2005 static BoolObjectClosure* _is_alive;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2006
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2007 // Check class_loader is alive for this bit of metadata.
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2008 static void check_class(Metadata* md) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2009 Klass* klass = NULL;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2010 if (md->is_klass()) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2011 klass = ((Klass*)md);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2012 } else if (md->is_method()) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2013 klass = ((Method*)md)->method_holder();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2014 } else if (md->is_methodData()) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2015 klass = ((MethodData*)md)->method()->method_holder();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2016 } else {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2017 md->print();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2018 ShouldNotReachHere();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2019 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2020 assert(klass->is_loader_alive(_is_alive), "must be alive");
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2021 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2022 public:
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2023 static void do_check_class(BoolObjectClosure* is_alive, nmethod* nm) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2024 assert(SafepointSynchronize::is_at_safepoint(), "this is only ok at safepoint");
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2025 _is_alive = is_alive;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2026 nm->metadata_do(check_class);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2027 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2028 };
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2029
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2030 // This is called during a safepoint so can use static data
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2031 BoolObjectClosure* CheckClass::_is_alive = NULL;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2032 #endif // ASSERT
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2033
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2034
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2035 // Processing of oop references should have been sufficient to keep
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2036 // all strong references alive. Any weak references should have been
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2037 // cleared as well. Visit all the metadata and ensure that it's
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2038 // really alive.
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2039 void nmethod::verify_metadata_loaders(address low_boundary, BoolObjectClosure* is_alive) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2040 #ifdef ASSERT
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2041 RelocIterator iter(this, low_boundary);
a61af66fc99e Initial load
duke
parents:
diff changeset
2042 while (iter.next()) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2043 // static_stub_Relocations may have dangling references to
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2044 // Method*s so trim them out here. Otherwise it looks like
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2045 // compiled code is maintaining a link to dead metadata.
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2046 address static_call_addr = NULL;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2047 if (iter.type() == relocInfo::opt_virtual_call_type) {
20277
882004b9e7e1 8047362: Add a version of CompiledIC_at that doesn't create a new RelocIterator
stefank
parents: 20269
diff changeset
2048 CompiledIC* cic = CompiledIC_at(&iter);
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2049 if (!cic->is_call_to_interpreted()) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2050 static_call_addr = iter.addr();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2051 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2052 } else if (iter.type() == relocInfo::static_call_type) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2053 CompiledStaticCall* csc = compiledStaticCall_at(iter.reloc());
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2054 if (!csc->is_call_to_interpreted()) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2055 static_call_addr = iter.addr();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2056 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2057 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2058 if (static_call_addr != NULL) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2059 RelocIterator sciter(this, low_boundary);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2060 while (sciter.next()) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2061 if (sciter.type() == relocInfo::static_stub_type &&
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2062 sciter.static_stub_reloc()->static_call() == static_call_addr) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2063 sciter.static_stub_reloc()->clear_inline_cache();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2064 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2065 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2066 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2067 }
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2068 // Check that the metadata embedded in the nmethod is alive
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2069 CheckClass::do_check_class(is_alive, this);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2070 #endif
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2071 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2072
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2073
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2074 // Iterate over metadata calling this function. Used by RedefineClasses
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2075 void nmethod::metadata_do(void f(Metadata*)) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2076 address low_boundary = verified_entry_point();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2077 if (is_not_entrant()) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2078 low_boundary += NativeJump::instruction_size;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2079 // %%% Note: On SPARC we patch only a 4-byte trap, not a full NativeJump.
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2080 // (See comment above.)
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2081 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2082 {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2083 // Visit all immediate references that are embedded in the instruction stream.
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2084 RelocIterator iter(this, low_boundary);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2085 while (iter.next()) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2086 if (iter.type() == relocInfo::metadata_type ) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2087 metadata_Relocation* r = iter.metadata_reloc();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2088 // In this lmetadata, we must only follow those metadatas directly embedded in
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2089 // the code. Other metadatas (oop_index>0) are seen as part of
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2090 // the metadata section below.
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2091 assert(1 == (r->metadata_is_immediate()) +
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2092 (r->metadata_addr() >= metadata_begin() && r->metadata_addr() < metadata_end()),
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2093 "metadata must be found in exactly one place");
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2094 if (r->metadata_is_immediate() && r->metadata_value() != NULL) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2095 Metadata* md = r->metadata_value();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2096 f(md);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2097 }
10253
4674e409a9e6 8014024: NPG: keep compiled ic methods from being deallocated in redefine classes
coleenp
parents: 10114
diff changeset
2098 } else if (iter.type() == relocInfo::virtual_call_type) {
4674e409a9e6 8014024: NPG: keep compiled ic methods from being deallocated in redefine classes
coleenp
parents: 10114
diff changeset
2099 // Check compiledIC holders associated with this nmethod
20277
882004b9e7e1 8047362: Add a version of CompiledIC_at that doesn't create a new RelocIterator
stefank
parents: 20269
diff changeset
2100 CompiledIC *ic = CompiledIC_at(&iter);
10253
4674e409a9e6 8014024: NPG: keep compiled ic methods from being deallocated in redefine classes
coleenp
parents: 10114
diff changeset
2101 if (ic->is_icholder_call()) {
4674e409a9e6 8014024: NPG: keep compiled ic methods from being deallocated in redefine classes
coleenp
parents: 10114
diff changeset
2102 CompiledICHolder* cichk = ic->cached_icholder();
4674e409a9e6 8014024: NPG: keep compiled ic methods from being deallocated in redefine classes
coleenp
parents: 10114
diff changeset
2103 f(cichk->holder_method());
4674e409a9e6 8014024: NPG: keep compiled ic methods from being deallocated in redefine classes
coleenp
parents: 10114
diff changeset
2104 f(cichk->holder_klass());
4674e409a9e6 8014024: NPG: keep compiled ic methods from being deallocated in redefine classes
coleenp
parents: 10114
diff changeset
2105 } else {
4674e409a9e6 8014024: NPG: keep compiled ic methods from being deallocated in redefine classes
coleenp
parents: 10114
diff changeset
2106 Metadata* ic_oop = ic->cached_metadata();
4674e409a9e6 8014024: NPG: keep compiled ic methods from being deallocated in redefine classes
coleenp
parents: 10114
diff changeset
2107 if (ic_oop != NULL) {
4674e409a9e6 8014024: NPG: keep compiled ic methods from being deallocated in redefine classes
coleenp
parents: 10114
diff changeset
2108 f(ic_oop);
4674e409a9e6 8014024: NPG: keep compiled ic methods from being deallocated in redefine classes
coleenp
parents: 10114
diff changeset
2109 }
4674e409a9e6 8014024: NPG: keep compiled ic methods from being deallocated in redefine classes
coleenp
parents: 10114
diff changeset
2110 }
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2111 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2112 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2113 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2114
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2115 // Visit the metadata section
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2116 for (Metadata** p = metadata_begin(); p < metadata_end(); p++) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2117 if (*p == Universe::non_oop_word() || *p == NULL) continue; // skip non-oops
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2118 Metadata* md = *p;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2119 f(md);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2120 }
10253
4674e409a9e6 8014024: NPG: keep compiled ic methods from being deallocated in redefine classes
coleenp
parents: 10114
diff changeset
2121
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2122 // Call function Method*, not embedded in these other places.
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2123 if (_method != NULL) f(_method);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2124 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2125
12080
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
2126 void nmethod::oops_do(OopClosure* f, bool allow_zombie) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2127 // make sure the oops ready to receive visitors
12080
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
2128 assert(allow_zombie || !is_zombie(), "should not call follow on zombie nmethod");
5888334c9c24 7145569: G1: optimize nmethods scanning
johnc
parents: 11041
diff changeset
2129 assert(!is_unloaded(), "should not call follow on unloaded nmethod");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2130
a61af66fc99e Initial load
duke
parents:
diff changeset
2131 // If the method is not entrant or zombie then a JMP is plastered over the
a61af66fc99e Initial load
duke
parents:
diff changeset
2132 // first few bytes. If an oop in the old code was there, that oop
a61af66fc99e Initial load
duke
parents:
diff changeset
2133 // should not get GC'd. Skip the first few bytes of oops on
a61af66fc99e Initial load
duke
parents:
diff changeset
2134 // not-entrant methods.
a61af66fc99e Initial load
duke
parents:
diff changeset
2135 address low_boundary = verified_entry_point();
a61af66fc99e Initial load
duke
parents:
diff changeset
2136 if (is_not_entrant()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2137 low_boundary += NativeJump::instruction_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
2138 // %%% Note: On SPARC we patch only a 4-byte trap, not a full NativeJump.
a61af66fc99e Initial load
duke
parents:
diff changeset
2139 // (See comment above.)
a61af66fc99e Initial load
duke
parents:
diff changeset
2140 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2141
a61af66fc99e Initial load
duke
parents:
diff changeset
2142 RelocIterator iter(this, low_boundary);
941
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 605
diff changeset
2143
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2144 while (iter.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2145 if (iter.type() == relocInfo::oop_type ) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2146 oop_Relocation* r = iter.oop_reloc();
a61af66fc99e Initial load
duke
parents:
diff changeset
2147 // In this loop, we must only follow those oops directly embedded in
a61af66fc99e Initial load
duke
parents:
diff changeset
2148 // the code. Other oops (oop_index>0) are seen as part of scopes_oops.
941
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 605
diff changeset
2149 assert(1 == (r->oop_is_immediate()) +
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 605
diff changeset
2150 (r->oop_addr() >= oops_begin() && r->oop_addr() < oops_end()),
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 605
diff changeset
2151 "oop must be found in exactly one place");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2152 if (r->oop_is_immediate() && r->oop_value() != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2153 f->do_oop(r->oop_addr());
a61af66fc99e Initial load
duke
parents:
diff changeset
2154 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2155 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2156 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2157
a61af66fc99e Initial load
duke
parents:
diff changeset
2158 // Scopes
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2159 // This includes oop constants not inlined in the code stream.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2160 for (oop* p = oops_begin(); p < oops_end(); p++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2161 if (*p == Universe::non_oop_word()) continue; // skip non-oops
a61af66fc99e Initial load
duke
parents:
diff changeset
2162 f->do_oop(p);
a61af66fc99e Initial load
duke
parents:
diff changeset
2163 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2164 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2165
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2166 #define NMETHOD_SENTINEL ((nmethod*)badAddress)
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2167
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2168 nmethod* volatile nmethod::_oops_do_mark_nmethods;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2169
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2170 // An nmethod is "marked" if its _mark_link is set non-null.
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2171 // Even if it is the end of the linked list, it will have a non-null link value,
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2172 // as long as it is on the list.
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2173 // This code must be MP safe, because it is used from parallel GC passes.
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2174 bool nmethod::test_set_oops_do_mark() {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2175 assert(nmethod::oops_do_marking_is_active(), "oops_do_marking_prologue must be called");
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2176 nmethod* observed_mark_link = _oops_do_mark_link;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2177 if (observed_mark_link == NULL) {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2178 // Claim this nmethod for this thread to mark.
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2179 observed_mark_link = (nmethod*)
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2180 Atomic::cmpxchg_ptr(NMETHOD_SENTINEL, &_oops_do_mark_link, NULL);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2181 if (observed_mark_link == NULL) {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2182
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2183 // Atomically append this nmethod (now claimed) to the head of the list:
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2184 nmethod* observed_mark_nmethods = _oops_do_mark_nmethods;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2185 for (;;) {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2186 nmethod* required_mark_nmethods = observed_mark_nmethods;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2187 _oops_do_mark_link = required_mark_nmethods;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2188 observed_mark_nmethods = (nmethod*)
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2189 Atomic::cmpxchg_ptr(this, &_oops_do_mark_nmethods, required_mark_nmethods);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2190 if (observed_mark_nmethods == required_mark_nmethods)
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2191 break;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2192 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2193 // Mark was clear when we first saw this guy.
2405
3d58a4983660 7022998: JSR 292 recursive method handle calls inline themselves infinitely
twisti
parents: 2376
diff changeset
2194 NOT_PRODUCT(if (TraceScavenge) print_on(tty, "oops_do, mark"));
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2195 return false;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2196 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2197 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2198 // On fall through, another racing thread marked this nmethod before we did.
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2199 return true;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2200 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2201
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2202 void nmethod::oops_do_marking_prologue() {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2203 NOT_PRODUCT(if (TraceScavenge) tty->print_cr("[oops_do_marking_prologue"));
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2204 assert(_oops_do_mark_nmethods == NULL, "must not call oops_do_marking_prologue twice in a row");
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2205 // We use cmpxchg_ptr instead of regular assignment here because the user
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2206 // may fork a bunch of threads, and we need them all to see the same state.
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2207 void* observed = Atomic::cmpxchg_ptr(NMETHOD_SENTINEL, &_oops_do_mark_nmethods, NULL);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2208 guarantee(observed == NULL, "no races in this sequential code");
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2209 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2210
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2211 void nmethod::oops_do_marking_epilogue() {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2212 assert(_oops_do_mark_nmethods != NULL, "must not call oops_do_marking_epilogue twice in a row");
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2213 nmethod* cur = _oops_do_mark_nmethods;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2214 while (cur != NMETHOD_SENTINEL) {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2215 assert(cur != NULL, "not NULL-terminated");
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2216 nmethod* next = cur->_oops_do_mark_link;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2217 cur->_oops_do_mark_link = NULL;
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
2218 cur->verify_oop_relocations();
2405
3d58a4983660 7022998: JSR 292 recursive method handle calls inline themselves infinitely
twisti
parents: 2376
diff changeset
2219 NOT_PRODUCT(if (TraceScavenge) cur->print_on(tty, "oops_do, unmark"));
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2220 cur = next;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2221 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2222 void* required = _oops_do_mark_nmethods;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2223 void* observed = Atomic::cmpxchg_ptr(NULL, &_oops_do_mark_nmethods, required);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2224 guarantee(observed == required, "no races in this sequential code");
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2225 NOT_PRODUCT(if (TraceScavenge) tty->print_cr("oops_do_marking_epilogue]"));
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2226 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2227
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2228 class DetectScavengeRoot: public OopClosure {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2229 bool _detected_scavenge_root;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2230 public:
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2231 DetectScavengeRoot() : _detected_scavenge_root(false)
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2232 { NOT_PRODUCT(_print_nm = NULL); }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2233 bool detected_scavenge_root() { return _detected_scavenge_root; }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2234 virtual void do_oop(oop* p) {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2235 if ((*p) != NULL && (*p)->is_scavengable()) {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2236 NOT_PRODUCT(maybe_print(p));
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2237 _detected_scavenge_root = true;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2238 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2239 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2240 virtual void do_oop(narrowOop* p) { ShouldNotReachHere(); }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2241
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2242 #ifndef PRODUCT
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2243 nmethod* _print_nm;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2244 void maybe_print(oop* p) {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2245 if (_print_nm == NULL) return;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2246 if (!_detected_scavenge_root) _print_nm->print_on(tty, "new scavenge root");
3377
2aa9ddbb9e60 7041789: 30% perf regression with c2/arm following 7017732
jmasa
parents: 2405
diff changeset
2247 tty->print_cr(""PTR_FORMAT"[offset=%d] detected scavengable oop "PTR_FORMAT" (found at "PTR_FORMAT")",
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2248 _print_nm, (int)((intptr_t)p - (intptr_t)_print_nm),
12316
190899198332 7195622: CheckUnhandledOops has limited usefulness now
hseigel
parents: 12175
diff changeset
2249 (void *)(*p), (intptr_t)p);
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2250 (*p)->print();
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2251 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2252 #endif //PRODUCT
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2253 };
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2254
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2255 bool nmethod::detect_scavenge_root_oops() {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2256 DetectScavengeRoot detect_scavenge_root;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2257 NOT_PRODUCT(if (TraceScavenge) detect_scavenge_root._print_nm = this);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2258 oops_do(&detect_scavenge_root);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2259 return detect_scavenge_root.detected_scavenge_root();
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2260 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2261
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2262 // Method that knows how to preserve outgoing arguments at call. This method must be
a61af66fc99e Initial load
duke
parents:
diff changeset
2263 // called with a frame corresponding to a Java invoke
a61af66fc99e Initial load
duke
parents:
diff changeset
2264 void nmethod::preserve_callee_argument_oops(frame fr, const RegisterMap *reg_map, OopClosure* f) {
1692
d2ede61b7a12 6976186: integrate Shark HotSpot changes
twisti
parents: 1691
diff changeset
2265 #ifndef SHARK
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2266 if (!method()->is_native()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2267 SimpleScopeDesc ssd(this, fr.pc());
2142
8012aa3ccede 4926272: methodOopDesc::method_from_bcp is unsafe
never
parents: 2094
diff changeset
2268 Bytecode_invoke call(ssd.method(), ssd.bci());
10390
28e5aed7f3a6 8009981: nashorn tests fail with -XX:+VerifyStack
roland
parents: 10253
diff changeset
2269 bool has_receiver = call.has_receiver();
28e5aed7f3a6 8009981: nashorn tests fail with -XX:+VerifyStack
roland
parents: 10253
diff changeset
2270 bool has_appendix = call.has_appendix();
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2142
diff changeset
2271 Symbol* signature = call.signature();
10390
28e5aed7f3a6 8009981: nashorn tests fail with -XX:+VerifyStack
roland
parents: 10253
diff changeset
2272 fr.oops_compiled_arguments_do(signature, has_receiver, has_appendix, reg_map, f);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2273 }
1692
d2ede61b7a12 6976186: integrate Shark HotSpot changes
twisti
parents: 1691
diff changeset
2274 #endif // !SHARK
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2275 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2276
a61af66fc99e Initial load
duke
parents:
diff changeset
2277
a61af66fc99e Initial load
duke
parents:
diff changeset
2278 oop nmethod::embeddedOop_at(u_char* p) {
2349
4cd9add59b1e 7024866: # assert(limit == NULL || limit <= nm->code_end()) failed: in bounds
never
parents: 2321
diff changeset
2279 RelocIterator iter(this, p, p + 1);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2280 while (iter.next())
a61af66fc99e Initial load
duke
parents:
diff changeset
2281 if (iter.type() == relocInfo::oop_type) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2282 return iter.oop_reloc()->oop_value();
a61af66fc99e Initial load
duke
parents:
diff changeset
2283 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2284 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2285 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2286
a61af66fc99e Initial load
duke
parents:
diff changeset
2287
a61af66fc99e Initial load
duke
parents:
diff changeset
2288 inline bool includes(void* p, void* from, void* to) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2289 return from <= p && p < to;
a61af66fc99e Initial load
duke
parents:
diff changeset
2290 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2291
a61af66fc99e Initial load
duke
parents:
diff changeset
2292
a61af66fc99e Initial load
duke
parents:
diff changeset
2293 void nmethod::copy_scopes_pcs(PcDesc* pcs, int count) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2294 assert(count >= 2, "must be sentinel values, at least");
a61af66fc99e Initial load
duke
parents:
diff changeset
2295
a61af66fc99e Initial load
duke
parents:
diff changeset
2296 #ifdef ASSERT
a61af66fc99e Initial load
duke
parents:
diff changeset
2297 // must be sorted and unique; we do a binary search in find_pc_desc()
a61af66fc99e Initial load
duke
parents:
diff changeset
2298 int prev_offset = pcs[0].pc_offset();
a61af66fc99e Initial load
duke
parents:
diff changeset
2299 assert(prev_offset == PcDesc::lower_offset_limit,
a61af66fc99e Initial load
duke
parents:
diff changeset
2300 "must start with a sentinel");
a61af66fc99e Initial load
duke
parents:
diff changeset
2301 for (int i = 1; i < count; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2302 int this_offset = pcs[i].pc_offset();
a61af66fc99e Initial load
duke
parents:
diff changeset
2303 assert(this_offset > prev_offset, "offsets must be sorted");
a61af66fc99e Initial load
duke
parents:
diff changeset
2304 prev_offset = this_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
2305 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2306 assert(prev_offset == PcDesc::upper_offset_limit,
a61af66fc99e Initial load
duke
parents:
diff changeset
2307 "must end with a sentinel");
a61af66fc99e Initial load
duke
parents:
diff changeset
2308 #endif //ASSERT
a61af66fc99e Initial load
duke
parents:
diff changeset
2309
1135
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2310 // Search for MethodHandle invokes and tag the nmethod.
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2311 for (int i = 0; i < count; i++) {
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2312 if (pcs[i].is_method_handle_invoke()) {
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2313 set_has_method_handle_invokes(true);
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2314 break;
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2315 }
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2316 }
2083
7d9caaedafce 6990933: assert(sender_cb) failed: sanity in frame::sender_for_interpreter_frame
twisti
parents: 1972
diff changeset
2317 assert(has_method_handle_invokes() == (_deoptimize_mh_offset != -1), "must have deopt mh handler");
1135
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2318
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2319 int size = count * sizeof(PcDesc);
a61af66fc99e Initial load
duke
parents:
diff changeset
2320 assert(scopes_pcs_size() >= size, "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
2321 memcpy(scopes_pcs_begin(), pcs, size);
a61af66fc99e Initial load
duke
parents:
diff changeset
2322
a61af66fc99e Initial load
duke
parents:
diff changeset
2323 // Adjust the final sentinel downward.
a61af66fc99e Initial load
duke
parents:
diff changeset
2324 PcDesc* last_pc = &scopes_pcs_begin()[count-1];
a61af66fc99e Initial load
duke
parents:
diff changeset
2325 assert(last_pc->pc_offset() == PcDesc::upper_offset_limit, "sanity");
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
2326 last_pc->set_pc_offset(content_size() + 1);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2327 for (; last_pc + 1 < scopes_pcs_end(); last_pc += 1) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2328 // Fill any rounding gaps with copies of the last record.
a61af66fc99e Initial load
duke
parents:
diff changeset
2329 last_pc[1] = last_pc[0];
a61af66fc99e Initial load
duke
parents:
diff changeset
2330 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2331 // The following assert could fail if sizeof(PcDesc) is not
a61af66fc99e Initial load
duke
parents:
diff changeset
2332 // an integral multiple of oopSize (the rounding term).
a61af66fc99e Initial load
duke
parents:
diff changeset
2333 // If it fails, change the logic to always allocate a multiple
a61af66fc99e Initial load
duke
parents:
diff changeset
2334 // of sizeof(PcDesc), and fill unused words with copies of *last_pc.
a61af66fc99e Initial load
duke
parents:
diff changeset
2335 assert(last_pc + 1 == scopes_pcs_end(), "must match exactly");
a61af66fc99e Initial load
duke
parents:
diff changeset
2336 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2337
a61af66fc99e Initial load
duke
parents:
diff changeset
2338 void nmethod::copy_scopes_data(u_char* buffer, int size) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2339 assert(scopes_data_size() >= size, "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
2340 memcpy(scopes_data_begin(), buffer, size);
a61af66fc99e Initial load
duke
parents:
diff changeset
2341 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2342
a61af66fc99e Initial load
duke
parents:
diff changeset
2343
a61af66fc99e Initial load
duke
parents:
diff changeset
2344 #ifdef ASSERT
a61af66fc99e Initial load
duke
parents:
diff changeset
2345 static PcDesc* linear_search(nmethod* nm, int pc_offset, bool approximate) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2346 PcDesc* lower = nm->scopes_pcs_begin();
a61af66fc99e Initial load
duke
parents:
diff changeset
2347 PcDesc* upper = nm->scopes_pcs_end();
a61af66fc99e Initial load
duke
parents:
diff changeset
2348 lower += 1; // exclude initial sentinel
a61af66fc99e Initial load
duke
parents:
diff changeset
2349 PcDesc* res = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2350 for (PcDesc* p = lower; p < upper; p++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2351 NOT_PRODUCT(--nmethod_stats.pc_desc_tests); // don't count this call to match_desc
a61af66fc99e Initial load
duke
parents:
diff changeset
2352 if (match_desc(p, pc_offset, approximate)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2353 if (res == NULL)
a61af66fc99e Initial load
duke
parents:
diff changeset
2354 res = p;
a61af66fc99e Initial load
duke
parents:
diff changeset
2355 else
a61af66fc99e Initial load
duke
parents:
diff changeset
2356 res = (PcDesc*) badAddress;
a61af66fc99e Initial load
duke
parents:
diff changeset
2357 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2358 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2359 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
2360 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2361 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
2362
a61af66fc99e Initial load
duke
parents:
diff changeset
2363
a61af66fc99e Initial load
duke
parents:
diff changeset
2364 // Finds a PcDesc with real-pc equal to "pc"
a61af66fc99e Initial load
duke
parents:
diff changeset
2365 PcDesc* nmethod::find_pc_desc_internal(address pc, bool approximate) {
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
2366 address base_address = code_begin();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2367 if ((pc < base_address) ||
a61af66fc99e Initial load
duke
parents:
diff changeset
2368 (pc - base_address) >= (ptrdiff_t) PcDesc::upper_offset_limit) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2369 return NULL; // PC is wildly out of range
a61af66fc99e Initial load
duke
parents:
diff changeset
2370 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2371 int pc_offset = (int) (pc - base_address);
a61af66fc99e Initial load
duke
parents:
diff changeset
2372
a61af66fc99e Initial load
duke
parents:
diff changeset
2373 // Check the PcDesc cache if it contains the desired PcDesc
a61af66fc99e Initial load
duke
parents:
diff changeset
2374 // (This as an almost 100% hit rate.)
a61af66fc99e Initial load
duke
parents:
diff changeset
2375 PcDesc* res = _pc_desc_cache.find_pc_desc(pc_offset, approximate);
a61af66fc99e Initial load
duke
parents:
diff changeset
2376 if (res != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2377 assert(res == linear_search(this, pc_offset, approximate), "cache ok");
a61af66fc99e Initial load
duke
parents:
diff changeset
2378 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
2379 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2380
a61af66fc99e Initial load
duke
parents:
diff changeset
2381 // Fallback algorithm: quasi-linear search for the PcDesc
a61af66fc99e Initial load
duke
parents:
diff changeset
2382 // Find the last pc_offset less than the given offset.
a61af66fc99e Initial load
duke
parents:
diff changeset
2383 // The successor must be the required match, if there is a match at all.
a61af66fc99e Initial load
duke
parents:
diff changeset
2384 // (Use a fixed radix to avoid expensive affine pointer arithmetic.)
a61af66fc99e Initial load
duke
parents:
diff changeset
2385 PcDesc* lower = scopes_pcs_begin();
a61af66fc99e Initial load
duke
parents:
diff changeset
2386 PcDesc* upper = scopes_pcs_end();
a61af66fc99e Initial load
duke
parents:
diff changeset
2387 upper -= 1; // exclude final sentinel
a61af66fc99e Initial load
duke
parents:
diff changeset
2388 if (lower >= upper) return NULL; // native method; no PcDescs at all
a61af66fc99e Initial load
duke
parents:
diff changeset
2389
a61af66fc99e Initial load
duke
parents:
diff changeset
2390 #define assert_LU_OK \
a61af66fc99e Initial load
duke
parents:
diff changeset
2391 /* invariant on lower..upper during the following search: */ \
a61af66fc99e Initial load
duke
parents:
diff changeset
2392 assert(lower->pc_offset() < pc_offset, "sanity"); \
a61af66fc99e Initial load
duke
parents:
diff changeset
2393 assert(upper->pc_offset() >= pc_offset, "sanity")
a61af66fc99e Initial load
duke
parents:
diff changeset
2394 assert_LU_OK;
a61af66fc99e Initial load
duke
parents:
diff changeset
2395
a61af66fc99e Initial load
duke
parents:
diff changeset
2396 // Use the last successful return as a split point.
a61af66fc99e Initial load
duke
parents:
diff changeset
2397 PcDesc* mid = _pc_desc_cache.last_pc_desc();
a61af66fc99e Initial load
duke
parents:
diff changeset
2398 NOT_PRODUCT(++nmethod_stats.pc_desc_searches);
a61af66fc99e Initial load
duke
parents:
diff changeset
2399 if (mid->pc_offset() < pc_offset) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2400 lower = mid;
a61af66fc99e Initial load
duke
parents:
diff changeset
2401 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
2402 upper = mid;
a61af66fc99e Initial load
duke
parents:
diff changeset
2403 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2404
a61af66fc99e Initial load
duke
parents:
diff changeset
2405 // Take giant steps at first (4096, then 256, then 16, then 1)
a61af66fc99e Initial load
duke
parents:
diff changeset
2406 const int LOG2_RADIX = 4 /*smaller steps in debug mode:*/ debug_only(-1);
a61af66fc99e Initial load
duke
parents:
diff changeset
2407 const int RADIX = (1 << LOG2_RADIX);
a61af66fc99e Initial load
duke
parents:
diff changeset
2408 for (int step = (1 << (LOG2_RADIX*3)); step > 1; step >>= LOG2_RADIX) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2409 while ((mid = lower + step) < upper) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2410 assert_LU_OK;
a61af66fc99e Initial load
duke
parents:
diff changeset
2411 NOT_PRODUCT(++nmethod_stats.pc_desc_searches);
a61af66fc99e Initial load
duke
parents:
diff changeset
2412 if (mid->pc_offset() < pc_offset) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2413 lower = mid;
a61af66fc99e Initial load
duke
parents:
diff changeset
2414 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
2415 upper = mid;
a61af66fc99e Initial load
duke
parents:
diff changeset
2416 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
2417 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2418 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2419 assert_LU_OK;
a61af66fc99e Initial load
duke
parents:
diff changeset
2420 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2421
a61af66fc99e Initial load
duke
parents:
diff changeset
2422 // Sneak up on the value with a linear search of length ~16.
a61af66fc99e Initial load
duke
parents:
diff changeset
2423 while (true) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2424 assert_LU_OK;
a61af66fc99e Initial load
duke
parents:
diff changeset
2425 mid = lower + 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
2426 NOT_PRODUCT(++nmethod_stats.pc_desc_searches);
a61af66fc99e Initial load
duke
parents:
diff changeset
2427 if (mid->pc_offset() < pc_offset) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2428 lower = mid;
a61af66fc99e Initial load
duke
parents:
diff changeset
2429 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
2430 upper = mid;
a61af66fc99e Initial load
duke
parents:
diff changeset
2431 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
2432 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2433 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2434 #undef assert_LU_OK
a61af66fc99e Initial load
duke
parents:
diff changeset
2435
a61af66fc99e Initial load
duke
parents:
diff changeset
2436 if (match_desc(upper, pc_offset, approximate)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2437 assert(upper == linear_search(this, pc_offset, approximate), "search ok");
a61af66fc99e Initial load
duke
parents:
diff changeset
2438 _pc_desc_cache.add_pc_desc(upper);
a61af66fc99e Initial load
duke
parents:
diff changeset
2439 return upper;
a61af66fc99e Initial load
duke
parents:
diff changeset
2440 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
2441 assert(NULL == linear_search(this, pc_offset, approximate), "search ok");
a61af66fc99e Initial load
duke
parents:
diff changeset
2442 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2443 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2444 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2445
a61af66fc99e Initial load
duke
parents:
diff changeset
2446
a61af66fc99e Initial load
duke
parents:
diff changeset
2447 bool nmethod::check_all_dependencies() {
a61af66fc99e Initial load
duke
parents:
diff changeset
2448 bool found_check = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
2449 // wholesale check of all dependencies
a61af66fc99e Initial load
duke
parents:
diff changeset
2450 for (Dependencies::DepStream deps(this); deps.next(); ) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2451 if (deps.check_dependency() != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2452 found_check = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
2453 NOT_DEBUG(break);
a61af66fc99e Initial load
duke
parents:
diff changeset
2454 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2455 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2456 return found_check; // tell caller if we found anything
a61af66fc99e Initial load
duke
parents:
diff changeset
2457 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2458
a61af66fc99e Initial load
duke
parents:
diff changeset
2459 bool nmethod::check_dependency_on(DepChange& changes) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2460 // What has happened:
a61af66fc99e Initial load
duke
parents:
diff changeset
2461 // 1) a new class dependee has been added
a61af66fc99e Initial load
duke
parents:
diff changeset
2462 // 2) dependee and all its super classes have been marked
a61af66fc99e Initial load
duke
parents:
diff changeset
2463 bool found_check = false; // set true if we are upset
a61af66fc99e Initial load
duke
parents:
diff changeset
2464 for (Dependencies::DepStream deps(this); deps.next(); ) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2465 // Evaluate only relevant dependencies.
a61af66fc99e Initial load
duke
parents:
diff changeset
2466 if (deps.spot_check_dependency_at(changes) != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2467 found_check = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
2468 NOT_DEBUG(break);
a61af66fc99e Initial load
duke
parents:
diff changeset
2469 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2470 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2471 return found_check;
a61af66fc99e Initial load
duke
parents:
diff changeset
2472 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2473
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2474 bool nmethod::is_evol_dependent_on(Klass* dependee) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2475 InstanceKlass *dependee_ik = InstanceKlass::cast(dependee);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2476 Array<Method*>* dependee_methods = dependee_ik->methods();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2477 for (Dependencies::DepStream deps(this); deps.next(); ) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2478 if (deps.type() == Dependencies::evol_method) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2479 Method* method = deps.method_argument(0);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2480 for (int j = 0; j < dependee_methods->length(); j++) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2481 if (dependee_methods->at(j) == method) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2482 // RC_TRACE macro has an embedded ResourceMark
a61af66fc99e Initial load
duke
parents:
diff changeset
2483 RC_TRACE(0x01000000,
a61af66fc99e Initial load
duke
parents:
diff changeset
2484 ("Found evol dependency of nmethod %s.%s(%s) compile_id=%d on method %s.%s(%s)",
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2485 _method->method_holder()->external_name(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2486 _method->name()->as_C_string(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2487 _method->signature()->as_C_string(), compile_id(),
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2488 method->method_holder()->external_name(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2489 method->name()->as_C_string(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2490 method->signature()->as_C_string()));
a61af66fc99e Initial load
duke
parents:
diff changeset
2491 if (TraceDependencies || LogCompilation)
a61af66fc99e Initial load
duke
parents:
diff changeset
2492 deps.log_dependency(dependee);
a61af66fc99e Initial load
duke
parents:
diff changeset
2493 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
2494 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2495 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2496 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2497 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2498 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
2499 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2500
a61af66fc99e Initial load
duke
parents:
diff changeset
2501 // Called from mark_for_deoptimization, when dependee is invalidated.
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2502 bool nmethod::is_dependent_on_method(Method* dependee) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2503 for (Dependencies::DepStream deps(this); deps.next(); ) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2504 if (deps.type() != Dependencies::evol_method)
a61af66fc99e Initial load
duke
parents:
diff changeset
2505 continue;
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2506 Method* method = deps.method_argument(0);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2507 if (method == dependee) return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
2508 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2509 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
2510 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2511
a61af66fc99e Initial load
duke
parents:
diff changeset
2512
a61af66fc99e Initial load
duke
parents:
diff changeset
2513 bool nmethod::is_patchable_at(address instr_addr) {
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
2514 assert(insts_contains(instr_addr), "wrong nmethod used");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2515 if (is_zombie()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2516 // a zombie may never be patched
a61af66fc99e Initial load
duke
parents:
diff changeset
2517 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
2518 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2519 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
2520 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2521
a61af66fc99e Initial load
duke
parents:
diff changeset
2522
a61af66fc99e Initial load
duke
parents:
diff changeset
2523 address nmethod::continuation_for_implicit_exception(address pc) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2524 // Exception happened outside inline-cache check code => we are inside
a61af66fc99e Initial load
duke
parents:
diff changeset
2525 // an active nmethod => use cpc to determine a return address
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
2526 int exception_offset = pc - code_begin();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2527 int cont_offset = ImplicitExceptionTable(this).at( exception_offset );
a61af66fc99e Initial load
duke
parents:
diff changeset
2528 #ifdef ASSERT
a61af66fc99e Initial load
duke
parents:
diff changeset
2529 if (cont_offset == 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2530 Thread* thread = ThreadLocalStorage::get_thread_slow();
a61af66fc99e Initial load
duke
parents:
diff changeset
2531 ResetNoHandleMark rnm; // Might be called from LEAF/QUICK ENTRY
a61af66fc99e Initial load
duke
parents:
diff changeset
2532 HandleMark hm(thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2533 ResourceMark rm(thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
2534 CodeBlob* cb = CodeCache::find_blob(pc);
a61af66fc99e Initial load
duke
parents:
diff changeset
2535 assert(cb != NULL && cb == this, "");
a61af66fc99e Initial load
duke
parents:
diff changeset
2536 tty->print_cr("implicit exception happened at " INTPTR_FORMAT, pc);
a61af66fc99e Initial load
duke
parents:
diff changeset
2537 print();
a61af66fc99e Initial load
duke
parents:
diff changeset
2538 method()->print_codes();
a61af66fc99e Initial load
duke
parents:
diff changeset
2539 print_code();
a61af66fc99e Initial load
duke
parents:
diff changeset
2540 print_pcs();
a61af66fc99e Initial load
duke
parents:
diff changeset
2541 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2542 #endif
1250
3f5b7efb9642 6920293: OptimizeStringConcat causing core dumps
never
parents: 1206
diff changeset
2543 if (cont_offset == 0) {
3f5b7efb9642 6920293: OptimizeStringConcat causing core dumps
never
parents: 1206
diff changeset
2544 // Let the normal error handling report the exception
3f5b7efb9642 6920293: OptimizeStringConcat causing core dumps
never
parents: 1206
diff changeset
2545 return NULL;
3f5b7efb9642 6920293: OptimizeStringConcat causing core dumps
never
parents: 1206
diff changeset
2546 }
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
2547 return code_begin() + cont_offset;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2548 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2549
a61af66fc99e Initial load
duke
parents:
diff changeset
2550
a61af66fc99e Initial load
duke
parents:
diff changeset
2551
a61af66fc99e Initial load
duke
parents:
diff changeset
2552 void nmethod_init() {
a61af66fc99e Initial load
duke
parents:
diff changeset
2553 // make sure you didn't forget to adjust the filler fields
a61af66fc99e Initial load
duke
parents:
diff changeset
2554 assert(sizeof(nmethod) % oopSize == 0, "nmethod size must be multiple of a word");
a61af66fc99e Initial load
duke
parents:
diff changeset
2555 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2556
a61af66fc99e Initial load
duke
parents:
diff changeset
2557
a61af66fc99e Initial load
duke
parents:
diff changeset
2558 //-------------------------------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
2559
a61af66fc99e Initial load
duke
parents:
diff changeset
2560
a61af66fc99e Initial load
duke
parents:
diff changeset
2561 // QQQ might we make this work from a frame??
a61af66fc99e Initial load
duke
parents:
diff changeset
2562 nmethodLocker::nmethodLocker(address pc) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2563 CodeBlob* cb = CodeCache::find_blob(pc);
a61af66fc99e Initial load
duke
parents:
diff changeset
2564 guarantee(cb != NULL && cb->is_nmethod(), "bad pc for a nmethod found");
a61af66fc99e Initial load
duke
parents:
diff changeset
2565 _nm = (nmethod*)cb;
a61af66fc99e Initial load
duke
parents:
diff changeset
2566 lock_nmethod(_nm);
a61af66fc99e Initial load
duke
parents:
diff changeset
2567 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2568
2342
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
2569 // Only JvmtiDeferredEvent::compiled_method_unload_event()
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
2570 // should pass zombie_ok == true.
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
2571 void nmethodLocker::lock_nmethod(nmethod* nm, bool zombie_ok) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2572 if (nm == NULL) return;
a61af66fc99e Initial load
duke
parents:
diff changeset
2573 Atomic::inc(&nm->_lock_count);
2342
46a56fac55c7 7024970: 2/3 assert(ServiceThread::is_service_thread(Thread::current())) failed: Service thread must post enqueue
dcubed
parents: 2321
diff changeset
2574 guarantee(zombie_ok || !nm->is_zombie(), "cannot lock a zombie method");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2575 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2576
a61af66fc99e Initial load
duke
parents:
diff changeset
2577 void nmethodLocker::unlock_nmethod(nmethod* nm) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2578 if (nm == NULL) return;
a61af66fc99e Initial load
duke
parents:
diff changeset
2579 Atomic::dec(&nm->_lock_count);
a61af66fc99e Initial load
duke
parents:
diff changeset
2580 guarantee(nm->_lock_count >= 0, "unmatched nmethod lock/unlock");
a61af66fc99e Initial load
duke
parents:
diff changeset
2581 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2582
1204
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2583
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2584 // -----------------------------------------------------------------------------
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2585 // nmethod::get_deopt_original_pc
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2586 //
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2587 // Return the original PC for the given PC if:
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2588 // (a) the given PC belongs to a nmethod and
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2589 // (b) it is a deopt PC
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2590 address nmethod::get_deopt_original_pc(const frame* fr) {
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2591 if (fr->cb() == NULL) return NULL;
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2592
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2593 nmethod* nm = fr->cb()->as_nmethod_or_null();
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2594 if (nm != NULL && nm->is_deopt_pc(fr->pc()))
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2595 return nm->get_original_pc(fr);
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2596
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2597 return NULL;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2598 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2599
a61af66fc99e Initial load
duke
parents:
diff changeset
2600
a61af66fc99e Initial load
duke
parents:
diff changeset
2601 // -----------------------------------------------------------------------------
1135
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2602 // MethodHandle
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2603
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2604 bool nmethod::is_method_handle_return(address return_pc) {
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2605 if (!has_method_handle_invokes()) return false;
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2606 PcDesc* pd = pc_desc_at(return_pc);
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2607 if (pd == NULL)
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2608 return false;
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2609 return pd->is_method_handle_invoke();
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2610 }
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2611
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2612
e66fd840cb6b 6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents: 1109
diff changeset
2613 // -----------------------------------------------------------------------------
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2614 // Verification
a61af66fc99e Initial load
duke
parents:
diff changeset
2615
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2616 class VerifyOopsClosure: public OopClosure {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2617 nmethod* _nm;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2618 bool _ok;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2619 public:
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2620 VerifyOopsClosure(nmethod* nm) : _nm(nm), _ok(true) { }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2621 bool ok() { return _ok; }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2622 virtual void do_oop(oop* p) {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2623 if ((*p) == NULL || (*p)->is_oop()) return;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2624 if (_ok) {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2625 _nm->print_nmethod(true);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2626 _ok = false;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2627 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2628 tty->print_cr("*** non-oop "PTR_FORMAT" found at "PTR_FORMAT" (offset %d)",
12316
190899198332 7195622: CheckUnhandledOops has limited usefulness now
hseigel
parents: 12175
diff changeset
2629 (void *)(*p), (intptr_t)p, (int)((intptr_t)p - (intptr_t)_nm));
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2630 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2631 virtual void do_oop(narrowOop* p) { ShouldNotReachHere(); }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2632 };
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2633
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2634 void nmethod::verify() {
a61af66fc99e Initial load
duke
parents:
diff changeset
2635
a61af66fc99e Initial load
duke
parents:
diff changeset
2636 // Hmm. OSR methods can be deopted but not marked as zombie or not_entrant
a61af66fc99e Initial load
duke
parents:
diff changeset
2637 // seems odd.
a61af66fc99e Initial load
duke
parents:
diff changeset
2638
a61af66fc99e Initial load
duke
parents:
diff changeset
2639 if( is_zombie() || is_not_entrant() )
a61af66fc99e Initial load
duke
parents:
diff changeset
2640 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
2641
a61af66fc99e Initial load
duke
parents:
diff changeset
2642 // Make sure all the entry points are correctly aligned for patching.
a61af66fc99e Initial load
duke
parents:
diff changeset
2643 NativeJump::check_verified_entry_alignment(entry_point(), verified_entry_point());
a61af66fc99e Initial load
duke
parents:
diff changeset
2644
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2645 // assert(method()->is_oop(), "must be valid");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2646
a61af66fc99e Initial load
duke
parents:
diff changeset
2647 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
2648
a61af66fc99e Initial load
duke
parents:
diff changeset
2649 if (!CodeCache::contains(this)) {
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1489
diff changeset
2650 fatal(err_msg("nmethod at " INTPTR_FORMAT " not in zone", this));
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2651 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2652
a61af66fc99e Initial load
duke
parents:
diff changeset
2653 if(is_native_method() )
a61af66fc99e Initial load
duke
parents:
diff changeset
2654 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
2655
a61af66fc99e Initial load
duke
parents:
diff changeset
2656 nmethod* nm = CodeCache::find_nmethod(verified_entry_point());
a61af66fc99e Initial load
duke
parents:
diff changeset
2657 if (nm != this) {
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1489
diff changeset
2658 fatal(err_msg("findNMethod did not find this nmethod (" INTPTR_FORMAT ")",
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1489
diff changeset
2659 this));
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2660 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2661
a61af66fc99e Initial load
duke
parents:
diff changeset
2662 for (PcDesc* p = scopes_pcs_begin(); p < scopes_pcs_end(); p++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2663 if (! p->verify(this)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2664 tty->print_cr("\t\tin nmethod at " INTPTR_FORMAT " (pcs)", this);
a61af66fc99e Initial load
duke
parents:
diff changeset
2665 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2666 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2667
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2668 VerifyOopsClosure voc(this);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2669 oops_do(&voc);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2670 assert(voc.ok(), "embedded oops must be OK");
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2671 verify_scavenge_root_oops();
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2672
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2673 verify_scopes();
a61af66fc99e Initial load
duke
parents:
diff changeset
2674 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2675
a61af66fc99e Initial load
duke
parents:
diff changeset
2676
a61af66fc99e Initial load
duke
parents:
diff changeset
2677 void nmethod::verify_interrupt_point(address call_site) {
13071
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2678 // Verify IC only when nmethod installation is finished.
13441
df832bd8edb9 8028107: Kitchensink crashed with EAV
kvn
parents: 13074
diff changeset
2679 bool is_installed = (method()->code() == this) // nmethod is in state 'in_use' and installed
df832bd8edb9 8028107: Kitchensink crashed with EAV
kvn
parents: 13074
diff changeset
2680 || !this->is_in_use(); // nmethod is installed, but not in 'in_use' state
13071
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2681 if (is_installed) {
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2682 Thread *cur = Thread::current();
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2683 if (CompiledIC_lock->owner() == cur ||
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2684 ((cur->is_VM_thread() || cur->is_ConcurrentGC_thread()) &&
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2685 SafepointSynchronize::is_at_safepoint())) {
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2686 CompiledIC_at(this, call_site);
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2687 CHECK_UNHANDLED_OOPS_ONLY(Thread::current()->clear_unhandled_oops());
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2688 } else {
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2689 MutexLocker ml_verify (CompiledIC_lock);
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2690 CompiledIC_at(this, call_site);
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2691 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2692 }
13071
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2693
e2509677809c 8023037: Race between ciEnv::register_method and nmethod::make_not_entrant_or_zombie
vlivanov
parents: 12334
diff changeset
2694 PcDesc* pd = pc_desc_at(nativeCall_at(call_site)->return_address());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2695 assert(pd != NULL, "PcDesc must exist");
a61af66fc99e Initial load
duke
parents:
diff changeset
2696 for (ScopeDesc* sd = new ScopeDesc(this, pd->scope_decode_offset(),
1253
f70b0d9ab095 6910618: C2: Error: assert(d->is_oop(),"JVM_ArrayCopy: dst not an oop")
kvn
parents: 1250
diff changeset
2697 pd->obj_decode_offset(), pd->should_reexecute(),
f70b0d9ab095 6910618: C2: Error: assert(d->is_oop(),"JVM_ArrayCopy: dst not an oop")
kvn
parents: 1250
diff changeset
2698 pd->return_oop());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2699 !sd->is_top(); sd = sd->sender()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2700 sd->verify();
a61af66fc99e Initial load
duke
parents:
diff changeset
2701 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2702 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2703
a61af66fc99e Initial load
duke
parents:
diff changeset
2704 void nmethod::verify_scopes() {
a61af66fc99e Initial load
duke
parents:
diff changeset
2705 if( !method() ) return; // Runtime stubs have no scope
a61af66fc99e Initial load
duke
parents:
diff changeset
2706 if (method()->is_native()) return; // Ignore stub methods.
a61af66fc99e Initial load
duke
parents:
diff changeset
2707 // iterate through all interrupt point
a61af66fc99e Initial load
duke
parents:
diff changeset
2708 // and verify the debug information is valid.
a61af66fc99e Initial load
duke
parents:
diff changeset
2709 RelocIterator iter((nmethod*)this);
a61af66fc99e Initial load
duke
parents:
diff changeset
2710 while (iter.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2711 address stub = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2712 switch (iter.type()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2713 case relocInfo::virtual_call_type:
a61af66fc99e Initial load
duke
parents:
diff changeset
2714 verify_interrupt_point(iter.addr());
a61af66fc99e Initial load
duke
parents:
diff changeset
2715 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
2716 case relocInfo::opt_virtual_call_type:
a61af66fc99e Initial load
duke
parents:
diff changeset
2717 stub = iter.opt_virtual_call_reloc()->static_stub();
a61af66fc99e Initial load
duke
parents:
diff changeset
2718 verify_interrupt_point(iter.addr());
a61af66fc99e Initial load
duke
parents:
diff changeset
2719 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
2720 case relocInfo::static_call_type:
a61af66fc99e Initial load
duke
parents:
diff changeset
2721 stub = iter.static_call_reloc()->static_stub();
a61af66fc99e Initial load
duke
parents:
diff changeset
2722 //verify_interrupt_point(iter.addr());
a61af66fc99e Initial load
duke
parents:
diff changeset
2723 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
2724 case relocInfo::runtime_call_type:
a61af66fc99e Initial load
duke
parents:
diff changeset
2725 address destination = iter.reloc()->value();
a61af66fc99e Initial load
duke
parents:
diff changeset
2726 // Right now there is no way to find out which entries support
a61af66fc99e Initial load
duke
parents:
diff changeset
2727 // an interrupt point. It would be nice if we had this
a61af66fc99e Initial load
duke
parents:
diff changeset
2728 // information in a table.
a61af66fc99e Initial load
duke
parents:
diff changeset
2729 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
2730 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2731 assert(stub == NULL || stub_contains(stub), "static call stub outside stub section");
a61af66fc99e Initial load
duke
parents:
diff changeset
2732 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2733 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2734
a61af66fc99e Initial load
duke
parents:
diff changeset
2735
a61af66fc99e Initial load
duke
parents:
diff changeset
2736 // -----------------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
2737 // Non-product code
a61af66fc99e Initial load
duke
parents:
diff changeset
2738 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
2739
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2740 class DebugScavengeRoot: public OopClosure {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2741 nmethod* _nm;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2742 bool _ok;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2743 public:
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2744 DebugScavengeRoot(nmethod* nm) : _nm(nm), _ok(true) { }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2745 bool ok() { return _ok; }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2746 virtual void do_oop(oop* p) {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2747 if ((*p) == NULL || !(*p)->is_scavengable()) return;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2748 if (_ok) {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2749 _nm->print_nmethod(true);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2750 _ok = false;
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2751 }
3377
2aa9ddbb9e60 7041789: 30% perf regression with c2/arm following 7017732
jmasa
parents: 2405
diff changeset
2752 tty->print_cr("*** scavengable oop "PTR_FORMAT" found at "PTR_FORMAT" (offset %d)",
12316
190899198332 7195622: CheckUnhandledOops has limited usefulness now
hseigel
parents: 12175
diff changeset
2753 (void *)(*p), (intptr_t)p, (int)((intptr_t)p - (intptr_t)_nm));
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2754 (*p)->print();
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2755 }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2756 virtual void do_oop(narrowOop* p) { ShouldNotReachHere(); }
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2757 };
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2758
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2759 void nmethod::verify_scavenge_root_oops() {
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
2760 if (UseG1GC) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
2761 return;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
2762 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20277
diff changeset
2763
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2764 if (!on_scavenge_root_list()) {
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2765 // Actually look inside, to verify the claim that it's clean.
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2766 DebugScavengeRoot debug_scavenge_root(this);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2767 oops_do(&debug_scavenge_root);
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2768 if (!debug_scavenge_root.ok())
3377
2aa9ddbb9e60 7041789: 30% perf regression with c2/arm following 7017732
jmasa
parents: 2405
diff changeset
2769 fatal("found an unadvertised bad scavengable oop in the code cache");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2770 }
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2771 assert(scavenge_root_not_marked(), "");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2772 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2773
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
2774 #endif // PRODUCT
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2775
a61af66fc99e Initial load
duke
parents:
diff changeset
2776 // Printing operations
a61af66fc99e Initial load
duke
parents:
diff changeset
2777
a61af66fc99e Initial load
duke
parents:
diff changeset
2778 void nmethod::print() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
2779 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
2780 ttyLocker ttyl; // keep the following output all in one block
a61af66fc99e Initial load
duke
parents:
diff changeset
2781
2405
3d58a4983660 7022998: JSR 292 recursive method handle calls inline themselves infinitely
twisti
parents: 2376
diff changeset
2782 tty->print("Compiled method ");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2783
a61af66fc99e Initial load
duke
parents:
diff changeset
2784 if (is_compiled_by_c1()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2785 tty->print("(c1) ");
a61af66fc99e Initial load
duke
parents:
diff changeset
2786 } else if (is_compiled_by_c2()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2787 tty->print("(c2) ");
1692
d2ede61b7a12 6976186: integrate Shark HotSpot changes
twisti
parents: 1691
diff changeset
2788 } else if (is_compiled_by_shark()) {
d2ede61b7a12 6976186: integrate Shark HotSpot changes
twisti
parents: 1691
diff changeset
2789 tty->print("(shark) ");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2790 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
2791 tty->print("(nm) ");
a61af66fc99e Initial load
duke
parents:
diff changeset
2792 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2793
2405
3d58a4983660 7022998: JSR 292 recursive method handle calls inline themselves infinitely
twisti
parents: 2376
diff changeset
2794 print_on(tty, NULL);
3d58a4983660 7022998: JSR 292 recursive method handle calls inline themselves infinitely
twisti
parents: 2376
diff changeset
2795
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2796 if (WizardMode) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2797 tty->print("((nmethod*) "INTPTR_FORMAT ") ", this);
a61af66fc99e Initial load
duke
parents:
diff changeset
2798 tty->print(" for method " INTPTR_FORMAT , (address)method());
a61af66fc99e Initial load
duke
parents:
diff changeset
2799 tty->print(" { ");
a61af66fc99e Initial load
duke
parents:
diff changeset
2800 if (is_in_use()) tty->print("in_use ");
a61af66fc99e Initial load
duke
parents:
diff changeset
2801 if (is_not_entrant()) tty->print("not_entrant ");
a61af66fc99e Initial load
duke
parents:
diff changeset
2802 if (is_zombie()) tty->print("zombie ");
a61af66fc99e Initial load
duke
parents:
diff changeset
2803 if (is_unloaded()) tty->print("unloaded ");
989
148e5441d916 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 931
diff changeset
2804 if (on_scavenge_root_list()) tty->print("scavenge_root ");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2805 tty->print_cr("}:");
a61af66fc99e Initial load
duke
parents:
diff changeset
2806 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2807 if (size () > 0) tty->print_cr(" total in heap [" INTPTR_FORMAT "," INTPTR_FORMAT "] = %d",
a61af66fc99e Initial load
duke
parents:
diff changeset
2808 (address)this,
a61af66fc99e Initial load
duke
parents:
diff changeset
2809 (address)this + size(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2810 size());
a61af66fc99e Initial load
duke
parents:
diff changeset
2811 if (relocation_size () > 0) tty->print_cr(" relocation [" INTPTR_FORMAT "," INTPTR_FORMAT "] = %d",
a61af66fc99e Initial load
duke
parents:
diff changeset
2812 relocation_begin(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2813 relocation_end(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2814 relocation_size());
1762
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
2815 if (consts_size () > 0) tty->print_cr(" constants [" INTPTR_FORMAT "," INTPTR_FORMAT "] = %d",
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
2816 consts_begin(),
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
2817 consts_end(),
0878d7bae69f 6961697: move nmethod constants section before instruction section
twisti
parents: 1748
diff changeset
2818 consts_size());
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
2819 if (insts_size () > 0) tty->print_cr(" main code [" INTPTR_FORMAT "," INTPTR_FORMAT "] = %d",
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
2820 insts_begin(),
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
2821 insts_end(),
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
2822 insts_size());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2823 if (stub_size () > 0) tty->print_cr(" stub code [" INTPTR_FORMAT "," INTPTR_FORMAT "] = %d",
a61af66fc99e Initial load
duke
parents:
diff changeset
2824 stub_begin(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2825 stub_end(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2826 stub_size());
1563
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
2827 if (oops_size () > 0) tty->print_cr(" oops [" INTPTR_FORMAT "," INTPTR_FORMAT "] = %d",
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
2828 oops_begin(),
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
2829 oops_end(),
1a5913bf5e19 6951083: oops and relocations should part of nmethod not CodeBlob
twisti
parents: 1538
diff changeset
2830 oops_size());
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2831 if (metadata_size () > 0) tty->print_cr(" metadata [" INTPTR_FORMAT "," INTPTR_FORMAT "] = %d",
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2832 metadata_begin(),
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2833 metadata_end(),
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2834 metadata_size());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2835 if (scopes_data_size () > 0) tty->print_cr(" scopes data [" INTPTR_FORMAT "," INTPTR_FORMAT "] = %d",
a61af66fc99e Initial load
duke
parents:
diff changeset
2836 scopes_data_begin(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2837 scopes_data_end(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2838 scopes_data_size());
a61af66fc99e Initial load
duke
parents:
diff changeset
2839 if (scopes_pcs_size () > 0) tty->print_cr(" scopes pcs [" INTPTR_FORMAT "," INTPTR_FORMAT "] = %d",
a61af66fc99e Initial load
duke
parents:
diff changeset
2840 scopes_pcs_begin(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2841 scopes_pcs_end(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2842 scopes_pcs_size());
a61af66fc99e Initial load
duke
parents:
diff changeset
2843 if (dependencies_size () > 0) tty->print_cr(" dependencies [" INTPTR_FORMAT "," INTPTR_FORMAT "] = %d",
a61af66fc99e Initial load
duke
parents:
diff changeset
2844 dependencies_begin(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2845 dependencies_end(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2846 dependencies_size());
a61af66fc99e Initial load
duke
parents:
diff changeset
2847 if (handler_table_size() > 0) tty->print_cr(" handler table [" INTPTR_FORMAT "," INTPTR_FORMAT "] = %d",
a61af66fc99e Initial load
duke
parents:
diff changeset
2848 handler_table_begin(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2849 handler_table_end(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2850 handler_table_size());
a61af66fc99e Initial load
duke
parents:
diff changeset
2851 if (nul_chk_table_size() > 0) tty->print_cr(" nul chk table [" INTPTR_FORMAT "," INTPTR_FORMAT "] = %d",
a61af66fc99e Initial load
duke
parents:
diff changeset
2852 nul_chk_table_begin(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2853 nul_chk_table_end(),
a61af66fc99e Initial load
duke
parents:
diff changeset
2854 nul_chk_table_size());
a61af66fc99e Initial load
duke
parents:
diff changeset
2855 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2856
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
2857 void nmethod::print_code() {
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
2858 HandleMark hm;
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
2859 ResourceMark m;
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
2860 Disassembler::decode(this);
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
2861 }
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
2862
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
2863
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
2864 #ifndef PRODUCT
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2865
a61af66fc99e Initial load
duke
parents:
diff changeset
2866 void nmethod::print_scopes() {
a61af66fc99e Initial load
duke
parents:
diff changeset
2867 // Find the first pc desc for all scopes in the code and print it.
a61af66fc99e Initial load
duke
parents:
diff changeset
2868 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
2869 for (PcDesc* p = scopes_pcs_begin(); p < scopes_pcs_end(); p++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2870 if (p->scope_decode_offset() == DebugInformationRecorder::serialized_null)
a61af66fc99e Initial load
duke
parents:
diff changeset
2871 continue;
a61af66fc99e Initial load
duke
parents:
diff changeset
2872
a61af66fc99e Initial load
duke
parents:
diff changeset
2873 ScopeDesc* sd = scope_desc_at(p->real_pc(this));
a61af66fc99e Initial load
duke
parents:
diff changeset
2874 sd->print_on(tty, p);
a61af66fc99e Initial load
duke
parents:
diff changeset
2875 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2876 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2877
a61af66fc99e Initial load
duke
parents:
diff changeset
2878 void nmethod::print_dependencies() {
a61af66fc99e Initial load
duke
parents:
diff changeset
2879 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
2880 ttyLocker ttyl; // keep the following output all in one block
a61af66fc99e Initial load
duke
parents:
diff changeset
2881 tty->print_cr("Dependencies:");
a61af66fc99e Initial load
duke
parents:
diff changeset
2882 for (Dependencies::DepStream deps(this); deps.next(); ) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2883 deps.print_dependency();
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2884 Klass* ctxk = deps.context_type();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2885 if (ctxk != NULL) {
6983
070d523b96a7 8001471: Klass::cast() does nothing
hseigel
parents: 6940
diff changeset
2886 if (ctxk->oop_is_instance() && ((InstanceKlass*)ctxk)->is_dependent_nmethod(this)) {
070d523b96a7 8001471: Klass::cast() does nothing
hseigel
parents: 6940
diff changeset
2887 tty->print_cr(" [nmethod<=klass]%s", ctxk->external_name());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2888 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2889 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2890 deps.log_dependency(); // put it into the xml log also
a61af66fc99e Initial load
duke
parents:
diff changeset
2891 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2892 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2893
a61af66fc99e Initial load
duke
parents:
diff changeset
2894
a61af66fc99e Initial load
duke
parents:
diff changeset
2895 void nmethod::print_relocations() {
a61af66fc99e Initial load
duke
parents:
diff changeset
2896 ResourceMark m; // in case methods get printed via the debugger
a61af66fc99e Initial load
duke
parents:
diff changeset
2897 tty->print_cr("relocations:");
a61af66fc99e Initial load
duke
parents:
diff changeset
2898 RelocIterator iter(this);
a61af66fc99e Initial load
duke
parents:
diff changeset
2899 iter.print();
a61af66fc99e Initial load
duke
parents:
diff changeset
2900 if (UseRelocIndex) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2901 jint* index_end = (jint*)relocation_end() - 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
2902 jint index_size = *index_end;
a61af66fc99e Initial load
duke
parents:
diff changeset
2903 jint* index_start = (jint*)( (address)index_end - index_size );
a61af66fc99e Initial load
duke
parents:
diff changeset
2904 tty->print_cr(" index @" INTPTR_FORMAT ": index_size=%d", index_start, index_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
2905 if (index_size > 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2906 jint* ip;
a61af66fc99e Initial load
duke
parents:
diff changeset
2907 for (ip = index_start; ip+2 <= index_end; ip += 2)
a61af66fc99e Initial load
duke
parents:
diff changeset
2908 tty->print_cr(" (%d %d) addr=" INTPTR_FORMAT " @" INTPTR_FORMAT,
a61af66fc99e Initial load
duke
parents:
diff changeset
2909 ip[0],
a61af66fc99e Initial load
duke
parents:
diff changeset
2910 ip[1],
a61af66fc99e Initial load
duke
parents:
diff changeset
2911 header_end()+ip[0],
a61af66fc99e Initial load
duke
parents:
diff changeset
2912 relocation_begin()-1+ip[1]);
a61af66fc99e Initial load
duke
parents:
diff changeset
2913 for (; ip < index_end; ip++)
a61af66fc99e Initial load
duke
parents:
diff changeset
2914 tty->print_cr(" (%d ?)", ip[0]);
10973
ef57c43512d6 8014431: cleanup warnings indicated by the -Wunused-value compiler option on linux
ccheung
parents: 10390
diff changeset
2915 tty->print_cr(" @" INTPTR_FORMAT ": index_size=%d", ip, *ip);
ef57c43512d6 8014431: cleanup warnings indicated by the -Wunused-value compiler option on linux
ccheung
parents: 10390
diff changeset
2916 ip++;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2917 tty->print_cr("reloc_end @" INTPTR_FORMAT ":", ip);
a61af66fc99e Initial load
duke
parents:
diff changeset
2918 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2919 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2920 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2921
a61af66fc99e Initial load
duke
parents:
diff changeset
2922
a61af66fc99e Initial load
duke
parents:
diff changeset
2923 void nmethod::print_pcs() {
a61af66fc99e Initial load
duke
parents:
diff changeset
2924 ResourceMark m; // in case methods get printed via debugger
a61af66fc99e Initial load
duke
parents:
diff changeset
2925 tty->print_cr("pc-bytecode offsets:");
a61af66fc99e Initial load
duke
parents:
diff changeset
2926 for (PcDesc* p = scopes_pcs_begin(); p < scopes_pcs_end(); p++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2927 p->print(this);
a61af66fc99e Initial load
duke
parents:
diff changeset
2928 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2929 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2930
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
2931 #endif // PRODUCT
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2932
a61af66fc99e Initial load
duke
parents:
diff changeset
2933 const char* nmethod::reloc_string_for(u_char* begin, u_char* end) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2934 RelocIterator iter(this, begin, end);
a61af66fc99e Initial load
duke
parents:
diff changeset
2935 bool have_one = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
2936 while (iter.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2937 have_one = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
2938 switch (iter.type()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2939 case relocInfo::none: return "no_reloc";
a61af66fc99e Initial load
duke
parents:
diff changeset
2940 case relocInfo::oop_type: {
a61af66fc99e Initial load
duke
parents:
diff changeset
2941 stringStream st;
a61af66fc99e Initial load
duke
parents:
diff changeset
2942 oop_Relocation* r = iter.oop_reloc();
a61af66fc99e Initial load
duke
parents:
diff changeset
2943 oop obj = r->oop_value();
a61af66fc99e Initial load
duke
parents:
diff changeset
2944 st.print("oop(");
a61af66fc99e Initial load
duke
parents:
diff changeset
2945 if (obj == NULL) st.print("NULL");
a61af66fc99e Initial load
duke
parents:
diff changeset
2946 else obj->print_value_on(&st);
a61af66fc99e Initial load
duke
parents:
diff changeset
2947 st.print(")");
a61af66fc99e Initial load
duke
parents:
diff changeset
2948 return st.as_string();
a61af66fc99e Initial load
duke
parents:
diff changeset
2949 }
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2950 case relocInfo::metadata_type: {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2951 stringStream st;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2952 metadata_Relocation* r = iter.metadata_reloc();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2953 Metadata* obj = r->metadata_value();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2954 st.print("metadata(");
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2955 if (obj == NULL) st.print("NULL");
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2956 else obj->print_value_on(&st);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2957 st.print(")");
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2958 return st.as_string();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
2959 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2960 case relocInfo::virtual_call_type: return "virtual_call";
a61af66fc99e Initial load
duke
parents:
diff changeset
2961 case relocInfo::opt_virtual_call_type: return "optimized virtual_call";
a61af66fc99e Initial load
duke
parents:
diff changeset
2962 case relocInfo::static_call_type: return "static_call";
a61af66fc99e Initial load
duke
parents:
diff changeset
2963 case relocInfo::static_stub_type: return "static_stub";
a61af66fc99e Initial load
duke
parents:
diff changeset
2964 case relocInfo::runtime_call_type: return "runtime_call";
a61af66fc99e Initial load
duke
parents:
diff changeset
2965 case relocInfo::external_word_type: return "external_word";
a61af66fc99e Initial load
duke
parents:
diff changeset
2966 case relocInfo::internal_word_type: return "internal_word";
a61af66fc99e Initial load
duke
parents:
diff changeset
2967 case relocInfo::section_word_type: return "section_word";
a61af66fc99e Initial load
duke
parents:
diff changeset
2968 case relocInfo::poll_type: return "poll";
a61af66fc99e Initial load
duke
parents:
diff changeset
2969 case relocInfo::poll_return_type: return "poll_return";
a61af66fc99e Initial load
duke
parents:
diff changeset
2970 case relocInfo::type_mask: return "type_bit_mask";
a61af66fc99e Initial load
duke
parents:
diff changeset
2971 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2972 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2973 return have_one ? "other" : NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2974 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2975
a61af66fc99e Initial load
duke
parents:
diff changeset
2976 // Return a the last scope in (begin..end]
a61af66fc99e Initial load
duke
parents:
diff changeset
2977 ScopeDesc* nmethod::scope_desc_in(address begin, address end) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2978 PcDesc* p = pc_desc_near(begin+1);
a61af66fc99e Initial load
duke
parents:
diff changeset
2979 if (p != NULL && p->real_pc(this) <= end) {
a61af66fc99e Initial load
duke
parents:
diff changeset
2980 return new ScopeDesc(this, p->scope_decode_offset(),
1253
f70b0d9ab095 6910618: C2: Error: assert(d->is_oop(),"JVM_ArrayCopy: dst not an oop")
kvn
parents: 1250
diff changeset
2981 p->obj_decode_offset(), p->should_reexecute(),
f70b0d9ab095 6910618: C2: Error: assert(d->is_oop(),"JVM_ArrayCopy: dst not an oop")
kvn
parents: 1250
diff changeset
2982 p->return_oop());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
2983 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2984 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
2985 }
a61af66fc99e Initial load
duke
parents:
diff changeset
2986
6796
b31471cdc53e 7200163: add CodeComments functionality to assember stubs
kvn
parents: 6792
diff changeset
2987 void nmethod::print_nmethod_labels(outputStream* stream, address block_begin) const {
1155
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
2988 if (block_begin == entry_point()) stream->print_cr("[Entry Point]");
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
2989 if (block_begin == verified_entry_point()) stream->print_cr("[Verified Entry Point]");
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
2990 if (block_begin == exception_begin()) stream->print_cr("[Exception Handler]");
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
2991 if (block_begin == stub_begin()) stream->print_cr("[Stub Code]");
1204
18a389214829 6921352: JSR 292 needs its own deopt handler
twisti
parents: 1202
diff changeset
2992 if (block_begin == deopt_handler_begin()) stream->print_cr("[Deopt Handler Code]");
1691
4a665be40fd3 6975855: don't emit deopt MH handler in C1 if not required
twisti
parents: 1644
diff changeset
2993
4a665be40fd3 6975855: don't emit deopt MH handler in C1 if not required
twisti
parents: 1644
diff changeset
2994 if (has_method_handle_invokes())
4a665be40fd3 6975855: don't emit deopt MH handler in C1 if not required
twisti
parents: 1644
diff changeset
2995 if (block_begin == deopt_mh_handler_begin()) stream->print_cr("[Deopt MH Handler Code]");
4a665be40fd3 6975855: don't emit deopt MH handler in C1 if not required
twisti
parents: 1644
diff changeset
2996
1155
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
2997 if (block_begin == consts_begin()) stream->print_cr("[Constants]");
1691
4a665be40fd3 6975855: don't emit deopt MH handler in C1 if not required
twisti
parents: 1644
diff changeset
2998
1155
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
2999 if (block_begin == entry_point()) {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3000 methodHandle m = method();
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3001 if (m.not_null()) {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3002 stream->print(" # ");
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3003 m->print_value_on(stream);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3004 stream->cr();
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3005 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3006 if (m.not_null() && !is_osr_method()) {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3007 ResourceMark rm;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3008 int sizeargs = m->size_of_parameters();
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3009 BasicType* sig_bt = NEW_RESOURCE_ARRAY(BasicType, sizeargs);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3010 VMRegPair* regs = NEW_RESOURCE_ARRAY(VMRegPair, sizeargs);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3011 {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3012 int sig_index = 0;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3013 if (!m->is_static())
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3014 sig_bt[sig_index++] = T_OBJECT; // 'this'
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3015 for (SignatureStream ss(m->signature()); !ss.at_return_type(); ss.next()) {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3016 BasicType t = ss.type();
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3017 sig_bt[sig_index++] = t;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3018 if (type2size[t] == 2) {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3019 sig_bt[sig_index++] = T_VOID;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3020 } else {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3021 assert(type2size[t] == 1, "size is 1 or 2");
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3022 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3023 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3024 assert(sig_index == sizeargs, "");
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3025 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3026 const char* spname = "sp"; // make arch-specific?
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3027 intptr_t out_preserve = SharedRuntime::java_calling_convention(sig_bt, regs, sizeargs, false);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3028 int stack_slot_offset = this->frame_size() * wordSize;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3029 int tab1 = 14, tab2 = 24;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3030 int sig_index = 0;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3031 int arg_index = (m->is_static() ? 0 : -1);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3032 bool did_old_sp = false;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3033 for (SignatureStream ss(m->signature()); !ss.at_return_type(); ) {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3034 bool at_this = (arg_index == -1);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3035 bool at_old_sp = false;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3036 BasicType t = (at_this ? T_OBJECT : ss.type());
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3037 assert(t == sig_bt[sig_index], "sigs in sync");
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3038 if (at_this)
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3039 stream->print(" # this: ");
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3040 else
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3041 stream->print(" # parm%d: ", arg_index);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3042 stream->move_to(tab1);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3043 VMReg fst = regs[sig_index].first();
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3044 VMReg snd = regs[sig_index].second();
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3045 if (fst->is_reg()) {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3046 stream->print("%s", fst->name());
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3047 if (snd->is_valid()) {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3048 stream->print(":%s", snd->name());
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3049 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3050 } else if (fst->is_stack()) {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3051 int offset = fst->reg2stack() * VMRegImpl::stack_slot_size + stack_slot_offset;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3052 if (offset == stack_slot_offset) at_old_sp = true;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3053 stream->print("[%s+0x%x]", spname, offset);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3054 } else {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3055 stream->print("reg%d:%d??", (int)(intptr_t)fst, (int)(intptr_t)snd);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3056 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3057 stream->print(" ");
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3058 stream->move_to(tab2);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3059 stream->print("= ");
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3060 if (at_this) {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3061 m->method_holder()->print_value_on(stream);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3062 } else {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3063 bool did_name = false;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3064 if (!at_this && ss.is_object()) {
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 2142
diff changeset
3065 Symbol* name = ss.as_symbol_or_null();
1155
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3066 if (name != NULL) {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3067 name->print_value_on(stream);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3068 did_name = true;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3069 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3070 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3071 if (!did_name)
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3072 stream->print("%s", type2name(t));
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3073 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3074 if (at_old_sp) {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3075 stream->print(" (%s of caller)", spname);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3076 did_old_sp = true;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3077 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3078 stream->cr();
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3079 sig_index += type2size[t];
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3080 arg_index += 1;
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3081 if (!at_this) ss.next();
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3082 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3083 if (!did_old_sp) {
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3084 stream->print(" # ");
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3085 stream->move_to(tab1);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3086 stream->print("[%s+0x%x]", spname, stack_slot_offset);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3087 stream->print(" (%s of caller)", spname);
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3088 stream->cr();
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3089 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3090 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3091 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3092 }
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1141
diff changeset
3093
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3094 void nmethod::print_code_comment_on(outputStream* st, int column, u_char* begin, u_char* end) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3095 // First, find an oopmap in (begin, end].
a61af66fc99e Initial load
duke
parents:
diff changeset
3096 // We use the odd half-closed interval so that oop maps and scope descs
a61af66fc99e Initial load
duke
parents:
diff changeset
3097 // which are tied to the byte after a call are printed with the call itself.
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
3098 address base = code_begin();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3099 OopMapSet* oms = oop_maps();
a61af66fc99e Initial load
duke
parents:
diff changeset
3100 if (oms != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3101 for (int i = 0, imax = oms->size(); i < imax; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3102 OopMap* om = oms->at(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
3103 address pc = base + om->offset();
a61af66fc99e Initial load
duke
parents:
diff changeset
3104 if (pc > begin) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3105 if (pc <= end) {
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3106 st->move_to(column);
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3107 st->print("; ");
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3108 om->print_on(st);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3109 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3110 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3111 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3112 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3113 }
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3114
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3115 // Print any debug info present at this pc.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3116 ScopeDesc* sd = scope_desc_in(begin, end);
a61af66fc99e Initial load
duke
parents:
diff changeset
3117 if (sd != NULL) {
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3118 st->move_to(column);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3119 if (sd->bci() == SynchronizationEntryBCI) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3120 st->print(";*synchronization entry");
a61af66fc99e Initial load
duke
parents:
diff changeset
3121 } else {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
3122 if (sd->method() == NULL) {
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3123 st->print("method is NULL");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3124 } else if (sd->method()->is_native()) {
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3125 st->print("method is native");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3126 } else {
2142
8012aa3ccede 4926272: methodOopDesc::method_from_bcp is unsafe
never
parents: 2094
diff changeset
3127 Bytecodes::Code bc = sd->method()->java_code_at(sd->bci());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3128 st->print(";*%s", Bytecodes::name(bc));
a61af66fc99e Initial load
duke
parents:
diff changeset
3129 switch (bc) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3130 case Bytecodes::_invokevirtual:
a61af66fc99e Initial load
duke
parents:
diff changeset
3131 case Bytecodes::_invokespecial:
a61af66fc99e Initial load
duke
parents:
diff changeset
3132 case Bytecodes::_invokestatic:
a61af66fc99e Initial load
duke
parents:
diff changeset
3133 case Bytecodes::_invokeinterface:
a61af66fc99e Initial load
duke
parents:
diff changeset
3134 {
2142
8012aa3ccede 4926272: methodOopDesc::method_from_bcp is unsafe
never
parents: 2094
diff changeset
3135 Bytecode_invoke invoke(sd->method(), sd->bci());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3136 st->print(" ");
2142
8012aa3ccede 4926272: methodOopDesc::method_from_bcp is unsafe
never
parents: 2094
diff changeset
3137 if (invoke.name() != NULL)
8012aa3ccede 4926272: methodOopDesc::method_from_bcp is unsafe
never
parents: 2094
diff changeset
3138 invoke.name()->print_symbol_on(st);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3139 else
a61af66fc99e Initial load
duke
parents:
diff changeset
3140 st->print("<UNKNOWN>");
a61af66fc99e Initial load
duke
parents:
diff changeset
3141 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3142 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3143 case Bytecodes::_getfield:
a61af66fc99e Initial load
duke
parents:
diff changeset
3144 case Bytecodes::_putfield:
a61af66fc99e Initial load
duke
parents:
diff changeset
3145 case Bytecodes::_getstatic:
a61af66fc99e Initial load
duke
parents:
diff changeset
3146 case Bytecodes::_putstatic:
a61af66fc99e Initial load
duke
parents:
diff changeset
3147 {
2142
8012aa3ccede 4926272: methodOopDesc::method_from_bcp is unsafe
never
parents: 2094
diff changeset
3148 Bytecode_field field(sd->method(), sd->bci());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3149 st->print(" ");
2142
8012aa3ccede 4926272: methodOopDesc::method_from_bcp is unsafe
never
parents: 2094
diff changeset
3150 if (field.name() != NULL)
8012aa3ccede 4926272: methodOopDesc::method_from_bcp is unsafe
never
parents: 2094
diff changeset
3151 field.name()->print_symbol_on(st);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3152 else
a61af66fc99e Initial load
duke
parents:
diff changeset
3153 st->print("<UNKNOWN>");
a61af66fc99e Initial load
duke
parents:
diff changeset
3154 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3155 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3156 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3157 }
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3158
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3159 // Print all scopes
a61af66fc99e Initial load
duke
parents:
diff changeset
3160 for (;sd != NULL; sd = sd->sender()) {
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3161 st->move_to(column);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3162 st->print("; -");
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6266
diff changeset
3163 if (sd->method() == NULL) {
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3164 st->print("method is NULL");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3165 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
3166 sd->method()->print_short_name(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
3167 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3168 int lineno = sd->method()->line_number_from_bci(sd->bci());
a61af66fc99e Initial load
duke
parents:
diff changeset
3169 if (lineno != -1) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3170 st->print("@%d (line %d)", sd->bci(), lineno);
a61af66fc99e Initial load
duke
parents:
diff changeset
3171 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
3172 st->print("@%d", sd->bci());
a61af66fc99e Initial load
duke
parents:
diff changeset
3173 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3174 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
3175 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3176 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3177
a61af66fc99e Initial load
duke
parents:
diff changeset
3178 // Print relocation information
a61af66fc99e Initial load
duke
parents:
diff changeset
3179 const char* str = reloc_string_for(begin, end);
a61af66fc99e Initial load
duke
parents:
diff changeset
3180 if (str != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3181 if (sd != NULL) st->cr();
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3182 st->move_to(column);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3183 st->print("; {%s}", str);
a61af66fc99e Initial load
duke
parents:
diff changeset
3184 }
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
3185 int cont_offset = ImplicitExceptionTable(this).at(begin - code_begin());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3186 if (cont_offset != 0) {
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3187 st->move_to(column);
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
3188 st->print("; implicit exception: dispatches to " INTPTR_FORMAT, code_begin() + cont_offset);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3189 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3190
a61af66fc99e Initial load
duke
parents:
diff changeset
3191 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3192
100
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3193 #ifndef PRODUCT
c7c777385a15 6667042: PrintAssembly option does not work without special plugin
jrose
parents: 30
diff changeset
3194
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3195 void nmethod::print_value_on(outputStream* st) const {
2405
3d58a4983660 7022998: JSR 292 recursive method handle calls inline themselves infinitely
twisti
parents: 2376
diff changeset
3196 st->print("nmethod");
3d58a4983660 7022998: JSR 292 recursive method handle calls inline themselves infinitely
twisti
parents: 2376
diff changeset
3197 print_on(st, NULL);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3198 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3199
a61af66fc99e Initial load
duke
parents:
diff changeset
3200 void nmethod::print_calls(outputStream* st) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3201 RelocIterator iter(this);
a61af66fc99e Initial load
duke
parents:
diff changeset
3202 while (iter.next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3203 switch (iter.type()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
3204 case relocInfo::virtual_call_type:
a61af66fc99e Initial load
duke
parents:
diff changeset
3205 case relocInfo::opt_virtual_call_type: {
a61af66fc99e Initial load
duke
parents:
diff changeset
3206 VerifyMutexLocker mc(CompiledIC_lock);
20277
882004b9e7e1 8047362: Add a version of CompiledIC_at that doesn't create a new RelocIterator
stefank
parents: 20269
diff changeset
3207 CompiledIC_at(&iter)->print();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3208 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3209 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3210 case relocInfo::static_call_type:
a61af66fc99e Initial load
duke
parents:
diff changeset
3211 st->print_cr("Static call at " INTPTR_FORMAT, iter.reloc()->addr());
a61af66fc99e Initial load
duke
parents:
diff changeset
3212 compiledStaticCall_at(iter.reloc())->print();
a61af66fc99e Initial load
duke
parents:
diff changeset
3213 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
3214 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3215 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3216 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3217
a61af66fc99e Initial load
duke
parents:
diff changeset
3218 void nmethod::print_handler_table() {
a61af66fc99e Initial load
duke
parents:
diff changeset
3219 ExceptionHandlerTable(this).print();
a61af66fc99e Initial load
duke
parents:
diff changeset
3220 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3221
a61af66fc99e Initial load
duke
parents:
diff changeset
3222 void nmethod::print_nul_chk_table() {
1748
3e8fbc61cee8 6978355: renaming for 6961697
twisti
parents: 1726
diff changeset
3223 ImplicitExceptionTable(this).print(code_begin());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3224 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3225
a61af66fc99e Initial load
duke
parents:
diff changeset
3226 void nmethod::print_statistics() {
a61af66fc99e Initial load
duke
parents:
diff changeset
3227 ttyLocker ttyl;
a61af66fc99e Initial load
duke
parents:
diff changeset
3228 if (xtty != NULL) xtty->head("statistics type='nmethod'");
a61af66fc99e Initial load
duke
parents:
diff changeset
3229 nmethod_stats.print_native_nmethod_stats();
a61af66fc99e Initial load
duke
parents:
diff changeset
3230 nmethod_stats.print_nmethod_stats();
a61af66fc99e Initial load
duke
parents:
diff changeset
3231 DebugInformationRecorder::print_statistics();
a61af66fc99e Initial load
duke
parents:
diff changeset
3232 nmethod_stats.print_pc_stats();
a61af66fc99e Initial load
duke
parents:
diff changeset
3233 Dependencies::print_statistics();
a61af66fc99e Initial load
duke
parents:
diff changeset
3234 if (xtty != NULL) xtty->tail("statistics");
a61af66fc99e Initial load
duke
parents:
diff changeset
3235 }
a61af66fc99e Initial load
duke
parents:
diff changeset
3236
a61af66fc99e Initial load
duke
parents:
diff changeset
3237 #endif // PRODUCT