Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/runtime/jcl/common/compiler.c
6000 views
1
/*******************************************************************************
2
* Copyright (c) 1998, 2018 IBM Corp. and others
3
*
4
* This program and the accompanying materials are made available under
5
* the terms of the Eclipse Public License 2.0 which accompanies this
6
* distribution and is available at https://www.eclipse.org/legal/epl-2.0/
7
* or the Apache License, Version 2.0 which accompanies this distribution and
8
* is available at https://www.apache.org/licenses/LICENSE-2.0.
9
*
10
* This Source Code may also be made available under the following
11
* Secondary Licenses when the conditions for such availability set
12
* forth in the Eclipse Public License, v. 2.0 are satisfied: GNU
13
* General Public License, version 2 with the GNU Classpath
14
* Exception [1] and GNU General Public License, version 2 with the
15
* OpenJDK Assembly Exception [2].
16
*
17
* [1] https://www.gnu.org/software/classpath/license.html
18
* [2] http://openjdk.java.net/legal/assembly-exception.html
19
*
20
* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 OR LicenseRef-GPL-2.0 WITH Assembly-exception
21
*******************************************************************************/
22
23
#include "j9.h"
24
#include "jcl.h"
25
26
27
void JNICALL Java_java_lang_Compiler_enable(JNIEnv *env, jclass clazz)
28
{
29
#ifdef J9VM_INTERP_NATIVE_SUPPORT
30
J9VMThread *currentThread = (J9VMThread *) env;
31
J9JavaVM *vm = currentThread->javaVM;
32
J9JITConfig * jitConfig = vm->jitConfig;
33
34
if ((jitConfig != NULL) && (jitConfig->enableJit != NULL)) {
35
#if defined(J9VM_INTERP_ATOMIC_FREE_JNI)
36
J9InternalVMFunctions *vmFuncs = vm->internalVMFunctions;
37
vmFuncs->internalEnterVMFromJNI(currentThread);
38
vmFuncs->internalReleaseVMAccess(currentThread);
39
#endif /* J9VM_INTERP_ATOMIC_FREE_JNI */
40
jitConfig->enableJit(jitConfig);
41
}
42
#endif
43
}
44
45
46
void JNICALL Java_java_lang_Compiler_disable(JNIEnv *env, jclass clazz)
47
{
48
#ifdef J9VM_INTERP_NATIVE_SUPPORT
49
J9VMThread *currentThread = (J9VMThread *) env;
50
J9JavaVM *vm = currentThread->javaVM;
51
J9JITConfig * jitConfig = vm->jitConfig;
52
53
if ((jitConfig != NULL) && (jitConfig->disableJit != NULL)) {
54
#if defined(J9VM_INTERP_ATOMIC_FREE_JNI)
55
J9InternalVMFunctions *vmFuncs = vm->internalVMFunctions;
56
vmFuncs->internalEnterVMFromJNI(currentThread);
57
vmFuncs->internalReleaseVMAccess(currentThread);
58
#endif /* J9VM_INTERP_ATOMIC_FREE_JNI */
59
jitConfig->disableJit(jitConfig);
60
}
61
#endif
62
}
63
64
65
jobject JNICALL Java_java_lang_Compiler_commandImpl(JNIEnv *env, jclass clazz, jobject cmd)
66
{
67
#ifdef J9VM_INTERP_NATIVE_SUPPORT
68
J9VMThread *currentThread = (J9VMThread *) env;
69
J9JavaVM *vm = currentThread->javaVM;
70
J9JITConfig * jitConfig = vm->jitConfig;
71
72
if ((cmd != NULL) && (jitConfig != NULL) && (jitConfig->command != NULL)) {
73
jclass stringClass = (*env)->FindClass(env, "java/lang/String");
74
75
if (stringClass != NULL) {
76
jclass intClass = (*env)->FindClass(env, "java/lang/Integer");
77
78
if (intClass != NULL) {
79
jmethodID mid = (*env)->GetMethodID(env, intClass, "<init>", "(I)V");
80
81
if (mid != NULL) {
82
if ((*env)->IsInstanceOf(env, cmd, stringClass)) {
83
const char * commandString = (const char *) (*env)->GetStringUTFChars(env, cmd, NULL);
84
85
if (commandString != NULL) {
86
I_32 result = 0;
87
#if defined(J9VM_INTERP_ATOMIC_FREE_JNI)
88
J9InternalVMFunctions *vmFuncs = vm->internalVMFunctions;
89
vmFuncs->internalEnterVMFromJNI(currentThread);
90
vmFuncs->internalReleaseVMAccess(currentThread);
91
#endif /* J9VM_INTERP_ATOMIC_FREE_JNI */
92
result = jitConfig->command(currentThread, commandString);
93
(*env)->ReleaseStringUTFChars(env, cmd, commandString);
94
return (*env)->NewObject(env, intClass, mid, result);
95
}
96
}
97
}
98
}
99
}
100
}
101
#endif
102
return NULL;
103
}
104
105
106
jboolean JNICALL Java_java_lang_Compiler_compileClassImpl(JNIEnv *env, jclass clazz, jclass compileClass)
107
{
108
jboolean rc = JNI_FALSE;
109
#ifdef J9VM_INTERP_NATIVE_SUPPORT
110
J9VMThread *currentThread = (J9VMThread *) env;
111
J9JavaVM *vm = currentThread->javaVM;
112
J9JITConfig * jitConfig = vm->jitConfig;
113
114
if ((compileClass != NULL) && (jitConfig != NULL) && (jitConfig->compileClass != NULL)) {
115
#if defined(J9VM_INTERP_ATOMIC_FREE_JNI)
116
J9InternalVMFunctions *vmFuncs = vm->internalVMFunctions;
117
vmFuncs->internalEnterVMFromJNI(currentThread);
118
vmFuncs->internalReleaseVMAccess(currentThread);
119
#endif /* J9VM_INTERP_ATOMIC_FREE_JNI */
120
rc = (jboolean)jitConfig->compileClass(currentThread, compileClass);
121
}
122
#endif
123
return rc;
124
}
125
126
127
jboolean JNICALL Java_java_lang_Compiler_compileClassesImpl(JNIEnv *env, jclass clazz, jstring nameRoot)
128
{
129
#ifdef J9VM_INTERP_NATIVE_SUPPORT
130
J9VMThread *currentThread = (J9VMThread *) env;
131
J9JavaVM *vm = currentThread->javaVM;
132
J9JITConfig * jitConfig = vm->jitConfig;
133
134
if ((nameRoot != NULL) && (jitConfig != NULL) && (jitConfig->compileClasses != NULL)) {
135
const char * pattern;
136
137
pattern = (const char *) (*env)->GetStringUTFChars(env, nameRoot, NULL);
138
if (pattern != NULL) {
139
jboolean rc;
140
141
#if defined(J9VM_INTERP_ATOMIC_FREE_JNI)
142
J9InternalVMFunctions *vmFuncs = vm->internalVMFunctions;
143
vmFuncs->internalEnterVMFromJNI(currentThread);
144
vmFuncs->internalReleaseVMAccess(currentThread);
145
#endif /* J9VM_INTERP_ATOMIC_FREE_JNI */
146
rc = (jboolean) jitConfig->compileClasses(currentThread, pattern);
147
(*env)->ReleaseStringUTFChars(env, nameRoot, pattern);
148
return rc;
149
}
150
}
151
#endif
152
return JNI_FALSE;
153
}
154
155