mirror of
https://github.com/corda/corda.git
synced 2025-01-17 02:09:50 +00:00
implement more JVM_* methods and avoid duplicate array class loading
This commit is contained in:
parent
d819a75f36
commit
f485016637
23
classpath/avian/OpenJDK.java
Normal file
23
classpath/avian/OpenJDK.java
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
/* Copyright (c) 2010, Avian Contributors
|
||||||
|
|
||||||
|
Permission to use, copy, modify, and/or distribute this software
|
||||||
|
for any purpose with or without fee is hereby granted, provided
|
||||||
|
that the above copyright notice and this permission notice appear
|
||||||
|
in all copies.
|
||||||
|
|
||||||
|
There is NO WARRANTY for this software. See license.txt for
|
||||||
|
details. */
|
||||||
|
|
||||||
|
package avian;
|
||||||
|
|
||||||
|
import java.security.AllPermission;
|
||||||
|
import java.security.Permissions;
|
||||||
|
import java.security.ProtectionDomain;
|
||||||
|
|
||||||
|
public class OpenJDK {
|
||||||
|
public static ProtectionDomain getProtectionDomain() {
|
||||||
|
Permissions p = new Permissions();
|
||||||
|
p.add(new AllPermission());
|
||||||
|
return new ProtectionDomain(null, p);
|
||||||
|
}
|
||||||
|
}
|
5
makefile
5
makefile
@ -444,6 +444,11 @@ ifneq ($(classpath),avian)
|
|||||||
$(classpath-src)/avian/VMField.java \
|
$(classpath-src)/avian/VMField.java \
|
||||||
$(classpath-src)/avian/VMMethod.java \
|
$(classpath-src)/avian/VMMethod.java \
|
||||||
$(classpath-src)/avian/resource/Handler.java
|
$(classpath-src)/avian/resource/Handler.java
|
||||||
|
|
||||||
|
ifdef openjdk
|
||||||
|
classpath-sources := $(classpath-sources) \
|
||||||
|
$(classpath-src)/avian/OpenJDK.java
|
||||||
|
endif
|
||||||
else
|
else
|
||||||
classpath-sources := $(shell find $(classpath-src) -name '*.java')
|
classpath-sources := $(shell find $(classpath-src) -name '*.java')
|
||||||
endif
|
endif
|
||||||
|
@ -251,6 +251,22 @@ class MyClasspath : public Classpath {
|
|||||||
t->m->processor->invoke
|
t->m->processor->invoke
|
||||||
(t, constructor, root(t, Machine::AppLoader),
|
(t, constructor, root(t, Machine::AppLoader),
|
||||||
root(t, Machine::BootLoader));
|
root(t, Machine::BootLoader));
|
||||||
|
if (UNLIKELY(t->exception)) return;
|
||||||
|
|
||||||
|
object scl = resolveField
|
||||||
|
(t, type(t, Machine::ClassLoaderType), "scl", "Ljava/lang/ClassLoader;");
|
||||||
|
if (UNLIKELY(t->exception)) return;
|
||||||
|
PROTECT(t, scl);
|
||||||
|
|
||||||
|
object sclSet = resolveField
|
||||||
|
(t, type(t, Machine::ClassLoaderType), "sclSet", "Z");
|
||||||
|
if (UNLIKELY(t->exception)) return;
|
||||||
|
|
||||||
|
set(t, classStaticTable(t, type(t, Machine::ClassLoaderType)),
|
||||||
|
fieldOffset(t, scl), root(t, Machine::AppLoader));
|
||||||
|
|
||||||
|
cast<uint8_t>(classStaticTable(t, type(t, Machine::ClassLoaderType)),
|
||||||
|
fieldOffset(t, sclSet)) = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void
|
virtual void
|
||||||
@ -593,6 +609,38 @@ Avian_sun_misc_Unsafe_staticFieldOffset
|
|||||||
(t, jclassVmClass(t, jfieldClazz(t, jfield))), jfieldSlot(t, jfield)));
|
(t, jclassVmClass(t, jfieldClazz(t, jfield))), jfieldSlot(t, jfield)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern "C" JNIEXPORT int64_t JNICALL
|
||||||
|
Avian_sun_misc_Unsafe_arrayBaseOffset
|
||||||
|
(Thread*, object, uintptr_t*)
|
||||||
|
{
|
||||||
|
return BytesPerWord * 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" JNIEXPORT int64_t JNICALL
|
||||||
|
Avian_sun_misc_Unsafe_arrayIndexScale
|
||||||
|
(Thread* t, object, uintptr_t* arguments)
|
||||||
|
{
|
||||||
|
object c = jclassVmClass(t, reinterpret_cast<object>(arguments[1]));
|
||||||
|
|
||||||
|
if (classVmFlags(t, c) & PrimitiveFlag) {
|
||||||
|
const char* name = reinterpret_cast<char*>
|
||||||
|
(&byteArrayBody(t, local::getClassName(t, c), 0));
|
||||||
|
|
||||||
|
switch (*name) {
|
||||||
|
case 'b': return 1;
|
||||||
|
case 's':
|
||||||
|
case 'c': return 2;
|
||||||
|
case 'l':
|
||||||
|
case 'd': return 8;
|
||||||
|
case 'i':
|
||||||
|
case 'f': return 4;
|
||||||
|
default: abort(t);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return BytesPerWord;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT int64_t JNICALL
|
extern "C" JNIEXPORT int64_t JNICALL
|
||||||
Avian_sun_misc_Unsafe_staticFieldBase
|
Avian_sun_misc_Unsafe_staticFieldBase
|
||||||
(Thread* t, object, uintptr_t* arguments)
|
(Thread* t, object, uintptr_t* arguments)
|
||||||
@ -645,6 +693,18 @@ Avian_sun_misc_Unsafe_getInt__Ljava_lang_Object_2J
|
|||||||
return cast<int32_t>(o, offset);
|
return cast<int32_t>(o, offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern "C" JNIEXPORT int64_t JNICALL
|
||||||
|
Avian_sun_misc_Unsafe_getIntVolatile
|
||||||
|
(Thread*, object, uintptr_t* arguments)
|
||||||
|
{
|
||||||
|
object o = reinterpret_cast<object>(arguments[1]);
|
||||||
|
int64_t offset; memcpy(&offset, arguments + 2, 8);
|
||||||
|
|
||||||
|
int32_t result = cast<int32_t>(o, offset);
|
||||||
|
loadMemoryBarrier();
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT void JNICALL
|
extern "C" JNIEXPORT void JNICALL
|
||||||
Avian_sun_misc_Unsafe_putInt__Ljava_lang_Object_2JI
|
Avian_sun_misc_Unsafe_putInt__Ljava_lang_Object_2JI
|
||||||
(Thread*, object, uintptr_t* arguments)
|
(Thread*, object, uintptr_t* arguments)
|
||||||
@ -1026,13 +1086,22 @@ extern "C" JNIEXPORT void JNICALL
|
|||||||
JVM_TraceMethodCalls(jboolean) { abort(); }
|
JVM_TraceMethodCalls(jboolean) { abort(); }
|
||||||
|
|
||||||
extern "C" JNIEXPORT jlong JNICALL
|
extern "C" JNIEXPORT jlong JNICALL
|
||||||
JVM_TotalMemory(void) { abort(); }
|
JVM_TotalMemory()
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jlong JNICALL
|
extern "C" JNIEXPORT jlong JNICALL
|
||||||
JVM_FreeMemory(void) { abort(); }
|
JVM_FreeMemory()
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jlong JNICALL
|
extern "C" JNIEXPORT jlong JNICALL
|
||||||
JVM_MaxMemory(void) { abort(); }
|
JVM_MaxMemory()
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jint JNICALL
|
extern "C" JNIEXPORT jint JNICALL
|
||||||
JVM_ActiveProcessorCount(void) { abort(); }
|
JVM_ActiveProcessorCount(void) { abort(); }
|
||||||
@ -1182,7 +1251,15 @@ extern "C" JNIEXPORT jint JNICALL
|
|||||||
JVM_CountStackFrames(Thread*, jobject) { abort(); }
|
JVM_CountStackFrames(Thread*, jobject) { abort(); }
|
||||||
|
|
||||||
extern "C" JNIEXPORT void JNICALL
|
extern "C" JNIEXPORT void JNICALL
|
||||||
JVM_Interrupt(Thread*, jobject) { abort(); }
|
JVM_Interrupt(Thread* t, jobject thread)
|
||||||
|
{
|
||||||
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
|
Thread* p = reinterpret_cast<Thread*>(threadPeer(t, *thread));
|
||||||
|
if (p) {
|
||||||
|
interrupt(t, p);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jboolean JNICALL
|
extern "C" JNIEXPORT jboolean JNICALL
|
||||||
JVM_IsInterrupted(Thread* t, jobject thread, jboolean clear)
|
JVM_IsInterrupted(Thread* t, jobject thread, jboolean clear)
|
||||||
@ -1246,7 +1323,10 @@ extern "C" JNIEXPORT jint JNICALL
|
|||||||
JVM_ClassLoaderDepth(Thread*) { abort(); }
|
JVM_ClassLoaderDepth(Thread*) { abort(); }
|
||||||
|
|
||||||
extern "C" JNIEXPORT jstring JNICALL
|
extern "C" JNIEXPORT jstring JNICALL
|
||||||
JVM_GetSystemPackage(Thread*, jstring) { abort(); }
|
JVM_GetSystemPackage(Thread*, jstring)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jobjectArray JNICALL
|
extern "C" JNIEXPORT jobjectArray JNICALL
|
||||||
JVM_GetSystemPackages(Thread*) { abort(); }
|
JVM_GetSystemPackages(Thread*) { abort(); }
|
||||||
@ -1434,13 +1514,23 @@ JVM_FindLoadedClass(Thread* t, jobject loader, jstring name)
|
|||||||
}
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jclass JNICALL
|
extern "C" JNIEXPORT jclass JNICALL
|
||||||
JVM_DefineClass(Thread*, const char*, jobject, const jbyte*,
|
JVM_DefineClass(Thread* t, const char*, jobject loader, const uint8_t* data,
|
||||||
jsize, jobject) { abort(); }
|
jsize length, jobject)
|
||||||
|
{
|
||||||
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
|
object c = defineClass(t, *loader, data, length);
|
||||||
|
|
||||||
|
return c ? makeLocalReference(t, getJClass(t, c)) : 0;
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jclass JNICALL
|
extern "C" JNIEXPORT jclass JNICALL
|
||||||
JVM_DefineClassWithSource(Thread*, const char*, jobject,
|
JVM_DefineClassWithSource(Thread* t, const char*, jobject loader,
|
||||||
const jbyte*, jsize, jobject,
|
const uint8_t* data, jsize length, jobject,
|
||||||
const char*) { abort(); }
|
const char*)
|
||||||
|
{
|
||||||
|
return JVM_DefineClass(t, 0, loader, data, length, 0);
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jstring JNICALL
|
extern "C" JNIEXPORT jstring JNICALL
|
||||||
JVM_GetClassName(Thread* t, jclass c)
|
JVM_GetClassName(Thread* t, jclass c)
|
||||||
@ -1501,7 +1591,20 @@ extern "C" JNIEXPORT void JNICALL
|
|||||||
JVM_SetClassSigners(Thread*, jclass, jobjectArray) { abort(); }
|
JVM_SetClassSigners(Thread*, jclass, jobjectArray) { abort(); }
|
||||||
|
|
||||||
extern "C" JNIEXPORT jobject JNICALL
|
extern "C" JNIEXPORT jobject JNICALL
|
||||||
JVM_GetProtectionDomain(Thread*, jclass) { abort(); }
|
JVM_GetProtectionDomain(Thread* t, jclass)
|
||||||
|
{
|
||||||
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
|
object openJDK = resolveClass
|
||||||
|
(t, root(t, Machine::BootLoader), "avian/OpenJDK");
|
||||||
|
if (UNLIKELY(t->exception)) return 0;
|
||||||
|
|
||||||
|
object method = resolveMethod
|
||||||
|
(t, openJDK, "getProtectionDomain", "()Ljava/security/ProtectionDomain;");
|
||||||
|
if (UNLIKELY(t->exception)) return 0;
|
||||||
|
|
||||||
|
return makeLocalReference(t, t->m->processor->invoke(t, method, 0));
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT void JNICALL
|
extern "C" JNIEXPORT void JNICALL
|
||||||
JVM_SetProtectionDomain(Thread*, jclass, jobject) { abort(); }
|
JVM_SetProtectionDomain(Thread*, jclass, jobject) { abort(); }
|
||||||
@ -1625,10 +1728,6 @@ JVM_GetClassDeclaredMethods(Thread* t, jclass c, jboolean publicOnly)
|
|||||||
? 0 : addendumAnnotationTable(t, methodAddendum(t, vmMethod));
|
? 0 : addendumAnnotationTable(t, methodAddendum(t, vmMethod));
|
||||||
|
|
||||||
if (annotationTable) {
|
if (annotationTable) {
|
||||||
fprintf(stderr, "method %s.%s has annotations\n",
|
|
||||||
&byteArrayBody(t, className(t, jclassVmClass(t, *c)), 0),
|
|
||||||
&byteArrayBody(t, methodName(t, vmMethod), 0));
|
|
||||||
|
|
||||||
set(t, classAddendum(t, jclassVmClass(t, *c)), AddendumPool,
|
set(t, classAddendum(t, jclassVmClass(t, *c)), AddendumPool,
|
||||||
addendumPool(t, methodAddendum(t, vmMethod)));
|
addendumPool(t, methodAddendum(t, vmMethod)));
|
||||||
}
|
}
|
||||||
@ -1809,6 +1908,10 @@ JVM_InvokeMethod(Thread* t, jobject method, jobject instance,
|
|||||||
(t, jclassVmClass(t, jmethodClazz(t, *method))),
|
(t, jclassVmClass(t, jmethodClazz(t, *method))),
|
||||||
jmethodSlot(t, *method));
|
jmethodSlot(t, *method));
|
||||||
|
|
||||||
|
if (methodFlags(t, vmMethod) & ACC_STATIC) {
|
||||||
|
instance = 0;
|
||||||
|
}
|
||||||
|
|
||||||
object result;
|
object result;
|
||||||
if (arguments) {
|
if (arguments) {
|
||||||
result = t->m->processor->invokeArray
|
result = t->m->processor->invokeArray
|
||||||
@ -2191,7 +2294,10 @@ extern "C" JNIEXPORT jint JNICALL
|
|||||||
JVM_SetLength(jint, jlong) { abort(); }
|
JVM_SetLength(jint, jlong) { abort(); }
|
||||||
|
|
||||||
extern "C" JNIEXPORT jint JNICALL
|
extern "C" JNIEXPORT jint JNICALL
|
||||||
JVM_Sync(jint) { abort(); }
|
JVM_Sync(jint fd)
|
||||||
|
{
|
||||||
|
return fsync(fd);
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jint JNICALL
|
extern "C" JNIEXPORT jint JNICALL
|
||||||
JVM_InitializeSocketLibrary()
|
JVM_InitializeSocketLibrary()
|
||||||
|
@ -1789,7 +1789,12 @@ makeArrayClass(Thread* t, object loader, object spec, bool throw_)
|
|||||||
if (elementClass == 0) return 0;
|
if (elementClass == 0) return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return makeArrayClass(t, loader, dimensions, spec, elementClass);
|
object class_ = hashMapFind
|
||||||
|
(t, getClassLoaderMap(t, classLoader(t, elementClass)), spec,
|
||||||
|
byteArrayHash, byteArrayEqual);
|
||||||
|
|
||||||
|
return class_ ? class_ : makeArrayClass
|
||||||
|
(t, classLoader(t, elementClass), dimensions, spec, elementClass);
|
||||||
}
|
}
|
||||||
|
|
||||||
object
|
object
|
||||||
@ -2281,15 +2286,19 @@ Thread::init()
|
|||||||
if (parent == 0) {
|
if (parent == 0) {
|
||||||
enter(this, Thread::ActiveState);
|
enter(this, Thread::ActiveState);
|
||||||
|
|
||||||
|
if (exception == 0) {
|
||||||
|
setRoot(this, Machine::NullPointerException, m->classpath->makeThrowable
|
||||||
|
(this, Machine::NullPointerExceptionType));
|
||||||
|
|
||||||
|
if (exception == 0) {
|
||||||
|
setRoot(this, Machine::ArrayIndexOutOfBoundsException,
|
||||||
|
m->classpath->makeThrowable
|
||||||
|
(this, Machine::IndexOutOfBoundsExceptionType));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
m->classpath->boot(this);
|
m->classpath->boot(this);
|
||||||
|
|
||||||
setRoot(this, Machine::NullPointerException, m->classpath->makeThrowable
|
|
||||||
(this, Machine::NullPointerExceptionType));
|
|
||||||
|
|
||||||
setRoot(this, Machine::ArrayIndexOutOfBoundsException,
|
|
||||||
m->classpath->makeThrowable
|
|
||||||
(this, Machine::IndexOutOfBoundsExceptionType));
|
|
||||||
|
|
||||||
enter(this, Thread::IdleState);
|
enter(this, Thread::IdleState);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2441,7 +2450,7 @@ enter(Thread* t, Thread::State s)
|
|||||||
// todo: this won't always help if some other thread sets the
|
// todo: this won't always help if some other thread sets the
|
||||||
// daemon field. The thread trying to shut down the VM really
|
// daemon field. The thread trying to shut down the VM really
|
||||||
// just needs to count from scratch every time any thread makes a
|
// just needs to count from scratch every time any thread makes a
|
||||||
// transition.
|
// transition (i.e. eliminate Machine::daemonCount).
|
||||||
|
|
||||||
if (UNLIKELY(((t->flags & Thread::DaemonFlag) != 0)
|
if (UNLIKELY(((t->flags & Thread::DaemonFlag) != 0)
|
||||||
!= threadDaemon(t, t->javaThread)))
|
!= threadDaemon(t, t->javaThread)))
|
||||||
|
Loading…
Reference in New Issue
Block a user