Mercurial > hg > graal-compiler
annotate src/share/vm/graal/graalRuntime.cpp @ 19605:15ef24874df7
Add assertion to ObjectValue conversion
author | Tom Rodriguez <tom.rodriguez@oracle.com> |
---|---|
date | Wed, 25 Feb 2015 19:13:16 -0800 |
parents | 9c2396ef02db |
children | 7366593c0610 |
rev | line source |
---|---|
7221 | 1 /* |
2 * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. | |
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 * | |
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA | |
20 * or visit www.oracle.com if you need additional information or have any | |
21 * questions. | |
22 */ | |
23 | |
24 #include "precompiled.hpp" | |
7735 | 25 #include "asm/codeBuffer.hpp" |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
26 #include "compiler/compileBroker.hpp" |
17033
2d6dd2eebd51
Fixed HSAIL deopt
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
16887
diff
changeset
|
27 #include "compiler/disassembler.hpp" |
7221 | 28 #include "graal/graalRuntime.hpp" |
15582
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
29 #include "graal/graalCompilerToVM.hpp" |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
30 #include "graal/graalCompiler.hpp" |
15582
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
31 #include "graal/graalJavaAccess.hpp" |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
32 #include "graal/graalEnv.hpp" |
7735 | 33 #include "memory/oopFactory.hpp" |
34 #include "prims/jvm.h" | |
7221 | 35 #include "runtime/biasedLocking.hpp" |
7735 | 36 #include "runtime/interfaceSupport.hpp" |
15582
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
37 #include "runtime/arguments.hpp" |
10542
554f67e4ff3f
Use slow-path stub call instead of deopt in lowering of DynamicNewArrayNode.
Roland Schatz <roland.schatz@oracle.com>
parents:
10475
diff
changeset
|
38 #include "runtime/reflection.hpp" |
8499
96a337d307bd
-More progress in G1 WBs
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
8496
diff
changeset
|
39 #include "utilities/debug.hpp" |
7221 | 40 |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
41 jobject GraalRuntime::_HotSpotGraalRuntime_instance = NULL; |
16683
4d0d1dc5db00
introduce extra field to record when HotSpotGraalRuntime has been initialized to avoid spurious errors during VM shutdown for short lived applications
Doug Simon <doug.simon@oracle.com>
parents:
16679
diff
changeset
|
42 bool GraalRuntime::_HotSpotGraalRuntime_initialized = false; |
18303
ab47ef2f2207
disable blocking compilation requests once GraalRuntime::shutdown has been called
Doug Simon <doug.simon@oracle.com>
parents:
18227
diff
changeset
|
43 bool GraalRuntime::_shutdown_called = false; |
15582
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
44 |
15603
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
45 void GraalRuntime::initialize_natives(JNIEnv *env, jclass c2vmClass) { |
15582
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
46 uintptr_t heap_end = (uintptr_t) Universe::heap()->reserved_region().end(); |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
47 uintptr_t allocation_end = heap_end + ((uintptr_t)16) * 1024 * 1024 * 1024; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
48 AMD64_ONLY(guarantee(heap_end < allocation_end, "heap end too close to end of address space (might lead to erroneous TLAB allocations)")); |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
49 NOT_LP64(error("check TLAB allocation code for address space conflicts")); |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
50 |
18614
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
51 ensure_graal_class_loader_is_initialized(); |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
52 |
15582
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
53 JavaThread* THREAD = JavaThread::current(); |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
54 { |
15603
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
55 ThreadToNativeFromVM trans(THREAD); |
15582
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
56 |
15603
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
57 ResourceMark rm; |
15582
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
58 HandleMark hm; |
15603
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
59 |
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
60 graal_compute_offsets(); |
15582
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
61 |
15603
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
62 // Ensure _non_oop_bits is initialized |
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
63 Universe::non_oop_word(); |
15582
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
64 |
15603
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
65 env->RegisterNatives(c2vmClass, CompilerToVM_methods, CompilerToVM_methods_count()); |
15582
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
66 } |
16428
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
67 if (HAS_PENDING_EXCEPTION) { |
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
68 abort_on_pending_exception(PENDING_EXCEPTION, "Could not register natives"); |
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
69 } |
15582
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
70 } |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
71 |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
72 BufferBlob* GraalRuntime::initialize_buffer_blob() { |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
73 JavaThread* THREAD = JavaThread::current(); |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
74 BufferBlob* buffer_blob = THREAD->get_buffer_blob(); |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
75 if (buffer_blob == NULL) { |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
76 buffer_blob = BufferBlob::create("Graal thread-local CodeBuffer", GraalNMethodSizeLimit); |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
77 if (buffer_blob != NULL) { |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
78 THREAD->set_buffer_blob(buffer_blob); |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
79 } |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
80 } |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
81 return buffer_blob; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
82 } |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
83 |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
84 BasicType GraalRuntime::kindToBasicType(jchar ch) { |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
85 switch(ch) { |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
86 case 'z': return T_BOOLEAN; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
87 case 'b': return T_BYTE; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
88 case 's': return T_SHORT; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
89 case 'c': return T_CHAR; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
90 case 'i': return T_INT; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
91 case 'f': return T_FLOAT; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
92 case 'j': return T_LONG; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
93 case 'd': return T_DOUBLE; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
94 case 'a': return T_OBJECT; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
95 case '-': return T_ILLEGAL; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
96 default: |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
97 fatal(err_msg("unexpected Kind: %c", ch)); |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
98 break; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
99 } |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
100 return T_ILLEGAL; |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
101 } |
063ec2920d21
made Graal runtime initialization in hosted mode lazy
Doug Simon <doug.simon@oracle.com>
parents:
14731
diff
changeset
|
102 |
7221 | 103 // Simple helper to see if the caller of a runtime stub which |
104 // entered the VM has been deoptimized | |
105 | |
106 static bool caller_is_deopted() { | |
107 JavaThread* thread = JavaThread::current(); | |
108 RegisterMap reg_map(thread, false); | |
109 frame runtime_frame = thread->last_frame(); | |
110 frame caller_frame = runtime_frame.sender(®_map); | |
111 assert(caller_frame.is_compiled_frame(), "must be compiled"); | |
112 return caller_frame.is_deoptimized_frame(); | |
113 } | |
114 | |
115 // Stress deoptimization | |
116 static void deopt_caller() { | |
117 if ( !caller_is_deopted()) { | |
118 JavaThread* thread = JavaThread::current(); | |
119 RegisterMap reg_map(thread, false); | |
120 frame runtime_frame = thread->last_frame(); | |
121 frame caller_frame = runtime_frame.sender(®_map); | |
122 Deoptimization::deoptimize_frame(thread, caller_frame.id(), Deoptimization::Reason_constraint); | |
123 assert(caller_is_deopted(), "Must be deoptimized"); | |
124 } | |
125 } | |
126 | |
12433
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
127 JRT_BLOCK_ENTRY(void, GraalRuntime::new_instance(JavaThread* thread, Klass* klass)) |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
128 JRT_BLOCK; |
7221 | 129 assert(klass->is_klass(), "not a class"); |
130 instanceKlassHandle h(thread, klass); | |
131 h->check_valid_for_instantiation(true, CHECK); | |
132 // make sure klass is initialized | |
133 h->initialize(CHECK); | |
134 // allocate instance and return via TLS | |
135 oop obj = h->allocate_instance(CHECK); | |
12433
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
136 thread->set_vm_result(obj); |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
137 JRT_BLOCK_END; |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
138 |
12366
0991c12c4186
Defer barriers upon slow-path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10953
diff
changeset
|
139 if (GraalDeferredInitBarriers) { |
12433
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
140 new_store_pre_barrier(thread); |
12366
0991c12c4186
Defer barriers upon slow-path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10953
diff
changeset
|
141 } |
7221 | 142 JRT_END |
143 | |
12433
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
144 JRT_BLOCK_ENTRY(void, GraalRuntime::new_array(JavaThread* thread, Klass* array_klass, jint length)) |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
145 JRT_BLOCK; |
7221 | 146 // Note: no handle for klass needed since they are not used |
147 // anymore after new_objArray() and no GC can happen before. | |
148 // (This may have to change if this code changes!) | |
149 assert(array_klass->is_klass(), "not a class"); | |
150 oop obj; | |
151 if (array_klass->oop_is_typeArray()) { | |
152 BasicType elt_type = TypeArrayKlass::cast(array_klass)->element_type(); | |
153 obj = oopFactory::new_typeArray(elt_type, length, CHECK); | |
154 } else { | |
155 Klass* elem_klass = ObjArrayKlass::cast(array_klass)->element_klass(); | |
156 obj = oopFactory::new_objArray(elem_klass, length, CHECK); | |
157 } | |
158 thread->set_vm_result(obj); | |
159 // This is pretty rare but this runtime patch is stressful to deoptimization | |
160 // if we deoptimize here so force a deopt to stress the path. | |
161 if (DeoptimizeALot) { | |
9338
0266549ff6e0
added support from compiled stubs to be installed as RuntimeStubs and to be able to directly call C/C++ runtime functions (GRAAL-81)
Doug Simon <doug.simon@oracle.com>
parents:
9232
diff
changeset
|
162 static int deopts = 0; |
0266549ff6e0
added support from compiled stubs to be installed as RuntimeStubs and to be able to directly call C/C++ runtime functions (GRAAL-81)
Doug Simon <doug.simon@oracle.com>
parents:
9232
diff
changeset
|
163 // Alternate between deoptimizing and raising an error (which will also cause a deopt) |
0266549ff6e0
added support from compiled stubs to be installed as RuntimeStubs and to be able to directly call C/C++ runtime functions (GRAAL-81)
Doug Simon <doug.simon@oracle.com>
parents:
9232
diff
changeset
|
164 if (deopts++ % 2 == 0) { |
0266549ff6e0
added support from compiled stubs to be installed as RuntimeStubs and to be able to directly call C/C++ runtime functions (GRAAL-81)
Doug Simon <doug.simon@oracle.com>
parents:
9232
diff
changeset
|
165 ResourceMark rm(THREAD); |
0266549ff6e0
added support from compiled stubs to be installed as RuntimeStubs and to be able to directly call C/C++ runtime functions (GRAAL-81)
Doug Simon <doug.simon@oracle.com>
parents:
9232
diff
changeset
|
166 THROW(vmSymbols::java_lang_OutOfMemoryError()); |
0266549ff6e0
added support from compiled stubs to be installed as RuntimeStubs and to be able to directly call C/C++ runtime functions (GRAAL-81)
Doug Simon <doug.simon@oracle.com>
parents:
9232
diff
changeset
|
167 } else { |
0266549ff6e0
added support from compiled stubs to be installed as RuntimeStubs and to be able to directly call C/C++ runtime functions (GRAAL-81)
Doug Simon <doug.simon@oracle.com>
parents:
9232
diff
changeset
|
168 deopt_caller(); |
0266549ff6e0
added support from compiled stubs to be installed as RuntimeStubs and to be able to directly call C/C++ runtime functions (GRAAL-81)
Doug Simon <doug.simon@oracle.com>
parents:
9232
diff
changeset
|
169 } |
7221 | 170 } |
12433
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
171 JRT_BLOCK_END; |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
172 |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
173 if (GraalDeferredInitBarriers) { |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
174 new_store_pre_barrier(thread); |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
175 } |
9338
0266549ff6e0
added support from compiled stubs to be installed as RuntimeStubs and to be able to directly call C/C++ runtime functions (GRAAL-81)
Doug Simon <doug.simon@oracle.com>
parents:
9232
diff
changeset
|
176 JRT_END |
7221 | 177 |
12433
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
178 void GraalRuntime::new_store_pre_barrier(JavaThread* thread) { |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
179 // After any safepoint, just before going back to compiled code, |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
180 // we inform the GC that we will be doing initializing writes to |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
181 // this object in the future without emitting card-marks, so |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
182 // GC may take any compensating steps. |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
183 // NOTE: Keep this code consistent with GraphKit::store_barrier. |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
184 |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
185 oop new_obj = thread->vm_result(); |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
186 if (new_obj == NULL) return; |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
187 |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
188 assert(Universe::heap()->can_elide_tlab_store_barriers(), |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
189 "compiler must check this first"); |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
190 // GC may decide to give back a safer copy of new_obj. |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
191 new_obj = Universe::heap()->new_store_pre_barrier(thread, new_obj); |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
192 thread->set_vm_result(new_obj); |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
193 } |
808348377021
Fix inconsistent oops in slow path allocation
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
12372
diff
changeset
|
194 |
7221 | 195 JRT_ENTRY(void, GraalRuntime::new_multi_array(JavaThread* thread, Klass* klass, int rank, jint* dims)) |
196 assert(klass->is_klass(), "not a class"); | |
197 assert(rank >= 1, "rank must be nonzero"); | |
198 oop obj = ArrayKlass::cast(klass)->multi_allocate(rank, dims, CHECK); | |
199 thread->set_vm_result(obj); | |
200 JRT_END | |
201 | |
12423
370b5f07f9e2
The runtime entries need to use oopDesc* rather than oop in their signature
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12372
diff
changeset
|
202 JRT_ENTRY(void, GraalRuntime::dynamic_new_array(JavaThread* thread, oopDesc* element_mirror, jint length)) |
10542
554f67e4ff3f
Use slow-path stub call instead of deopt in lowering of DynamicNewArrayNode.
Roland Schatz <roland.schatz@oracle.com>
parents:
10475
diff
changeset
|
203 oop obj = Reflection::reflect_new_array(element_mirror, length, CHECK); |
554f67e4ff3f
Use slow-path stub call instead of deopt in lowering of DynamicNewArrayNode.
Roland Schatz <roland.schatz@oracle.com>
parents:
10475
diff
changeset
|
204 thread->set_vm_result(obj); |
554f67e4ff3f
Use slow-path stub call instead of deopt in lowering of DynamicNewArrayNode.
Roland Schatz <roland.schatz@oracle.com>
parents:
10475
diff
changeset
|
205 JRT_END |
554f67e4ff3f
Use slow-path stub call instead of deopt in lowering of DynamicNewArrayNode.
Roland Schatz <roland.schatz@oracle.com>
parents:
10475
diff
changeset
|
206 |
13578
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
207 JRT_ENTRY(void, GraalRuntime::dynamic_new_instance(JavaThread* thread, oopDesc* type_mirror)) |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
208 instanceKlassHandle klass(THREAD, java_lang_Class::as_Klass(type_mirror)); |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
209 |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
210 if (klass == NULL) { |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
211 ResourceMark rm(THREAD); |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
212 THROW(vmSymbols::java_lang_InstantiationException()); |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
213 } |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
214 |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
215 // Create new instance (the receiver) |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
216 klass->check_valid_for_instantiation(false, CHECK); |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
217 |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
218 // Make sure klass gets initialized |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
219 klass->initialize(CHECK); |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
220 |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
221 oop obj = klass->allocate_instance(CHECK); |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
222 thread->set_vm_result(obj); |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
223 JRT_END |
d8143c431d63
Add DynamicNewInstanceNode and use it to intrinsify Unsafe.allocateInstance
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12668
diff
changeset
|
224 |
7221 | 225 extern void vm_exit(int code); |
226 | |
227 // Enter this method from compiled code handler below. This is where we transition | |
228 // to VM mode. This is done as a helper routine so that the method called directly | |
229 // from compiled code does not have to transition to VM. This allows the entry | |
230 // method to see if the nmethod that we have just looked up a handler for has | |
231 // been deoptimized while we were in the vm. This simplifies the assembly code | |
232 // cpu directories. | |
233 // | |
234 // We are entering here from exception stub (via the entry method below) | |
235 // If there is a compiled exception handler in this method, we will continue there; | |
236 // otherwise we will unwind the stack and continue at the caller of top frame method | |
237 // Note: we enter in Java using a special JRT wrapper. This wrapper allows us to | |
238 // control the area where we can allow a safepoint. After we exit the safepoint area we can | |
239 // check to see if the handler we are going to return is now in a nmethod that has | |
240 // been deoptimized. If that is the case we return the deopt blob | |
241 // unpack_with_exception entry instead. This makes life for the exception blob easier | |
242 // because making that same check and diverting is painful from assembly language. | |
243 JRT_ENTRY_NO_ASYNC(static address, exception_handler_for_pc_helper(JavaThread* thread, oopDesc* ex, address pc, nmethod*& nm)) | |
244 // Reset method handle flag. | |
245 thread->set_is_method_handle_return(false); | |
246 | |
247 Handle exception(thread, ex); | |
248 nm = CodeCache::find_nmethod(pc); | |
249 assert(nm != NULL, "this is not an nmethod"); | |
250 // Adjust the pc as needed/ | |
251 if (nm->is_deopt_pc(pc)) { | |
252 RegisterMap map(thread, false); | |
253 frame exception_frame = thread->last_frame().sender(&map); | |
254 // if the frame isn't deopted then pc must not correspond to the caller of last_frame | |
255 assert(exception_frame.is_deoptimized_frame(), "must be deopted"); | |
256 pc = exception_frame.pc(); | |
257 } | |
258 #ifdef ASSERT | |
259 assert(exception.not_null(), "NULL exceptions should be handled by throw_exception"); | |
260 assert(exception->is_oop(), "just checking"); | |
261 // Check that exception is a subclass of Throwable, otherwise we have a VerifyError | |
262 if (!(exception->is_a(SystemDictionary::Throwable_klass()))) { | |
263 if (ExitVMOnVerifyError) vm_exit(-1); | |
264 ShouldNotReachHere(); | |
265 } | |
266 #endif | |
267 | |
268 // Check the stack guard pages and reenable them if necessary and there is | |
269 // enough space on the stack to do so. Use fast exceptions only if the guard | |
270 // pages are enabled. | |
271 bool guard_pages_enabled = thread->stack_yellow_zone_enabled(); | |
272 if (!guard_pages_enabled) guard_pages_enabled = thread->reguard_stack(); | |
273 | |
274 if (JvmtiExport::can_post_on_exceptions()) { | |
275 // To ensure correct notification of exception catches and throws | |
276 // we have to deoptimize here. If we attempted to notify the | |
277 // catches and throws during this exception lookup it's possible | |
278 // we could deoptimize on the way out of the VM and end back in | |
279 // the interpreter at the throw site. This would result in double | |
280 // notifications since the interpreter would also notify about | |
281 // these same catches and throws as it unwound the frame. | |
282 | |
283 RegisterMap reg_map(thread); | |
284 frame stub_frame = thread->last_frame(); | |
285 frame caller_frame = stub_frame.sender(®_map); | |
286 | |
287 // We don't really want to deoptimize the nmethod itself since we | |
288 // can actually continue in the exception handler ourselves but I | |
289 // don't see an easy way to have the desired effect. | |
290 Deoptimization::deoptimize_frame(thread, caller_frame.id(), Deoptimization::Reason_constraint); | |
291 assert(caller_is_deopted(), "Must be deoptimized"); | |
292 | |
293 return SharedRuntime::deopt_blob()->unpack_with_exception_in_tls(); | |
294 } | |
295 | |
296 // ExceptionCache is used only for exceptions at call sites and not for implicit exceptions | |
297 if (guard_pages_enabled) { | |
298 address fast_continuation = nm->handler_for_exception_and_pc(exception, pc); | |
299 if (fast_continuation != NULL) { | |
300 // Set flag if return address is a method handle call site. | |
301 thread->set_is_method_handle_return(nm->is_method_handle_return(pc)); | |
302 return fast_continuation; | |
303 } | |
304 } | |
305 | |
306 // If the stack guard pages are enabled, check whether there is a handler in | |
307 // the current method. Otherwise (guard pages disabled), force an unwind and | |
308 // skip the exception cache update (i.e., just leave continuation==NULL). | |
309 address continuation = NULL; | |
310 if (guard_pages_enabled) { | |
311 | |
312 // New exception handling mechanism can support inlined methods | |
313 // with exception handlers since the mappings are from PC to PC | |
314 | |
315 // debugging support | |
316 // tracing | |
317 if (TraceExceptions) { | |
318 ttyLocker ttyl; | |
319 ResourceMark rm; | |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
320 tty->print_cr("Exception <%s> (" INTPTR_FORMAT ") thrown in compiled method <%s> at PC " INTPTR_FORMAT " for thread " INTPTR_FORMAT "", |
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
321 exception->print_value_string(), p2i((address)exception()), nm->method()->print_value_string(), p2i(pc), p2i(thread)); |
7221 | 322 } |
323 // for AbortVMOnException flag | |
324 NOT_PRODUCT(Exceptions::debug_check_abort(exception)); | |
325 | |
326 // Clear out the exception oop and pc since looking up an | |
327 // exception handler can cause class loading, which might throw an | |
328 // exception and those fields are expected to be clear during | |
329 // normal bytecode execution. | |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
330 thread->clear_exception_oop_and_pc(); |
7221 | 331 |
332 continuation = SharedRuntime::compute_compiled_exc_handler(nm, pc, exception, false, false); | |
333 // If an exception was thrown during exception dispatch, the exception oop may have changed | |
334 thread->set_exception_oop(exception()); | |
335 thread->set_exception_pc(pc); | |
336 | |
337 // the exception cache is used only by non-implicit exceptions | |
338 if (continuation != NULL && !SharedRuntime::deopt_blob()->contains(continuation)) { | |
339 nm->add_handler_for_exception_and_pc(exception, pc, continuation); | |
340 } | |
341 } | |
342 | |
343 // Set flag if return address is a method handle call site. | |
344 thread->set_is_method_handle_return(nm->is_method_handle_return(pc)); | |
345 | |
346 if (TraceExceptions) { | |
347 ttyLocker ttyl; | |
348 ResourceMark rm; | |
349 tty->print_cr("Thread " PTR_FORMAT " continuing at PC " PTR_FORMAT " for exception thrown at PC " PTR_FORMAT, | |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
350 p2i(thread), p2i(continuation), p2i(pc)); |
7221 | 351 } |
352 | |
353 return continuation; | |
354 JRT_END | |
355 | |
356 // Enter this method from compiled code only if there is a Java exception handler | |
357 // in the method handling the exception. | |
358 // We are entering here from exception stub. We don't do a normal VM transition here. | |
359 // We do it in a helper. This is so we can check to see if the nmethod we have just | |
360 // searched for an exception handler has been deoptimized in the meantime. | |
361 address GraalRuntime::exception_handler_for_pc(JavaThread* thread) { | |
362 oop exception = thread->exception_oop(); | |
363 address pc = thread->exception_pc(); | |
364 // Still in Java mode | |
365 DEBUG_ONLY(ResetNoHandleMark rnhm); | |
366 nmethod* nm = NULL; | |
367 address continuation = NULL; | |
368 { | |
369 // Enter VM mode by calling the helper | |
370 ResetNoHandleMark rnhm; | |
371 continuation = exception_handler_for_pc_helper(thread, exception, pc, nm); | |
372 } | |
373 // Back in JAVA, use no oops DON'T safepoint | |
374 | |
375 // Now check to see if the nmethod we were called from is now deoptimized. | |
376 // If so we must return to the deopt blob and deoptimize the nmethod | |
377 if (nm != NULL && caller_is_deopted()) { | |
378 continuation = SharedRuntime::deopt_blob()->unpack_with_exception_in_tls(); | |
379 } | |
380 | |
381 assert(continuation != NULL, "no handler found"); | |
382 return continuation; | |
383 } | |
384 | |
7911
983f7bdb85ff
removed redundant graal_ prefix from Graal specific functions and variable in native code
Doug Simon <doug.simon@oracle.com>
parents:
7735
diff
changeset
|
385 JRT_ENTRY(void, GraalRuntime::create_null_exception(JavaThread* thread)) |
12668
e27f3169460e
notify JVMTI about exception throws from runtime
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
12435
diff
changeset
|
386 SharedRuntime::throw_and_post_jvmti_exception(thread, vmSymbols::java_lang_NullPointerException()); |
e27f3169460e
notify JVMTI about exception throws from runtime
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
12435
diff
changeset
|
387 thread->set_vm_result(PENDING_EXCEPTION); |
e27f3169460e
notify JVMTI about exception throws from runtime
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
12435
diff
changeset
|
388 CLEAR_PENDING_EXCEPTION; |
7221 | 389 JRT_END |
390 | |
7911
983f7bdb85ff
removed redundant graal_ prefix from Graal specific functions and variable in native code
Doug Simon <doug.simon@oracle.com>
parents:
7735
diff
changeset
|
391 JRT_ENTRY(void, GraalRuntime::create_out_of_bounds_exception(JavaThread* thread, jint index)) |
7221 | 392 char message[jintAsStringSize]; |
393 sprintf(message, "%d", index); | |
12668
e27f3169460e
notify JVMTI about exception throws from runtime
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
12435
diff
changeset
|
394 SharedRuntime::throw_and_post_jvmti_exception(thread, vmSymbols::java_lang_ArrayIndexOutOfBoundsException(), message); |
e27f3169460e
notify JVMTI about exception throws from runtime
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
12435
diff
changeset
|
395 thread->set_vm_result(PENDING_EXCEPTION); |
e27f3169460e
notify JVMTI about exception throws from runtime
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
12435
diff
changeset
|
396 CLEAR_PENDING_EXCEPTION; |
7221 | 397 JRT_END |
398 | |
7911
983f7bdb85ff
removed redundant graal_ prefix from Graal specific functions and variable in native code
Doug Simon <doug.simon@oracle.com>
parents:
7735
diff
changeset
|
399 JRT_ENTRY_NO_ASYNC(void, GraalRuntime::monitorenter(JavaThread* thread, oopDesc* obj, BasicLock* lock)) |
7221 | 400 if (TraceGraal >= 3) { |
401 char type[O_BUFLEN]; | |
402 obj->klass()->name()->as_C_string(type, O_BUFLEN); | |
403 markOop mark = obj->mark(); | |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
404 tty->print_cr("%s: entered locking slow case with obj=" INTPTR_FORMAT ", type=%s, mark=" INTPTR_FORMAT ", lock=" INTPTR_FORMAT, thread->name(), p2i(obj), type, p2i(mark), p2i(lock)); |
7221 | 405 tty->flush(); |
406 } | |
407 #ifdef ASSERT | |
408 if (PrintBiasedLockingStatistics) { | |
409 Atomic::inc(BiasedLocking::slow_path_entry_count_addr()); | |
410 } | |
411 #endif | |
412 Handle h_obj(thread, obj); | |
413 assert(h_obj()->is_oop(), "must be NULL or an object"); | |
414 if (UseBiasedLocking) { | |
415 // Retry fast entry if bias is revoked to avoid unnecessary inflation | |
416 ObjectSynchronizer::fast_enter(h_obj, lock, true, CHECK); | |
417 } else { | |
7226 | 418 if (GraalUseFastLocking) { |
7221 | 419 // When using fast locking, the compiled code has already tried the fast case |
420 ObjectSynchronizer::slow_enter(h_obj, lock, THREAD); | |
421 } else { | |
422 ObjectSynchronizer::fast_enter(h_obj, lock, false, THREAD); | |
423 } | |
424 } | |
425 if (TraceGraal >= 3) { | |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
426 tty->print_cr("%s: exiting locking slow with obj=" INTPTR_FORMAT, thread->name(), p2i(obj)); |
7221 | 427 } |
428 JRT_END | |
429 | |
7911
983f7bdb85ff
removed redundant graal_ prefix from Graal specific functions and variable in native code
Doug Simon <doug.simon@oracle.com>
parents:
7735
diff
changeset
|
430 JRT_LEAF(void, GraalRuntime::monitorexit(JavaThread* thread, oopDesc* obj, BasicLock* lock)) |
7221 | 431 assert(thread == JavaThread::current(), "threads must correspond"); |
432 assert(thread->last_Java_sp(), "last_Java_sp must be set"); | |
433 // monitorexit is non-blocking (leaf routine) => no exceptions can be thrown | |
434 EXCEPTION_MARK; | |
435 | |
436 #ifdef DEBUG | |
437 if (!obj->is_oop()) { | |
438 ResetNoHandleMark rhm; | |
439 nmethod* method = thread->last_frame().cb()->as_nmethod_or_null(); | |
440 if (method != NULL) { | |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
441 tty->print_cr("ERROR in monitorexit in method %s wrong obj " INTPTR_FORMAT, method->name(), p2i(obj)); |
7221 | 442 } |
443 thread->print_stack_on(tty); | |
444 assert(false, "invalid lock object pointer dected"); | |
445 } | |
446 #endif | |
447 | |
7226 | 448 if (GraalUseFastLocking) { |
7221 | 449 // When using fast locking, the compiled code has already tried the fast case |
450 ObjectSynchronizer::slow_exit(obj, lock, THREAD); | |
451 } else { | |
452 ObjectSynchronizer::fast_exit(obj, lock, THREAD); | |
453 } | |
454 if (TraceGraal >= 3) { | |
455 char type[O_BUFLEN]; | |
456 obj->klass()->name()->as_C_string(type, O_BUFLEN); | |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
457 tty->print_cr("%s: exited locking slow case with obj=" INTPTR_FORMAT ", type=%s, mark=" INTPTR_FORMAT ", lock=" INTPTR_FORMAT, thread->name(), p2i(obj), type, p2i(obj->mark()), p2i(lock)); |
7221 | 458 tty->flush(); |
459 } | |
460 JRT_END | |
461 | |
16887
aa412e64808e
logObject and logPrimitive should be leaf
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
16876
diff
changeset
|
462 JRT_LEAF(void, GraalRuntime::log_object(JavaThread* thread, oopDesc* obj, jint flags)) |
7221 | 463 bool string = mask_bits_are_true(flags, LOG_OBJECT_STRING); |
12356
359f7e70ae7f
Reduce HotSpot diff and fix previous merge
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
10953
diff
changeset
|
464 bool addr = mask_bits_are_true(flags, LOG_OBJECT_ADDRESS); |
7221 | 465 bool newline = mask_bits_are_true(flags, LOG_OBJECT_NEWLINE); |
466 if (!string) { | |
12356
359f7e70ae7f
Reduce HotSpot diff and fix previous merge
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
10953
diff
changeset
|
467 if (!addr && obj->is_oop_or_null(true)) { |
7221 | 468 char buf[O_BUFLEN]; |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
469 tty->print("%s@" INTPTR_FORMAT, obj->klass()->name()->as_C_string(buf, O_BUFLEN), p2i(obj)); |
7221 | 470 } else { |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
471 tty->print(INTPTR_FORMAT, p2i(obj)); |
7221 | 472 } |
473 } else { | |
474 ResourceMark rm; | |
475 assert(obj != NULL && java_lang_String::is_instance(obj), "must be"); | |
476 char *buf = java_lang_String::as_utf8_string(obj); | |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
477 tty->print_raw(buf); |
7221 | 478 } |
479 if (newline) { | |
480 tty->cr(); | |
481 } | |
482 JRT_END | |
483 | |
10434
8b22524df53b
Add G1 Barriers' foreign calls
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10072
diff
changeset
|
484 JRT_LEAF(void, GraalRuntime::write_barrier_pre(JavaThread* thread, oopDesc* obj)) |
8b22524df53b
Add G1 Barriers' foreign calls
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10072
diff
changeset
|
485 thread->satb_mark_queue().enqueue(obj); |
8b22524df53b
Add G1 Barriers' foreign calls
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10072
diff
changeset
|
486 JRT_END |
8b22524df53b
Add G1 Barriers' foreign calls
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10072
diff
changeset
|
487 |
8b22524df53b
Add G1 Barriers' foreign calls
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10072
diff
changeset
|
488 JRT_LEAF(void, GraalRuntime::write_barrier_post(JavaThread* thread, void* card_addr)) |
8b22524df53b
Add G1 Barriers' foreign calls
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10072
diff
changeset
|
489 thread->dirty_card_queue().enqueue(card_addr); |
8b22524df53b
Add G1 Barriers' foreign calls
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10072
diff
changeset
|
490 JRT_END |
8b22524df53b
Add G1 Barriers' foreign calls
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10072
diff
changeset
|
491 |
12356
359f7e70ae7f
Reduce HotSpot diff and fix previous merge
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
10953
diff
changeset
|
492 JRT_LEAF(jboolean, GraalRuntime::validate_object(JavaThread* thread, oopDesc* parent, oopDesc* child)) |
10953
97e282186b5b
Add heap sanity checker with premature hard crash for debugging write barriers
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10542
diff
changeset
|
493 bool ret = true; |
97e282186b5b
Add heap sanity checker with premature hard crash for debugging write barriers
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10542
diff
changeset
|
494 if(!Universe::heap()->is_in_closed_subset(parent)) { |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
495 tty->print_cr("Parent Object "INTPTR_FORMAT" not in heap", p2i(parent)); |
10953
97e282186b5b
Add heap sanity checker with premature hard crash for debugging write barriers
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10542
diff
changeset
|
496 parent->print(); |
97e282186b5b
Add heap sanity checker with premature hard crash for debugging write barriers
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10542
diff
changeset
|
497 ret=false; |
97e282186b5b
Add heap sanity checker with premature hard crash for debugging write barriers
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10542
diff
changeset
|
498 } |
97e282186b5b
Add heap sanity checker with premature hard crash for debugging write barriers
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10542
diff
changeset
|
499 if(!Universe::heap()->is_in_closed_subset(child)) { |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
500 tty->print_cr("Child Object "INTPTR_FORMAT" not in heap", p2i(child)); |
10953
97e282186b5b
Add heap sanity checker with premature hard crash for debugging write barriers
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10542
diff
changeset
|
501 child->print(); |
97e282186b5b
Add heap sanity checker with premature hard crash for debugging write barriers
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10542
diff
changeset
|
502 ret=false; |
97e282186b5b
Add heap sanity checker with premature hard crash for debugging write barriers
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10542
diff
changeset
|
503 } |
97e282186b5b
Add heap sanity checker with premature hard crash for debugging write barriers
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10542
diff
changeset
|
504 return (jint)ret; |
97e282186b5b
Add heap sanity checker with premature hard crash for debugging write barriers
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10542
diff
changeset
|
505 JRT_END |
97e282186b5b
Add heap sanity checker with premature hard crash for debugging write barriers
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
10542
diff
changeset
|
506 |
14731
0cb5c4d276d4
use raw data support to fix incorrect use of String.intern() for embedding strings in code
Doug Simon <doug.simon@oracle.com>
parents:
14608
diff
changeset
|
507 JRT_ENTRY(void, GraalRuntime::vm_error(JavaThread* thread, jlong where, jlong format, jlong value)) |
7221 | 508 ResourceMark rm; |
14731
0cb5c4d276d4
use raw data support to fix incorrect use of String.intern() for embedding strings in code
Doug Simon <doug.simon@oracle.com>
parents:
14608
diff
changeset
|
509 const char *error_msg = where == 0L ? "<internal Graal error>" : (char*) (address) where; |
7221 | 510 char *detail_msg = NULL; |
14731
0cb5c4d276d4
use raw data support to fix incorrect use of String.intern() for embedding strings in code
Doug Simon <doug.simon@oracle.com>
parents:
14608
diff
changeset
|
511 if (format != 0L) { |
0cb5c4d276d4
use raw data support to fix incorrect use of String.intern() for embedding strings in code
Doug Simon <doug.simon@oracle.com>
parents:
14608
diff
changeset
|
512 const char* buf = (char*) (address) format; |
7221 | 513 size_t detail_msg_length = strlen(buf) * 2; |
514 detail_msg = (char *) NEW_RESOURCE_ARRAY(u_char, detail_msg_length); | |
515 jio_snprintf(detail_msg, detail_msg_length, buf, value); | |
516 } | |
517 report_vm_error(__FILE__, __LINE__, error_msg, detail_msg); | |
518 JRT_END | |
519 | |
12423
370b5f07f9e2
The runtime entries need to use oopDesc* rather than oop in their signature
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12372
diff
changeset
|
520 JRT_LEAF(oopDesc*, GraalRuntime::load_and_clear_exception(JavaThread* thread)) |
9820
1b60f639ac4b
implemented alternative implementation for loading the exception object from the thread at the start of an exception dispatcher
Doug Simon <doug.simon@oracle.com>
parents:
9596
diff
changeset
|
521 oop exception = thread->exception_oop(); |
1b60f639ac4b
implemented alternative implementation for loading the exception object from the thread at the start of an exception dispatcher
Doug Simon <doug.simon@oracle.com>
parents:
9596
diff
changeset
|
522 assert(exception != NULL, "npe"); |
1b60f639ac4b
implemented alternative implementation for loading the exception object from the thread at the start of an exception dispatcher
Doug Simon <doug.simon@oracle.com>
parents:
9596
diff
changeset
|
523 thread->set_exception_oop(NULL); |
1b60f639ac4b
implemented alternative implementation for loading the exception object from the thread at the start of an exception dispatcher
Doug Simon <doug.simon@oracle.com>
parents:
9596
diff
changeset
|
524 thread->set_exception_pc(0); |
1b60f639ac4b
implemented alternative implementation for loading the exception object from the thread at the start of an exception dispatcher
Doug Simon <doug.simon@oracle.com>
parents:
9596
diff
changeset
|
525 return exception; |
1b60f639ac4b
implemented alternative implementation for loading the exception object from the thread at the start of an exception dispatcher
Doug Simon <doug.simon@oracle.com>
parents:
9596
diff
changeset
|
526 JRT_END |
8506 | 527 |
12423
370b5f07f9e2
The runtime entries need to use oopDesc* rather than oop in their signature
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12372
diff
changeset
|
528 JRT_LEAF(void, GraalRuntime::log_printf(JavaThread* thread, oopDesc* format, jlong v1, jlong v2, jlong v3)) |
7221 | 529 ResourceMark rm; |
530 assert(format != NULL && java_lang_String::is_instance(format), "must be"); | |
531 char *buf = java_lang_String::as_utf8_string(format); | |
7235
a6bd253a770f
expanded LOG_PRINTF stub to handle up to 3 arguments in addition to the format string
Doug Simon <doug.simon@oracle.com>
parents:
7226
diff
changeset
|
532 tty->print(buf, v1, v2, v3); |
7221 | 533 JRT_END |
534 | |
9573
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
535 static void decipher(jlong v, bool ignoreZero) { |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
536 if (v != 0 || !ignoreZero) { |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
537 void* p = (void *)(address) v; |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
538 CodeBlob* cb = CodeCache::find_blob(p); |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
539 if (cb) { |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
540 if (cb->is_nmethod()) { |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
541 char buf[O_BUFLEN]; |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
542 tty->print("%s [" INTPTR_FORMAT "+" JLONG_FORMAT "]", cb->as_nmethod_or_null()->method()->name_and_sig_as_C_string(buf, O_BUFLEN), p2i(cb->code_begin()), (jlong)((address)v - cb->code_begin())); |
9573
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
543 return; |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
544 } |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
545 cb->print_value_on(tty); |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
546 return; |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
547 } |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
548 if (Universe::heap()->is_in(p)) { |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
549 oop obj = oop(p); |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
550 obj->print_value_on(tty); |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
551 return; |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
552 } |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
553 tty->print(INTPTR_FORMAT " [long: " JLONG_FORMAT ", double %lf, char %c]",p2i((void *)v), (jlong)v, (jdouble)v, (char)v); |
9573
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
554 } |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
555 } |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
556 |
9471
5fa54bf57f8c
replaced exception_handler_nofpu assembler stub with a compiled stub (GRAAL-81)
Doug Simon <doug.simon@oracle.com>
parents:
9457
diff
changeset
|
557 JRT_LEAF(void, GraalRuntime::vm_message(jboolean vmError, jlong format, jlong v1, jlong v2, jlong v3)) |
9232
bb2447c64055
strings used in compiled stubs are lowered to malloc'ed C strings so that there are no embedded oops (for the strings) in the resulting installed code
Doug Simon <doug.simon@oracle.com>
parents:
8506
diff
changeset
|
558 ResourceMark rm; |
bb2447c64055
strings used in compiled stubs are lowered to malloc'ed C strings so that there are no embedded oops (for the strings) in the resulting installed code
Doug Simon <doug.simon@oracle.com>
parents:
8506
diff
changeset
|
559 char *buf = (char*) (address) format; |
9471
5fa54bf57f8c
replaced exception_handler_nofpu assembler stub with a compiled stub (GRAAL-81)
Doug Simon <doug.simon@oracle.com>
parents:
9457
diff
changeset
|
560 if (vmError) { |
9573
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
561 if (buf != NULL) { |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
562 fatal(err_msg(buf, v1, v2, v3)); |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
563 } else { |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
564 fatal("<anonymous error>"); |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
565 } |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
566 } else if (buf != NULL) { |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
567 tty->print(buf, v1, v2, v3); |
9471
5fa54bf57f8c
replaced exception_handler_nofpu assembler stub with a compiled stub (GRAAL-81)
Doug Simon <doug.simon@oracle.com>
parents:
9457
diff
changeset
|
568 } else { |
9573
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
569 assert(v2 == 0, "v2 != 0"); |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
570 assert(v3 == 0, "v3 != 0"); |
a79e8020ad4b
added Stub.decipher() to print information about values in stubs
Doug Simon <doug.simon@oracle.com>
parents:
9565
diff
changeset
|
571 decipher(v1, false); |
9471
5fa54bf57f8c
replaced exception_handler_nofpu assembler stub with a compiled stub (GRAAL-81)
Doug Simon <doug.simon@oracle.com>
parents:
9457
diff
changeset
|
572 } |
9232
bb2447c64055
strings used in compiled stubs are lowered to malloc'ed C strings so that there are no embedded oops (for the strings) in the resulting installed code
Doug Simon <doug.simon@oracle.com>
parents:
8506
diff
changeset
|
573 JRT_END |
bb2447c64055
strings used in compiled stubs are lowered to malloc'ed C strings so that there are no embedded oops (for the strings) in the resulting installed code
Doug Simon <doug.simon@oracle.com>
parents:
8506
diff
changeset
|
574 |
16887
aa412e64808e
logObject and logPrimitive should be leaf
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
16876
diff
changeset
|
575 JRT_LEAF(void, GraalRuntime::log_primitive(JavaThread* thread, jchar typeChar, jlong value, jboolean newline)) |
7221 | 576 union { |
577 jlong l; | |
578 jdouble d; | |
579 jfloat f; | |
580 } uu; | |
581 uu.l = value; | |
582 switch (typeChar) { | |
583 case 'z': tty->print(value == 0 ? "false" : "true"); break; | |
584 case 'b': tty->print("%d", (jbyte) value); break; | |
585 case 'c': tty->print("%c", (jchar) value); break; | |
586 case 's': tty->print("%d", (jshort) value); break; | |
587 case 'i': tty->print("%d", (jint) value); break; | |
588 case 'f': tty->print("%f", uu.f); break; | |
18657
74f612049e4e
fixed format string issues
Doug Simon <doug.simon@oracle.com>
parents:
18634
diff
changeset
|
589 case 'j': tty->print(JLONG_FORMAT, value); break; |
7221 | 590 case 'd': tty->print("%lf", uu.d); break; |
591 default: assert(false, "unknown typeChar"); break; | |
592 } | |
593 if (newline) { | |
594 tty->cr(); | |
595 } | |
596 JRT_END | |
597 | |
12423
370b5f07f9e2
The runtime entries need to use oopDesc* rather than oop in their signature
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12372
diff
changeset
|
598 JRT_ENTRY(jint, GraalRuntime::identity_hash_code(JavaThread* thread, oopDesc* obj)) |
7221 | 599 return (jint) obj->identity_hash(); |
600 JRT_END | |
601 | |
12423
370b5f07f9e2
The runtime entries need to use oopDesc* rather than oop in their signature
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12372
diff
changeset
|
602 JRT_ENTRY(jboolean, GraalRuntime::thread_is_interrupted(JavaThread* thread, oopDesc* receiver, jboolean clear_interrupted)) |
7220
fcae6d960acd
added more compiler intrinsics
Christian Haeubl <haeubl@ssw.jku.at>
parents:
7216
diff
changeset
|
603 // Ensure that the C++ Thread and OSThread structures aren't freed before we operate |
fcae6d960acd
added more compiler intrinsics
Christian Haeubl <haeubl@ssw.jku.at>
parents:
7216
diff
changeset
|
604 Handle receiverHandle(thread, receiver); |
12423
370b5f07f9e2
The runtime entries need to use oopDesc* rather than oop in their signature
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
12372
diff
changeset
|
605 MutexLockerEx ml(thread->threadObj() == (void*)receiver ? NULL : Threads_lock); |
7386
707e9cca11de
fixed HotSpot windows build
Christian Haeubl <haeubl@ssw.jku.at>
parents:
7235
diff
changeset
|
606 JavaThread* receiverThread = java_lang_Thread::thread(receiverHandle()); |
14608
682fba1bcf95
add missing null check in is_interrupted
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
13578
diff
changeset
|
607 if (receiverThread == NULL) { |
682fba1bcf95
add missing null check in is_interrupted
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
13578
diff
changeset
|
608 // The other thread may exit during this process, which is ok so return false. |
682fba1bcf95
add missing null check in is_interrupted
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
13578
diff
changeset
|
609 return JNI_FALSE; |
682fba1bcf95
add missing null check in is_interrupted
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
13578
diff
changeset
|
610 } else { |
682fba1bcf95
add missing null check in is_interrupted
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
13578
diff
changeset
|
611 return (jint) Thread::is_interrupted(receiverThread, clear_interrupted != 0); |
682fba1bcf95
add missing null check in is_interrupted
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
13578
diff
changeset
|
612 } |
7221 | 613 JRT_END |
614 | |
18227
bcb1e5c232d8
Test deoptimization inside ForeignCallNode
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
18043
diff
changeset
|
615 JRT_ENTRY(jint, GraalRuntime::test_deoptimize_call_int(JavaThread* thread, int value)) |
bcb1e5c232d8
Test deoptimization inside ForeignCallNode
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
18043
diff
changeset
|
616 deopt_caller(); |
bcb1e5c232d8
Test deoptimization inside ForeignCallNode
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
18043
diff
changeset
|
617 return value; |
bcb1e5c232d8
Test deoptimization inside ForeignCallNode
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
18043
diff
changeset
|
618 JRT_END |
bcb1e5c232d8
Test deoptimization inside ForeignCallNode
Tom Rodriguez <tom.rodriguez@oracle.com>
parents:
18043
diff
changeset
|
619 |
18614
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
620 // private static void Factory.init() |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
621 JVM_ENTRY(void, JVM_InitGraalClassLoader(JNIEnv *env, jclass c, jobject loader_handle)) |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
622 SystemDictionary::init_graal_loader(JNIHandles::resolve(loader_handle)); |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
623 SystemDictionary::WKID scan = SystemDictionary::FIRST_GRAAL_WKID; |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
624 SystemDictionary::initialize_wk_klasses_through(SystemDictionary::LAST_GRAAL_WKID, scan, CHECK); |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
625 JVM_END |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
626 |
15603
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
627 // private static GraalRuntime Graal.initializeRuntime() |
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
628 JVM_ENTRY(jobject, JVM_GetGraalRuntime(JNIEnv *env, jclass c)) |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
629 return GraalRuntime::get_HotSpotGraalRuntime_jobject(); |
7221 | 630 JVM_END |
10475
3489047ffea2
Restructure the handling of HotSpotInstalledCode and their link to nmethods.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
10434
diff
changeset
|
631 |
15916
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
632 // private static String[] Graal.getServiceImpls(Class service) |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
633 JVM_ENTRY(jobject, JVM_GetGraalServiceImpls(JNIEnv *env, jclass c, jclass serviceClass)) |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
634 HandleMark hm; |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
635 KlassHandle serviceKlass(THREAD, java_lang_Class::as_Klass(JNIHandles::resolve_non_null(serviceClass))); |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
636 return JNIHandles::make_local(THREAD, GraalRuntime::get_service_impls(serviceKlass, THREAD)()); |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
637 JVM_END |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
638 |
15603
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
639 // private static TruffleRuntime Truffle.createRuntime() |
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
640 JVM_ENTRY(jobject, JVM_CreateTruffleRuntime(JNIEnv *env, jclass c)) |
18634
b4071daf1892
ensure Graal class loader is initialized prior to loading HotSpotTruffleRuntime
Andreas Woess <andreas.woess@jku.at>
parents:
18628
diff
changeset
|
641 GraalRuntime::ensure_graal_class_loader_is_initialized(); |
16428
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
642 TempNewSymbol name = SymbolTable::new_symbol("com/oracle/graal/truffle/hotspot/HotSpotTruffleRuntime", CHECK_NULL); |
16395
ad431bf0de07
added support to load classes from graal.jar with a separate class loader
Doug Simon <doug.simon@oracle.com>
parents:
16291
diff
changeset
|
643 KlassHandle klass = GraalRuntime::resolve_or_fail(name, CHECK_NULL); |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
644 |
16428
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
645 TempNewSymbol makeInstance = SymbolTable::new_symbol("makeInstance", CHECK_NULL); |
18961
afa70d3e8159
Allow users to provide their own TruffleRuntime implementation
Paul Woegerer <paul.woegerer@oracle.com>
parents:
18748
diff
changeset
|
646 TempNewSymbol sig = SymbolTable::new_symbol("()Lcom/oracle/truffle/api/TruffleRuntime;", CHECK_NULL); |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
647 JavaValue result(T_OBJECT); |
16428
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
648 JavaCalls::call_static(&result, klass, makeInstance, sig, CHECK_NULL); |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
649 return JNIHandles::make_local((oop) result.get_jobject()); |
10475
3489047ffea2
Restructure the handling of HotSpotInstalledCode and their link to nmethods.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
10434
diff
changeset
|
650 JVM_END |
15603
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
651 |
16691
dd8449afc086
GNFI: move GNFI interfaces to oracle.nfi - interface does not depend on graal
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16683
diff
changeset
|
652 // private static NativeFunctionInterfaceRuntime.createInterface() |
dd8449afc086
GNFI: move GNFI interfaces to oracle.nfi - interface does not depend on graal
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16683
diff
changeset
|
653 JVM_ENTRY(jobject, JVM_CreateNativeFunctionInterface(JNIEnv *env, jclass c)) |
16717
91e7d77cfb81
NFI: initialization only if platform is x86
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16691
diff
changeset
|
654 const char* backendName = NULL; |
91e7d77cfb81
NFI: initialization only if platform is x86
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16691
diff
changeset
|
655 #ifdef TARGET_ARCH_x86 |
91e7d77cfb81
NFI: initialization only if platform is x86
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16691
diff
changeset
|
656 #ifdef _LP64 |
91e7d77cfb81
NFI: initialization only if platform is x86
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16691
diff
changeset
|
657 backendName = "com/oracle/graal/hotspot/amd64/AMD64HotSpotBackend"; |
18748
3d6e630a72f1
Fix GNFI class loader problem
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
18711
diff
changeset
|
658 #endif |
16717
91e7d77cfb81
NFI: initialization only if platform is x86
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16691
diff
changeset
|
659 #endif |
91e7d77cfb81
NFI: initialization only if platform is x86
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16691
diff
changeset
|
660 |
91e7d77cfb81
NFI: initialization only if platform is x86
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16691
diff
changeset
|
661 if (backendName == NULL) { |
91e7d77cfb81
NFI: initialization only if platform is x86
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16691
diff
changeset
|
662 return NULL; |
91e7d77cfb81
NFI: initialization only if platform is x86
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16691
diff
changeset
|
663 } |
18748
3d6e630a72f1
Fix GNFI class loader problem
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
18711
diff
changeset
|
664 GraalRuntime::ensure_graal_class_loader_is_initialized(); |
16717
91e7d77cfb81
NFI: initialization only if platform is x86
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16691
diff
changeset
|
665 TempNewSymbol name = SymbolTable::new_symbol(backendName, CHECK_NULL); |
16691
dd8449afc086
GNFI: move GNFI interfaces to oracle.nfi - interface does not depend on graal
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16683
diff
changeset
|
666 KlassHandle klass = GraalRuntime::resolve_or_fail(name, CHECK_NULL); |
dd8449afc086
GNFI: move GNFI interfaces to oracle.nfi - interface does not depend on graal
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16683
diff
changeset
|
667 |
dd8449afc086
GNFI: move GNFI interfaces to oracle.nfi - interface does not depend on graal
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16683
diff
changeset
|
668 TempNewSymbol makeInstance = SymbolTable::new_symbol("createNativeFunctionInterface", CHECK_NULL); |
dd8449afc086
GNFI: move GNFI interfaces to oracle.nfi - interface does not depend on graal
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16683
diff
changeset
|
669 TempNewSymbol sig = SymbolTable::new_symbol("()Lcom/oracle/nfi/api/NativeFunctionInterface;", CHECK_NULL); |
dd8449afc086
GNFI: move GNFI interfaces to oracle.nfi - interface does not depend on graal
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16683
diff
changeset
|
670 JavaValue result(T_OBJECT); |
dd8449afc086
GNFI: move GNFI interfaces to oracle.nfi - interface does not depend on graal
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16683
diff
changeset
|
671 JavaCalls::call_static(&result, klass, makeInstance, sig, CHECK_NULL); |
dd8449afc086
GNFI: move GNFI interfaces to oracle.nfi - interface does not depend on graal
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16683
diff
changeset
|
672 return JNIHandles::make_local((oop) result.get_jobject()); |
dd8449afc086
GNFI: move GNFI interfaces to oracle.nfi - interface does not depend on graal
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16683
diff
changeset
|
673 JVM_END |
dd8449afc086
GNFI: move GNFI interfaces to oracle.nfi - interface does not depend on graal
Matthias Grimmer <grimmer@ssw.jku.at>
parents:
16683
diff
changeset
|
674 |
16628
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
675 void GraalRuntime::check_generated_sources_sha1(TRAPS) { |
18711
88c280297bd2
put GeneratedSourcesSha1 into com.oracle.graal.hotspot.sourcegen package
Doug Simon <doug.simon@oracle.com>
parents:
18657
diff
changeset
|
676 TempNewSymbol name = SymbolTable::new_symbol("com/oracle/graal/hotspot/sourcegen/GeneratedSourcesSha1", CHECK_ABORT); |
16628
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
677 KlassHandle klass = load_required_class(name); |
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
678 fieldDescriptor fd; |
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
679 if (!InstanceKlass::cast(klass())->find_field(vmSymbols::value_name(), vmSymbols::string_signature(), true, &fd)) { |
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
680 THROW_MSG(vmSymbols::java_lang_NoSuchFieldError(), "GeneratedSourcesSha1.value"); |
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
681 } |
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
682 |
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
683 Symbol* value = java_lang_String::as_symbol(klass->java_mirror()->obj_field(fd.offset()), CHECK); |
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
684 if (!value->equals(_generated_sources_sha1)) { |
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
685 char buf[200]; |
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
686 jio_snprintf(buf, sizeof(buf), "Generated sources SHA1 check failed (%s != %s) - need to rebuild the VM", value->as_C_string(), _generated_sources_sha1); |
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
687 THROW_MSG(vmSymbols::java_lang_InternalError(), buf); |
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
688 } |
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
689 } |
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
690 |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
691 Handle GraalRuntime::get_HotSpotGraalRuntime() { |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
692 if (JNIHandles::resolve(_HotSpotGraalRuntime_instance) == NULL) { |
16683
4d0d1dc5db00
introduce extra field to record when HotSpotGraalRuntime has been initialized to avoid spurious errors during VM shutdown for short lived applications
Doug Simon <doug.simon@oracle.com>
parents:
16679
diff
changeset
|
693 guarantee(!_HotSpotGraalRuntime_initialized, "cannot reinitialize HotSpotGraalRuntime"); |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
694 Thread* THREAD = Thread::current(); |
16628
d3fec84757ed
improved generated sources up-to-date check by using SHA1 digests
Doug Simon <doug.simon@oracle.com>
parents:
16580
diff
changeset
|
695 check_generated_sources_sha1(CHECK_ABORT_(Handle())); |
16428
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
696 TempNewSymbol name = SymbolTable::new_symbol("com/oracle/graal/hotspot/HotSpotGraalRuntime", CHECK_ABORT_(Handle())); |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
697 KlassHandle klass = load_required_class(name); |
16428
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
698 TempNewSymbol runtime = SymbolTable::new_symbol("runtime", CHECK_ABORT_(Handle())); |
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
699 TempNewSymbol sig = SymbolTable::new_symbol("()Lcom/oracle/graal/hotspot/HotSpotGraalRuntime;", CHECK_ABORT_(Handle())); |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
700 JavaValue result(T_OBJECT); |
16428
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
701 JavaCalls::call_static(&result, klass, runtime, sig, CHECK_ABORT_(Handle())); |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
702 _HotSpotGraalRuntime_instance = JNIHandles::make_global((oop) result.get_jobject()); |
16683
4d0d1dc5db00
introduce extra field to record when HotSpotGraalRuntime has been initialized to avoid spurious errors during VM shutdown for short lived applications
Doug Simon <doug.simon@oracle.com>
parents:
16679
diff
changeset
|
703 _HotSpotGraalRuntime_initialized = true; |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
704 } |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
705 return Handle(JNIHandles::resolve_non_null(_HotSpotGraalRuntime_instance)); |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
706 } |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
707 |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
708 // private static void CompilerToVMImpl.init() |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
709 JVM_ENTRY(void, JVM_InitializeGraalNatives(JNIEnv *env, jclass c2vmClass)) |
15603
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
710 GraalRuntime::initialize_natives(env, c2vmClass); |
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
711 JVM_END |
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
712 |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
713 // private static boolean HotSpotOptions.parseVMOptions() |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
714 JVM_ENTRY(jboolean, JVM_ParseGraalOptions(JNIEnv *env, jclass c)) |
15603
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
715 HandleMark hm; |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
716 KlassHandle hotSpotOptionsClass(THREAD, java_lang_Class::as_Klass(JNIHandles::resolve_non_null(c))); |
16876
9d4c73b0646e
graalRuntime: name_len shound be a size_t
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
16870
diff
changeset
|
717 bool result = GraalRuntime::parse_arguments(hotSpotOptionsClass, CHECK_false); |
9d4c73b0646e
graalRuntime: name_len shound be a size_t
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
16870
diff
changeset
|
718 return result; |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
719 JVM_END |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
720 |
18614
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
721 |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
722 void GraalRuntime::ensure_graal_class_loader_is_initialized() { |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
723 // This initialization code is guarded by a static pointer to the Factory class. |
18628 | 724 // Once it is non-null, the Graal class loader and well known Graal classes are |
18614
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
725 // guaranteed to have been initialized. By going through the static |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
726 // initializer of Factory, we can rely on class initialization semantics to |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
727 // synchronize threads racing to do the initialization. |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
728 static Klass* _FactoryKlass = NULL; |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
729 if (_FactoryKlass == NULL) { |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
730 Thread* THREAD = Thread::current(); |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
731 TempNewSymbol name = SymbolTable::new_symbol("com/oracle/graal/hotspot/loader/Factory", CHECK_ABORT); |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
732 KlassHandle klass = SystemDictionary::resolve_or_fail(name, true, THREAD); |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
733 if (HAS_PENDING_EXCEPTION) { |
18618
0aec14bcf006
ensure the error message about missing Graal classes is printed exactly once
Doug Simon <doug.simon@oracle.com>
parents:
18614
diff
changeset
|
734 static volatile int seen_error = 0; |
0aec14bcf006
ensure the error message about missing Graal classes is printed exactly once
Doug Simon <doug.simon@oracle.com>
parents:
18614
diff
changeset
|
735 if (!seen_error && Atomic::cmpxchg(1, &seen_error, 0) == 0) { |
0aec14bcf006
ensure the error message about missing Graal classes is printed exactly once
Doug Simon <doug.simon@oracle.com>
parents:
18614
diff
changeset
|
736 // Only report the failure on the first thread that hits it |
0aec14bcf006
ensure the error message about missing Graal classes is printed exactly once
Doug Simon <doug.simon@oracle.com>
parents:
18614
diff
changeset
|
737 abort_on_pending_exception(PENDING_EXCEPTION, "Graal classes are not available"); |
0aec14bcf006
ensure the error message about missing Graal classes is printed exactly once
Doug Simon <doug.simon@oracle.com>
parents:
18614
diff
changeset
|
738 } else { |
0aec14bcf006
ensure the error message about missing Graal classes is printed exactly once
Doug Simon <doug.simon@oracle.com>
parents:
18614
diff
changeset
|
739 CLEAR_PENDING_EXCEPTION; |
0aec14bcf006
ensure the error message about missing Graal classes is printed exactly once
Doug Simon <doug.simon@oracle.com>
parents:
18614
diff
changeset
|
740 // Give first thread time to report the error. |
0aec14bcf006
ensure the error message about missing Graal classes is printed exactly once
Doug Simon <doug.simon@oracle.com>
parents:
18614
diff
changeset
|
741 os::sleep(THREAD, 100, false); |
0aec14bcf006
ensure the error message about missing Graal classes is printed exactly once
Doug Simon <doug.simon@oracle.com>
parents:
18614
diff
changeset
|
742 vm_abort(false); |
0aec14bcf006
ensure the error message about missing Graal classes is printed exactly once
Doug Simon <doug.simon@oracle.com>
parents:
18614
diff
changeset
|
743 } |
18614
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
744 } |
18618
0aec14bcf006
ensure the error message about missing Graal classes is printed exactly once
Doug Simon <doug.simon@oracle.com>
parents:
18614
diff
changeset
|
745 |
18628 | 746 // We cannot use graalJavaAccess for this because we are currently in the |
747 // process of initializing that mechanism. | |
18614
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
748 TempNewSymbol field_name = SymbolTable::new_symbol("useGraalClassLoader", CHECK_ABORT); |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
749 fieldDescriptor field_desc; |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
750 if (klass->find_field(field_name, vmSymbols::bool_signature(), &field_desc) == NULL) { |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
751 ResourceMark rm; |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
752 fatal(err_msg("Invalid layout of %s at %s", field_name->as_C_string(), klass->external_name())); |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
753 } |
18618
0aec14bcf006
ensure the error message about missing Graal classes is printed exactly once
Doug Simon <doug.simon@oracle.com>
parents:
18614
diff
changeset
|
754 |
18614
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
755 InstanceKlass* ik = InstanceKlass::cast(klass()); |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
756 address addr = ik->static_field_addr(field_desc.offset() - InstanceMirrorKlass::offset_of_static_fields()); |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
757 *((jboolean *) addr) = (jboolean) UseGraalClassLoader; |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
758 klass->initialize(CHECK_ABORT); |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
759 _FactoryKlass = klass(); |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
760 } |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
761 } |
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
762 |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
763 jint GraalRuntime::check_arguments(TRAPS) { |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
764 KlassHandle nullHandle; |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
765 parse_arguments(nullHandle, THREAD); |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
766 if (HAS_PENDING_EXCEPTION) { |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
767 // Errors in parsing Graal arguments cause exceptions. |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
768 // We now load and initialize HotSpotOptions which in turn |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
769 // causes argument parsing to be redone with better error messages. |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
770 CLEAR_PENDING_EXCEPTION; |
16428
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
771 TempNewSymbol name = SymbolTable::new_symbol("Lcom/oracle/graal/hotspot/HotSpotOptions;", CHECK_ABORT_(JNI_ERR)); |
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
772 instanceKlassHandle hotSpotOptionsClass = resolve_or_fail(name, CHECK_ABORT_(JNI_ERR)); |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
773 |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
774 parse_arguments(hotSpotOptionsClass, THREAD); |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
775 assert(HAS_PENDING_EXCEPTION, "must be"); |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
776 |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
777 ResourceMark rm; |
16273
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
778 Handle exception = PENDING_EXCEPTION; |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
779 CLEAR_PENDING_EXCEPTION; |
16273
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
780 oop message = java_lang_Throwable::message(exception); |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
781 if (message != NULL) { |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
782 tty->print_cr("Error parsing Graal options: %s", java_lang_String::as_utf8_string(message)); |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
783 } else { |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
784 call_printStackTrace(exception, THREAD); |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
785 } |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
786 return JNI_ERR; |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
787 } |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
788 return JNI_OK; |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
789 } |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
790 |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
791 bool GraalRuntime::parse_arguments(KlassHandle hotSpotOptionsClass, TRAPS) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
792 ResourceMark rm(THREAD); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
793 |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
794 // Process option overrides from graal.options first |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
795 parse_graal_options_file(hotSpotOptionsClass, CHECK_false); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
796 |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
797 // Now process options on the command line |
15603
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
798 int numOptions = Arguments::num_graal_args(); |
b7fb36e57da8
made Graal initialization be driven from Java to simplify sequencing and synchronization
Doug Simon <doug.simon@oracle.com>
parents:
15589
diff
changeset
|
799 for (int i = 0; i < numOptions; i++) { |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
800 char* arg = Arguments::graal_args_array()[i]; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
801 parse_argument(hotSpotOptionsClass, arg, CHECK_false); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
802 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
803 return CITime || CITimeEach; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
804 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
805 |
16876
9d4c73b0646e
graalRuntime: name_len shound be a size_t
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
16870
diff
changeset
|
806 void GraalRuntime::check_required_value(const char* name, size_t name_len, const char* value, TRAPS) { |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
807 if (value == NULL) { |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
808 char buf[200]; |
16273
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
809 jio_snprintf(buf, sizeof(buf), "Must use '-G:%.*s=<value>' format for %.*s option", name_len, name, name_len, name); |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
810 THROW_MSG(vmSymbols::java_lang_InternalError(), buf); |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
811 } |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
812 } |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
813 |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
814 void GraalRuntime::parse_argument(KlassHandle hotSpotOptionsClass, char* arg, TRAPS) { |
18614
c307546c7b0a
made initialization of the Graal class loader and well known Graal classes lazy
Doug Simon <doug.simon@oracle.com>
parents:
18303
diff
changeset
|
815 ensure_graal_class_loader_is_initialized(); |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
816 char first = arg[0]; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
817 char* name; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
818 size_t name_len; |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
819 bool recognized = true; |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
820 if (first == '+' || first == '-') { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
821 name = arg + 1; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
822 name_len = strlen(name); |
16876
9d4c73b0646e
graalRuntime: name_len shound be a size_t
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
16870
diff
changeset
|
823 recognized = set_option_bool(hotSpotOptionsClass, name, name_len, first, CHECK); |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
824 } else { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
825 char* sep = strchr(arg, '='); |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
826 name = arg; |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
827 char* value = NULL; |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
828 if (sep != NULL) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
829 name_len = sep - name; |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
830 value = sep + 1; |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
831 } else { |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
832 name_len = strlen(name); |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
833 } |
16876
9d4c73b0646e
graalRuntime: name_len shound be a size_t
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
16870
diff
changeset
|
834 recognized = set_option(hotSpotOptionsClass, name, name_len, value, CHECK); |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
835 } |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
836 |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
837 if (!recognized) { |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
838 bool throw_err = hotSpotOptionsClass.is_null(); |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
839 if (!hotSpotOptionsClass.is_null()) { |
16876
9d4c73b0646e
graalRuntime: name_len shound be a size_t
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
16870
diff
changeset
|
840 set_option_helper(hotSpotOptionsClass, name, name_len, Handle(), ' ', Handle(), 0L); |
16275
7af7db0bbfe9
handle unwinding exception through recursive call properly
Doug Simon <doug.simon@oracle.com>
parents:
16274
diff
changeset
|
841 if (!HAS_PENDING_EXCEPTION) { |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
842 throw_err = true; |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
843 } |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
844 } |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
845 |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
846 if (throw_err) { |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
847 char buf[200]; |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
848 jio_snprintf(buf, sizeof(buf), "Unrecognized Graal option %.*s", name_len, name); |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
849 THROW_MSG(vmSymbols::java_lang_InternalError(), buf); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
850 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
851 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
852 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
853 |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
854 void GraalRuntime::parse_graal_options_file(KlassHandle hotSpotOptionsClass, TRAPS) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
855 const char* home = Arguments::get_java_home(); |
16876
9d4c73b0646e
graalRuntime: name_len shound be a size_t
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
16870
diff
changeset
|
856 size_t path_len = strlen(home) + strlen("/lib/graal.options") + 1; |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
857 char* path = NEW_RESOURCE_ARRAY_IN_THREAD(THREAD, char, path_len); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
858 char sep = os::file_separator()[0]; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
859 sprintf(path, "%s%clib%cgraal.options", home, sep, sep); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
860 |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
861 struct stat st; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
862 if (os::stat(path, &st) == 0) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
863 int file_handle = os::open(path, 0, 0); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
864 if (file_handle != -1) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
865 char* buffer = NEW_RESOURCE_ARRAY_IN_THREAD(THREAD, char, st.st_size); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
866 int num_read = (int) os::read(file_handle, (char*) buffer, st.st_size); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
867 if (num_read == -1) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
868 warning("Error reading file %s due to %s", path, strerror(errno)); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
869 } else if (num_read != st.st_size) { |
18657
74f612049e4e
fixed format string issues
Doug Simon <doug.simon@oracle.com>
parents:
18634
diff
changeset
|
870 warning("Only read %d of " SIZE_FORMAT " bytes from %s", num_read, (size_t) st.st_size, path); |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
871 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
872 os::close(file_handle); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
873 if (num_read == st.st_size) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
874 char* line = buffer; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
875 int lineNo = 1; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
876 while (line - buffer < num_read) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
877 char* nl = strchr(line, '\n'); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
878 if (nl != NULL) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
879 *nl = '\0'; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
880 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
881 parse_argument(hotSpotOptionsClass, line, THREAD); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
882 if (HAS_PENDING_EXCEPTION) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
883 warning("Error in %s:%d", path, lineNo); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
884 return; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
885 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
886 if (nl != NULL) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
887 line = nl + 1; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
888 lineNo++; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
889 } else { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
890 // File without newline at the end |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
891 break; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
892 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
893 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
894 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
895 } else { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
896 warning("Error opening file %s due to %s", path, strerror(errno)); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
897 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
898 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
899 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
900 |
16876
9d4c73b0646e
graalRuntime: name_len shound be a size_t
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
16870
diff
changeset
|
901 jlong GraalRuntime::parse_primitive_option_value(char spec, const char* name, size_t name_len, const char* value, TRAPS) { |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
902 check_required_value(name, name_len, value, CHECK_(0L)); |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
903 union { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
904 jint i; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
905 jlong l; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
906 double d; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
907 } uu; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
908 uu.l = 0L; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
909 char dummy; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
910 switch (spec) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
911 case 'd': |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
912 case 'f': { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
913 if (sscanf(value, "%lf%c", &uu.d, &dummy) == 1) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
914 return uu.l; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
915 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
916 break; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
917 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
918 case 'i': { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
919 if (sscanf(value, "%d%c", &uu.i, &dummy) == 1) { |
17165
5247c895a6ab
[SPARC] Use Fzero(d|s) for clearing a fp register
Stefan Anzinger <stefan.anzinger@oracle.com>
parents:
17033
diff
changeset
|
920 return (jlong)uu.i; |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
921 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
922 break; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
923 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
924 default: |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
925 ShouldNotReachHere(); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
926 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
927 ResourceMark rm(THREAD); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
928 char buf[200]; |
16274
60c3f610183e
separate error messages for missing versus invalid non-String option values
Doug Simon <doug.simon@oracle.com>
parents:
16273
diff
changeset
|
929 bool missing = strlen(value) == 0; |
60c3f610183e
separate error messages for missing versus invalid non-String option values
Doug Simon <doug.simon@oracle.com>
parents:
16273
diff
changeset
|
930 if (missing) { |
60c3f610183e
separate error messages for missing versus invalid non-String option values
Doug Simon <doug.simon@oracle.com>
parents:
16273
diff
changeset
|
931 jio_snprintf(buf, sizeof(buf), "Missing %s value for Graal option %.*s", (spec == 'i' ? "numeric" : "float/double"), name_len, name); |
60c3f610183e
separate error messages for missing versus invalid non-String option values
Doug Simon <doug.simon@oracle.com>
parents:
16273
diff
changeset
|
932 } else { |
60c3f610183e
separate error messages for missing versus invalid non-String option values
Doug Simon <doug.simon@oracle.com>
parents:
16273
diff
changeset
|
933 jio_snprintf(buf, sizeof(buf), "Invalid %s value for Graal option %.*s: %s", (spec == 'i' ? "numeric" : "float/double"), name_len, name, value); |
60c3f610183e
separate error messages for missing versus invalid non-String option values
Doug Simon <doug.simon@oracle.com>
parents:
16273
diff
changeset
|
934 } |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
935 THROW_MSG_(vmSymbols::java_lang_InternalError(), buf, 0L); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
936 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
937 |
16876
9d4c73b0646e
graalRuntime: name_len shound be a size_t
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
16870
diff
changeset
|
938 void GraalRuntime::set_option_helper(KlassHandle hotSpotOptionsClass, char* name, size_t name_len, Handle option, jchar spec, Handle stringValue, jlong primitiveValue) { |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
939 Thread* THREAD = Thread::current(); |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
940 Handle name_handle; |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
941 if (name != NULL) { |
16876
9d4c73b0646e
graalRuntime: name_len shound be a size_t
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
16870
diff
changeset
|
942 if (strlen(name) > name_len) { |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
943 // Temporarily replace '=' with NULL to create the Java string for the option name |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
944 char save = name[name_len]; |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
945 name[name_len] = '\0'; |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
946 name_handle = java_lang_String::create_from_str(name, THREAD); |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
947 name[name_len] = '='; |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
948 if (HAS_PENDING_EXCEPTION) { |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
949 return; |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
950 } |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
951 } else { |
16876
9d4c73b0646e
graalRuntime: name_len shound be a size_t
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
16870
diff
changeset
|
952 assert(strlen(name) == name_len, "must be"); |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
953 name_handle = java_lang_String::create_from_str(name, CHECK); |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
954 } |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
955 } |
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
956 |
16428
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
957 TempNewSymbol setOption = SymbolTable::new_symbol("setOption", CHECK); |
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
958 TempNewSymbol sig = SymbolTable::new_symbol("(Ljava/lang/String;Lcom/oracle/graal/options/OptionValue;CLjava/lang/String;J)V", CHECK); |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
959 JavaValue result(T_VOID); |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
960 JavaCallArguments args; |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
961 args.push_oop(name_handle()); |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
962 args.push_oop(option()); |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
963 args.push_int(spec); |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
964 args.push_oop(stringValue()); |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
965 args.push_long(primitiveValue); |
16270
d56a09df1a1f
implemented eager checking of Graal options (GRAAL-807)
Doug Simon <doug.simon@oracle.com>
parents:
16006
diff
changeset
|
966 JavaCalls::call_static(&result, hotSpotOptionsClass, setOption, sig, &args, CHECK); |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
967 } |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
968 |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
969 Handle GraalRuntime::get_OptionValue(const char* declaringClass, const char* fieldName, const char* fieldSig, TRAPS) { |
16428
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
970 TempNewSymbol name = SymbolTable::new_symbol(declaringClass, CHECK_NH); |
16395
ad431bf0de07
added support to load classes from graal.jar with a separate class loader
Doug Simon <doug.simon@oracle.com>
parents:
16291
diff
changeset
|
971 Klass* klass = resolve_or_fail(name, CHECK_NH); |
15870
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
972 |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
973 // The class has been loaded so the field and signature should already be in the symbol |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
974 // table. If they're not there, the field doesn't exist. |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
975 TempNewSymbol fieldname = SymbolTable::probe(fieldName, (int)strlen(fieldName)); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
976 TempNewSymbol signame = SymbolTable::probe(fieldSig, (int)strlen(fieldSig)); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
977 if (fieldname == NULL || signame == NULL) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
978 THROW_MSG_(vmSymbols::java_lang_NoSuchFieldError(), (char*) fieldName, Handle()); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
979 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
980 // Make sure class is initialized before handing id's out to fields |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
981 klass->initialize(CHECK_NH); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
982 |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
983 fieldDescriptor fd; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
984 if (!InstanceKlass::cast(klass)->find_field(fieldname, signame, true, &fd)) { |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
985 THROW_MSG_(vmSymbols::java_lang_NoSuchFieldError(), (char*) fieldName, Handle()); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
986 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
987 |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
988 Handle ret = klass->java_mirror()->obj_field(fd.offset()); |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
989 return ret; |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
990 } |
fe608a56e3f7
made HotSpotOptions processing faster by removing use of service loader in VM startup and only doing work for options specified on the command line
Doug Simon <doug.simon@oracle.com>
parents:
15603
diff
changeset
|
991 |
15916
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
992 Handle GraalRuntime::create_Service(const char* name, TRAPS) { |
16428
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
993 TempNewSymbol kname = SymbolTable::new_symbol(name, CHECK_NH); |
16395
ad431bf0de07
added support to load classes from graal.jar with a separate class loader
Doug Simon <doug.simon@oracle.com>
parents:
16291
diff
changeset
|
994 Klass* k = resolve_or_fail(kname, CHECK_NH); |
15916
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
995 instanceKlassHandle klass(THREAD, k); |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
996 klass->initialize(CHECK_NH); |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
997 klass->check_valid_for_instantiation(true, CHECK_NH); |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
998 JavaValue result(T_VOID); |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
999 instanceHandle service = klass->allocate_instance_handle(CHECK_NH); |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
1000 JavaCalls::call_special(&result, service, klass, vmSymbols::object_initializer_name(), vmSymbols::void_method_signature(), THREAD); |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
1001 return service; |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
1002 } |
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
1003 |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1004 void GraalRuntime::shutdown() { |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1005 if (_HotSpotGraalRuntime_instance != NULL) { |
18303
ab47ef2f2207
disable blocking compilation requests once GraalRuntime::shutdown has been called
Doug Simon <doug.simon@oracle.com>
parents:
18227
diff
changeset
|
1006 _shutdown_called = true; |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1007 JavaThread* THREAD = JavaThread::current(); |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1008 HandleMark hm(THREAD); |
16428
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
1009 TempNewSymbol name = SymbolTable::new_symbol("com/oracle/graal/hotspot/HotSpotGraalRuntime", CHECK_ABORT); |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1010 KlassHandle klass = load_required_class(name); |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1011 JavaValue result(T_VOID); |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1012 JavaCallArguments args; |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1013 args.push_oop(get_HotSpotGraalRuntime()); |
16428
78ddecd6255f
added CHECK macros in uses of SymbolTable::new_symbol; added CHECK_ABORT macros for TRAPS functions that must abort the VM if they throw an exception
Doug Simon <doug.simon@oracle.com>
parents:
16399
diff
changeset
|
1014 JavaCalls::call_special(&result, klass, vmSymbols::shutdown_method_name(), vmSymbols::void_method_signature(), &args, CHECK_ABORT); |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1015 |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1016 JNIHandles::destroy_global(_HotSpotGraalRuntime_instance); |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1017 _HotSpotGraalRuntime_instance = NULL; |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1018 } |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1019 } |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1020 |
16273
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
1021 void GraalRuntime::call_printStackTrace(Handle exception, Thread* thread) { |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
1022 assert(exception->is_a(SystemDictionary::Throwable_klass()), "Throwable instance expected"); |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
1023 JavaValue result(T_VOID); |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
1024 JavaCalls::call_virtual(&result, |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
1025 exception, |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
1026 KlassHandle(thread, |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
1027 SystemDictionary::Throwable_klass()), |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
1028 vmSymbols::printStackTrace_name(), |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
1029 vmSymbols::void_method_signature(), |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
1030 thread); |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
1031 } |
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
1032 |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1033 void GraalRuntime::abort_on_pending_exception(Handle exception, const char* message, bool dump_core) { |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1034 Thread* THREAD = Thread::current(); |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1035 CLEAR_PENDING_EXCEPTION; |
18043
f55f2d400797
Fix some format strings
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
17319
diff
changeset
|
1036 tty->print_raw_cr(message); |
16273
d6ffc6164830
handle any exception raised during Graal option checking/parsing, not just those with a non-null message
Doug Simon <doug.simon@oracle.com>
parents:
16270
diff
changeset
|
1037 call_printStackTrace(exception, THREAD); |
16679
58622d6b1097
give all aborting threads a chance to print Graal related stack traces
Doug Simon <doug.simon@oracle.com>
parents:
16628
diff
changeset
|
1038 |
58622d6b1097
give all aborting threads a chance to print Graal related stack traces
Doug Simon <doug.simon@oracle.com>
parents:
16628
diff
changeset
|
1039 // Give other aborting threads to also print their stack traces. |
58622d6b1097
give all aborting threads a chance to print Graal related stack traces
Doug Simon <doug.simon@oracle.com>
parents:
16628
diff
changeset
|
1040 // This can be very useful when debugging class initialization |
58622d6b1097
give all aborting threads a chance to print Graal related stack traces
Doug Simon <doug.simon@oracle.com>
parents:
16628
diff
changeset
|
1041 // failures. |
58622d6b1097
give all aborting threads a chance to print Graal related stack traces
Doug Simon <doug.simon@oracle.com>
parents:
16628
diff
changeset
|
1042 os::sleep(THREAD, 200, false); |
58622d6b1097
give all aborting threads a chance to print Graal related stack traces
Doug Simon <doug.simon@oracle.com>
parents:
16628
diff
changeset
|
1043 |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1044 vm_abort(dump_core); |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1045 } |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1046 |
16395
ad431bf0de07
added support to load classes from graal.jar with a separate class loader
Doug Simon <doug.simon@oracle.com>
parents:
16291
diff
changeset
|
1047 Klass* GraalRuntime::resolve_or_null(Symbol* name, TRAPS) { |
ad431bf0de07
added support to load classes from graal.jar with a separate class loader
Doug Simon <doug.simon@oracle.com>
parents:
16291
diff
changeset
|
1048 return SystemDictionary::resolve_or_null(name, SystemDictionary::graal_loader(), Handle(), CHECK_NULL); |
ad431bf0de07
added support to load classes from graal.jar with a separate class loader
Doug Simon <doug.simon@oracle.com>
parents:
16291
diff
changeset
|
1049 } |
ad431bf0de07
added support to load classes from graal.jar with a separate class loader
Doug Simon <doug.simon@oracle.com>
parents:
16291
diff
changeset
|
1050 |
ad431bf0de07
added support to load classes from graal.jar with a separate class loader
Doug Simon <doug.simon@oracle.com>
parents:
16291
diff
changeset
|
1051 Klass* GraalRuntime::resolve_or_fail(Symbol* name, TRAPS) { |
ad431bf0de07
added support to load classes from graal.jar with a separate class loader
Doug Simon <doug.simon@oracle.com>
parents:
16291
diff
changeset
|
1052 return SystemDictionary::resolve_or_fail(name, SystemDictionary::graal_loader(), Handle(), true, CHECK_NULL); |
ad431bf0de07
added support to load classes from graal.jar with a separate class loader
Doug Simon <doug.simon@oracle.com>
parents:
16291
diff
changeset
|
1053 } |
ad431bf0de07
added support to load classes from graal.jar with a separate class loader
Doug Simon <doug.simon@oracle.com>
parents:
16291
diff
changeset
|
1054 |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1055 Klass* GraalRuntime::load_required_class(Symbol* name) { |
16395
ad431bf0de07
added support to load classes from graal.jar with a separate class loader
Doug Simon <doug.simon@oracle.com>
parents:
16291
diff
changeset
|
1056 Klass* klass = resolve_or_null(name, Thread::current()); |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1057 if (klass == NULL) { |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1058 tty->print_cr("Could not load class %s", name->as_C_string()); |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1059 vm_abort(false); |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1060 } |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1061 return klass; |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1062 } |
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15916
diff
changeset
|
1063 |
15916
6aa352b260f4
removed use of ServiceLoader in runtime initialization
Doug Simon <doug.simon@oracle.com>
parents:
15894
diff
changeset
|
1064 #include "graalRuntime.inline.hpp" |