Mercurial > hg > truffle
annotate src/share/vm/runtime/init.cpp @ 9126:bc26f978b0ce
HotSpotResolvedObjectType: implement hasFinalizeSubclass() correctly
don't use the (wrong) cached value, but ask the runtime on each request.
Fixes regression on xml.* benchmarks @ specjvm2008. The problem was:
After the constructor of Object was deoptimized due to an assumption violation,
it was recompiled again after some time. However, on recompilation, the value
of hasFinalizeSubclass for the class was not updated and it was compiled again
with a, now wrong, assumption, which then triggers deoptimization again.
This was repeated until it hit the recompilation limit (defined by
PerMethodRecompilationCutoff), and therefore only executed by the interpreter
from now on, causing the performance regression.
author | Bernhard Urban <bernhard.urban@jku.at> |
---|---|
date | Mon, 15 Apr 2013 19:54:58 +0200 |
parents | b9a918201d47 |
children | 58fc8e2b7b6d |
rev | line source |
---|---|
0 | 1 /* |
4872
aa3d708d67c4
7141200: log some interesting information in ring buffers for crashes
never
parents:
4773
diff
changeset
|
2 * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. |
0 | 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 * | |
5 * This code is free software; you can redistribute it and/or modify it | |
6 * under the terms of the GNU General Public License version 2 only, as | |
7 * published by the Free Software Foundation. | |
8 * | |
9 * This code is distributed in the hope that it will be useful, but WITHOUT | |
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
12 * version 2 for more details (a copy is included in the LICENSE file that | |
13 * accompanied this code). | |
14 * | |
15 * You should have received a copy of the GNU General Public License version | |
16 * 2 along with this work; if not, write to the Free Software Foundation, | |
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. | |
18 * | |
1552
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1299
diff
changeset
|
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1299
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:
1299
diff
changeset
|
21 * questions. |
0 | 22 * |
23 */ | |
24 | |
1972 | 25 #include "precompiled.hpp" |
6162 | 26 #include "classfile/symbolTable.hpp" |
1972 | 27 #include "code/icBuffer.hpp" |
28 #include "gc_interface/collectedHeap.hpp" | |
29 #include "interpreter/bytecodes.hpp" | |
30 #include "memory/universe.hpp" | |
31 #include "prims/methodHandles.hpp" | |
32 #include "runtime/handles.inline.hpp" | |
33 #include "runtime/icache.hpp" | |
34 #include "runtime/init.hpp" | |
35 #include "runtime/safepoint.hpp" | |
36 #include "runtime/sharedRuntime.hpp" | |
8001
db9981fd3124
8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents:
6854
diff
changeset
|
37 #include "utilities/macros.hpp" |
0 | 38 |
39 // Initialization done by VM thread in vm_init_globals() | |
40 void check_ThreadShadow(); | |
41 void eventlog_init(); | |
42 void mutex_init(); | |
43 void chunkpool_init(); | |
44 void perfMemory_init(); | |
45 | |
46 // Initialization done by Java thread in init_globals() | |
47 void management_init(); | |
48 void bytecodes_init(); | |
49 void classLoader_init(); | |
50 void codeCache_init(); | |
51 void VM_Version_init(); | |
4749
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2088
diff
changeset
|
52 void os_init_globals(); // depends on VM_Version_init, before universe_init |
0 | 53 void stubRoutines_init1(); |
4749
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2088
diff
changeset
|
54 jint universe_init(); // depends on codeCache_init and stubRoutines_init |
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2088
diff
changeset
|
55 void interpreter_init(); // before any methods loaded |
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2088
diff
changeset
|
56 void invocationCounter_init(); // before any methods loaded |
0 | 57 void marksweep_init(); |
58 void accessFlags_init(); | |
59 void templateTable_init(); | |
60 void InterfaceSupport_init(); | |
4749
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2088
diff
changeset
|
61 void universe2_init(); // dependent on codeCache_init and stubRoutines_init, loads primordial classes |
0 | 62 void referenceProcessor_init(); |
63 void jni_handles_init(); | |
64 void vmStructs_init(); | |
65 | |
66 void vtableStubs_init(); | |
67 void InlineCacheBuffer_init(); | |
68 void compilerOracle_init(); | |
69 void compilationPolicy_init(); | |
4872
aa3d708d67c4
7141200: log some interesting information in ring buffers for crashes
never
parents:
4773
diff
changeset
|
70 void compileBroker_init(); |
0 | 71 |
72 // Initialization after compiler initialization | |
73 bool universe_post_init(); // must happen after compiler_init | |
74 void javaClasses_init(); // must happen after vtable initialization | |
75 void stubRoutines_init2(); // note: StubRoutines need 2-phase init | |
76 | |
77 // Do not disable thread-local-storage, as it is important for some | |
78 // JNI/JVM/JVMTI functions and signal handlers to work properly | |
79 // during VM shutdown | |
80 void perfMemory_exit(); | |
81 void ostream_exit(); | |
82 | |
83 void vm_init_globals() { | |
84 check_ThreadShadow(); | |
113
ba764ed4b6f2
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
0
diff
changeset
|
85 basic_types_init(); |
0 | 86 eventlog_init(); |
87 mutex_init(); | |
88 chunkpool_init(); | |
89 perfMemory_init(); | |
90 } | |
91 | |
92 | |
93 jint init_globals() { | |
94 HandleMark hm; | |
95 management_init(); | |
96 bytecodes_init(); | |
97 classLoader_init(); | |
6725
da91efe96a93
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
6162
diff
changeset
|
98 Metaspace::global_initialize(); // must be before codeCache |
0 | 99 codeCache_init(); |
100 VM_Version_init(); | |
4749
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2088
diff
changeset
|
101 os_init_globals(); |
0 | 102 stubRoutines_init1(); |
4749
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2088
diff
changeset
|
103 jint status = universe_init(); // dependent on codeCache_init and |
6725
da91efe96a93
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
6162
diff
changeset
|
104 // stubRoutines_init1 and metaspace_init. |
0 | 105 if (status != JNI_OK) |
106 return status; | |
107 | |
108 interpreter_init(); // before any methods loaded | |
109 invocationCounter_init(); // before any methods loaded | |
110 marksweep_init(); | |
111 accessFlags_init(); | |
112 templateTable_init(); | |
113 InterfaceSupport_init(); | |
114 SharedRuntime::generate_stubs(); | |
4749
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2088
diff
changeset
|
115 universe2_init(); // dependent on codeCache_init and stubRoutines_init1 |
0 | 116 referenceProcessor_init(); |
117 jni_handles_init(); | |
6854
fb19af007ffc
7189254: Change makefiles for more flexibility to override defaults
jprovino
parents:
6725
diff
changeset
|
118 #if INCLUDE_VM_STRUCTS |
0 | 119 vmStructs_init(); |
6854
fb19af007ffc
7189254: Change makefiles for more flexibility to override defaults
jprovino
parents:
6725
diff
changeset
|
120 #endif // INCLUDE_VM_STRUCTS |
0 | 121 |
122 vtableStubs_init(); | |
123 InlineCacheBuffer_init(); | |
124 compilerOracle_init(); | |
125 compilationPolicy_init(); | |
4872
aa3d708d67c4
7141200: log some interesting information in ring buffers for crashes
never
parents:
4773
diff
changeset
|
126 compileBroker_init(); |
0 | 127 VMRegImpl::set_regName(); |
128 | |
129 if (!universe_post_init()) { | |
130 return JNI_ERR; | |
131 } | |
4749
7ab5f6318694
7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents:
2088
diff
changeset
|
132 javaClasses_init(); // must happen after vtable initialization |
0 | 133 stubRoutines_init2(); // note: StubRoutines need 2-phase init |
134 | |
1730
f55c4f82ab9d
6978249: spill between cpu and fpu registers when those moves are fast
never
parents:
1644
diff
changeset
|
135 // All the flags that get adjusted by VM_Version_init and os::init_2 |
f55c4f82ab9d
6978249: spill between cpu and fpu registers when those moves are fast
never
parents:
1644
diff
changeset
|
136 // have been set so dump the flags now. |
f55c4f82ab9d
6978249: spill between cpu and fpu registers when those moves are fast
never
parents:
1644
diff
changeset
|
137 if (PrintFlagsFinal) { |
4773 | 138 CommandLineFlags::printFlags(tty, false); |
1730
f55c4f82ab9d
6978249: spill between cpu and fpu registers when those moves are fast
never
parents:
1644
diff
changeset
|
139 } |
f55c4f82ab9d
6978249: spill between cpu and fpu registers when those moves are fast
never
parents:
1644
diff
changeset
|
140 |
0 | 141 return JNI_OK; |
142 } | |
143 | |
144 | |
145 void exit_globals() { | |
146 static bool destructorsCalled = false; | |
147 if (!destructorsCalled) { | |
148 destructorsCalled = true; | |
149 perfMemory_exit(); | |
150 if (PrintSafepointStatistics) { | |
151 // Print the collected safepoint statistics. | |
152 SafepointSynchronize::print_stat_on_exit(); | |
153 } | |
6162 | 154 if (PrintStringTableStatistics) { |
155 SymbolTable::dump(tty); | |
156 StringTable::dump(tty); | |
157 } | |
0 | 158 ostream_exit(); |
159 } | |
160 } | |
161 | |
162 | |
163 static bool _init_completed = false; | |
164 | |
165 bool is_init_completed() { | |
166 return _init_completed; | |
167 } | |
168 | |
169 | |
170 void set_init_completed() { | |
1959
9eecf81a02fb
7000578: CMS: assert(SafepointSynchronize::is_at_safepoint()) failed: Else races are possible
ysr
parents:
1730
diff
changeset
|
171 assert(Universe::is_fully_initialized(), "Should have completed initialization"); |
0 | 172 _init_completed = true; |
173 } |