mirror of
https://github.com/corda/corda.git
synced 2025-01-22 12:28:11 +00:00
start work on OpenJDK 7 class library port
This commit is contained in:
parent
999e90c332
commit
bc5661d6f3
13
classpath/java/lang/ReflectiveOperationException.java
Normal file
13
classpath/java/lang/ReflectiveOperationException.java
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
/* Copyright (c) 2012, 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 java.lang;
|
||||||
|
|
||||||
|
public class ReflectiveOperationException extends Exception { }
|
@ -45,7 +45,6 @@ openjdk-sources = \
|
|||||||
$(openjdk-src)/share/native/java/util/zip/CRC32.c \
|
$(openjdk-src)/share/native/java/util/zip/CRC32.c \
|
||||||
$(openjdk-src)/share/native/java/util/zip/Deflater.c \
|
$(openjdk-src)/share/native/java/util/zip/Deflater.c \
|
||||||
$(openjdk-src)/share/native/java/util/zip/Inflater.c \
|
$(openjdk-src)/share/native/java/util/zip/Inflater.c \
|
||||||
$(openjdk-src)/share/native/java/util/zip/ZipEntry.c \
|
|
||||||
$(openjdk-src)/share/native/java/util/zip/ZipFile.c \
|
$(openjdk-src)/share/native/java/util/zip/ZipFile.c \
|
||||||
$(openjdk-src)/share/native/java/util/zip/zip_util.c \
|
$(openjdk-src)/share/native/java/util/zip/zip_util.c \
|
||||||
$(openjdk-src)/share/native/sun/management/VMManagementImpl.c \
|
$(openjdk-src)/share/native/sun/management/VMManagementImpl.c \
|
||||||
@ -76,6 +75,7 @@ openjdk-headers-classes = \
|
|||||||
java.lang.Double \
|
java.lang.Double \
|
||||||
java.lang.Float \
|
java.lang.Float \
|
||||||
java.lang.Integer \
|
java.lang.Integer \
|
||||||
|
java.lang.Long \
|
||||||
java.lang.Object \
|
java.lang.Object \
|
||||||
java.lang.Package \
|
java.lang.Package \
|
||||||
java.lang.Runtime \
|
java.lang.Runtime \
|
||||||
@ -124,7 +124,7 @@ openjdk-headers-classes = \
|
|||||||
sun.net.spi.DefaultProxySelector \
|
sun.net.spi.DefaultProxySelector \
|
||||||
sun.nio.ch.FileKey \
|
sun.nio.ch.FileKey \
|
||||||
sun.nio.ch.FileChannelImpl \
|
sun.nio.ch.FileChannelImpl \
|
||||||
sun.nio.ch.FileDispatcher \
|
sun.nio.ch.FileDispatcherImpl \
|
||||||
sun.nio.ch.DatagramChannelImpl \
|
sun.nio.ch.DatagramChannelImpl \
|
||||||
sun.nio.ch.DatagramDispatcher \
|
sun.nio.ch.DatagramDispatcher \
|
||||||
sun.nio.ch.IOStatus \
|
sun.nio.ch.IOStatus \
|
||||||
@ -235,6 +235,10 @@ ifeq ($(platform),windows)
|
|||||||
else
|
else
|
||||||
openjdk-sources += \
|
openjdk-sources += \
|
||||||
$(openjdk-src)/solaris/native/common/jdk_util_md.c \
|
$(openjdk-src)/solaris/native/common/jdk_util_md.c \
|
||||||
|
$(openjdk-src)/solaris/native/common/jni_util_md.c \
|
||||||
|
$(openjdk-src)/solaris/native/common/deps/syscalls_fp.c \
|
||||||
|
$(openjdk-src)/solaris/native/common/deps/gconf2/gconf_fp.c \
|
||||||
|
$(openjdk-src)/solaris/native/common/deps/glib2/gio_fp.c \
|
||||||
$(openjdk-src)/solaris/native/java/io/canonicalize_md.c \
|
$(openjdk-src)/solaris/native/java/io/canonicalize_md.c \
|
||||||
$(openjdk-src)/solaris/native/java/io/Console_md.c \
|
$(openjdk-src)/solaris/native/java/io/Console_md.c \
|
||||||
$(openjdk-src)/solaris/native/java/io/FileDescriptor_md.c \
|
$(openjdk-src)/solaris/native/java/io/FileDescriptor_md.c \
|
||||||
@ -265,7 +269,7 @@ else
|
|||||||
$(openjdk-src)/solaris/native/sun/nio/ch/DatagramChannelImpl.c \
|
$(openjdk-src)/solaris/native/sun/nio/ch/DatagramChannelImpl.c \
|
||||||
$(openjdk-src)/solaris/native/sun/nio/ch/DatagramDispatcher.c \
|
$(openjdk-src)/solaris/native/sun/nio/ch/DatagramDispatcher.c \
|
||||||
$(openjdk-src)/solaris/native/sun/nio/ch/FileChannelImpl.c \
|
$(openjdk-src)/solaris/native/sun/nio/ch/FileChannelImpl.c \
|
||||||
$(openjdk-src)/solaris/native/sun/nio/ch/FileDispatcher.c \
|
$(openjdk-src)/solaris/native/sun/nio/ch/FileDispatcherImpl.c \
|
||||||
$(openjdk-src)/solaris/native/sun/nio/ch/FileKey.c \
|
$(openjdk-src)/solaris/native/sun/nio/ch/FileKey.c \
|
||||||
$(openjdk-src)/solaris/native/sun/nio/ch/IOUtil.c \
|
$(openjdk-src)/solaris/native/sun/nio/ch/IOUtil.c \
|
||||||
$(openjdk-src)/solaris/native/sun/nio/ch/Net.c \
|
$(openjdk-src)/solaris/native/sun/nio/ch/Net.c \
|
||||||
@ -276,6 +280,7 @@ else
|
|||||||
$(openjdk-src)/solaris/native/sun/nio/ch/PollArrayWrapper.c \
|
$(openjdk-src)/solaris/native/sun/nio/ch/PollArrayWrapper.c \
|
||||||
$(openjdk-src)/solaris/native/sun/nio/ch/InheritedChannel.c \
|
$(openjdk-src)/solaris/native/sun/nio/ch/InheritedChannel.c \
|
||||||
$(openjdk-src)/solaris/native/sun/nio/ch/NativeThread.c \
|
$(openjdk-src)/solaris/native/sun/nio/ch/NativeThread.c \
|
||||||
|
$(openjdk-src)/solaris/native/sun/nio/fs/UnixNativeDispatcher.c \
|
||||||
|
|
||||||
ifeq ($(platform),linux)
|
ifeq ($(platform),linux)
|
||||||
openjdk-sources += \
|
openjdk-sources += \
|
||||||
@ -287,6 +292,7 @@ else
|
|||||||
java.io.UnixFileSystem \
|
java.io.UnixFileSystem \
|
||||||
sun.nio.ch.InheritedChannel \
|
sun.nio.ch.InheritedChannel \
|
||||||
sun.nio.ch.EPollArrayWrapper \
|
sun.nio.ch.EPollArrayWrapper \
|
||||||
|
sun.nio.fs.UnixNativeDispatcher \
|
||||||
|
|
||||||
openjdk-cflags += "-I$(openjdk-src)/solaris/javavm/export" \
|
openjdk-cflags += "-I$(openjdk-src)/solaris/javavm/export" \
|
||||||
"-I$(openjdk-src)/solaris/native/common" \
|
"-I$(openjdk-src)/solaris/native/common" \
|
||||||
@ -297,7 +303,12 @@ else
|
|||||||
"-I$(openjdk-src)/solaris/native/sun/management" \
|
"-I$(openjdk-src)/solaris/native/sun/management" \
|
||||||
"-I$(openjdk-src)/solaris/native/sun/nio/ch" \
|
"-I$(openjdk-src)/solaris/native/sun/nio/ch" \
|
||||||
"-I$(openjdk-src)/solaris/javavm/include" \
|
"-I$(openjdk-src)/solaris/javavm/include" \
|
||||||
"-I$(openjdk-src)/solaris/hpi/include"
|
"-I$(openjdk-src)/solaris/hpi/include" \
|
||||||
|
"-I$(openjdk-src)/solaris/native/common/deps" \
|
||||||
|
"-I$(openjdk-src)/solaris/native/common/deps/glib2" \
|
||||||
|
"-I$(openjdk-src)/solaris/native/common/deps/gconf2" \
|
||||||
|
$(shell pkg-config --cflags glib-2.0) \
|
||||||
|
$(shell pkg-config --cflags gconf-2.0)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
openjdk-local-sources = \
|
openjdk-local-sources = \
|
||||||
|
@ -551,32 +551,13 @@ class MyClasspath : public Classpath {
|
|||||||
expect(t, loadLibrary(t, libraryPath, "java", true, true));
|
expect(t, loadLibrary(t, libraryPath, "java", true, true));
|
||||||
#endif // not AVIAN_OPENJDK_SRC
|
#endif // not AVIAN_OPENJDK_SRC
|
||||||
|
|
||||||
object constructor = resolveMethod
|
object assertionLock = resolveField
|
||||||
(t, type(t, Machine::ClassLoaderType), "<init>",
|
(t, type(t, Machine::ClassLoaderType), "assertionLock",
|
||||||
"(Ljava/lang/ClassLoader;)V");
|
"Ljava/lang/Object;");
|
||||||
|
|
||||||
PROTECT(t, constructor);
|
set(t, root(t, Machine::BootLoader), fieldOffset(t, assertionLock),
|
||||||
|
|
||||||
t->m->processor->invoke(t, constructor, root(t, Machine::BootLoader), 0);
|
|
||||||
|
|
||||||
t->m->processor->invoke
|
|
||||||
(t, constructor, root(t, Machine::AppLoader),
|
|
||||||
root(t, Machine::BootLoader));
|
root(t, Machine::BootLoader));
|
||||||
|
|
||||||
object scl = resolveField
|
|
||||||
(t, type(t, Machine::ClassLoaderType), "scl", "Ljava/lang/ClassLoader;");
|
|
||||||
|
|
||||||
PROTECT(t, scl);
|
|
||||||
|
|
||||||
object sclSet = resolveField
|
|
||||||
(t, type(t, Machine::ClassLoaderType), "sclSet", "Z");
|
|
||||||
|
|
||||||
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;
|
|
||||||
|
|
||||||
t->m->processor->invoke
|
t->m->processor->invoke
|
||||||
(t, root(t, Machine::BootLoader), "java/lang/System",
|
(t, root(t, Machine::BootLoader), "java/lang/System",
|
||||||
"initializeSystemClass", "()V", 0);
|
"initializeSystemClass", "()V", 0);
|
||||||
@ -1318,15 +1299,17 @@ getZipFileEntry(Thread* t, object method, uintptr_t* arguments)
|
|||||||
|
|
||||||
ZipFile* file = reinterpret_cast<ZipFile*>(peer);
|
ZipFile* file = reinterpret_cast<ZipFile*>(peer);
|
||||||
if (file->region) {
|
if (file->region) {
|
||||||
THREAD_RUNTIME_ARRAY(t, char, p, stringLength(t, path) + 2);
|
THREAD_RUNTIME_ARRAY(t, char, p, byteArrayLength(t, path) + 2);
|
||||||
stringChars(t, path, RUNTIME_ARRAY_BODY(p));
|
memcpy(RUNTIME_ARRAY_BODY(p), &byteArrayBody(t, path, 0),
|
||||||
|
byteArrayLength(t, path));
|
||||||
|
RUNTIME_ARRAY_BODY(p)[byteArrayLength(t, path)] = 0;
|
||||||
replace('\\', '/', RUNTIME_ARRAY_BODY(p));
|
replace('\\', '/', RUNTIME_ARRAY_BODY(p));
|
||||||
if (addSlash) {
|
if (addSlash) {
|
||||||
RUNTIME_ARRAY_BODY(p)[stringLength(t, path)] = '/';
|
RUNTIME_ARRAY_BODY(p)[byteArrayLength(t, path)] = '/';
|
||||||
RUNTIME_ARRAY_BODY(p)[stringLength(t, path) + 1] = 0;
|
RUNTIME_ARRAY_BODY(p)[byteArrayLength(t, path) + 1] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return reinterpret_cast<int64_t>(find(file, p, stringLength(t, path)));
|
return reinterpret_cast<int64_t>(find(file, p, byteArrayLength(t, path)));
|
||||||
} else {
|
} else {
|
||||||
int64_t entry = longValue
|
int64_t entry = longValue
|
||||||
(t, t->m->processor->invoke
|
(t, t->m->processor->invoke
|
||||||
@ -1340,6 +1323,43 @@ getZipFileEntry(Thread* t, object method, uintptr_t* arguments)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int64_t JNICALL
|
||||||
|
getZipFileEntryBytes(Thread* t, object method, uintptr_t* arguments)
|
||||||
|
{
|
||||||
|
int64_t peer; memcpy(&peer, arguments, 8);
|
||||||
|
int type = arguments[2];
|
||||||
|
|
||||||
|
ZipFile::Entry* entry = reinterpret_cast<ZipFile::Entry*>(peer);
|
||||||
|
if (entry->start) {
|
||||||
|
switch (type) {
|
||||||
|
case 0: { // name
|
||||||
|
unsigned nameLength = fileNameLength(entry->start);
|
||||||
|
object array = makeByteArray(t, nameLength + 1);
|
||||||
|
memcpy(&byteArrayBody(t, array, 0), fileName(entry->start), nameLength);
|
||||||
|
byteArrayBody(t, array, nameLength) = 0;
|
||||||
|
return reinterpret_cast<int64_t>(array);
|
||||||
|
} break;
|
||||||
|
|
||||||
|
case 1: { // extra
|
||||||
|
return 0;
|
||||||
|
} break;
|
||||||
|
|
||||||
|
case 2: { // comment
|
||||||
|
return 0;
|
||||||
|
} break;
|
||||||
|
|
||||||
|
default: abort(t);
|
||||||
|
}
|
||||||
|
return compressedSize(entry->start);
|
||||||
|
} else {
|
||||||
|
return reinterpret_cast<int64_t>
|
||||||
|
(t->m->processor->invoke
|
||||||
|
(t, nativeInterceptOriginal
|
||||||
|
(t, methodRuntimeDataNative(t, getMethodRuntimeData(t, method))),
|
||||||
|
0, entry->entry, type));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int64_t JNICALL
|
int64_t JNICALL
|
||||||
getNextZipFileEntry(Thread* t, object method, uintptr_t* arguments)
|
getNextZipFileEntry(Thread* t, object method, uintptr_t* arguments)
|
||||||
{
|
{
|
||||||
@ -1703,6 +1723,11 @@ intercept(Thread* t, object c, const char* name, const char* spec,
|
|||||||
object runtimeData = getMethodRuntimeData(t, m);
|
object runtimeData = getMethodRuntimeData(t, m);
|
||||||
|
|
||||||
set(t, runtimeData, MethodRuntimeDataNative, native);
|
set(t, runtimeData, MethodRuntimeDataNative, native);
|
||||||
|
} else {
|
||||||
|
fprintf(stderr, "unable to find %s%s in %s\n",
|
||||||
|
name, spec, &byteArrayBody(t, className(t, c), 0));
|
||||||
|
|
||||||
|
abort(t);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1770,60 +1795,6 @@ interceptFileOperations(Thread* t)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
{ object zipEntryClass = resolveClass
|
|
||||||
(t, root(t, Machine::BootLoader), "java/util/zip/ZipEntry", false);
|
|
||||||
|
|
||||||
if (zipEntryClass) {
|
|
||||||
PROTECT(t, zipEntryClass);
|
|
||||||
|
|
||||||
object zipEntryNameField = findFieldInClass2
|
|
||||||
(t, zipEntryClass, "name", "Ljava/lang/String;");
|
|
||||||
|
|
||||||
if (zipEntryNameField) {
|
|
||||||
cp->zipEntryNameField = fieldOffset(t, zipEntryNameField);
|
|
||||||
|
|
||||||
object zipEntryTimeField = findFieldInClass2
|
|
||||||
(t, zipEntryClass, "time", "J");
|
|
||||||
|
|
||||||
if (zipEntryTimeField) {
|
|
||||||
cp->zipEntryTimeField = fieldOffset(t, zipEntryTimeField);
|
|
||||||
|
|
||||||
object zipEntryCrcField = findFieldInClass2
|
|
||||||
(t, zipEntryClass, "crc", "J");
|
|
||||||
|
|
||||||
if (zipEntryCrcField) {
|
|
||||||
cp->zipEntryCrcField = fieldOffset(t, zipEntryCrcField);
|
|
||||||
|
|
||||||
object zipEntrySizeField = findFieldInClass2
|
|
||||||
(t, zipEntryClass, "size", "J");
|
|
||||||
|
|
||||||
if (zipEntrySizeField) {
|
|
||||||
cp->zipEntrySizeField = fieldOffset(t, zipEntrySizeField);
|
|
||||||
|
|
||||||
object zipEntryCsizeField = findFieldInClass2
|
|
||||||
(t, zipEntryClass, "csize", "J");
|
|
||||||
|
|
||||||
if (zipEntryCsizeField) {
|
|
||||||
cp->zipEntryCsizeField = fieldOffset(t, zipEntryCsizeField);
|
|
||||||
|
|
||||||
object zipEntryMethodField = findFieldInClass2
|
|
||||||
(t, zipEntryClass, "method", "I");
|
|
||||||
|
|
||||||
if (zipEntryMethodField) {
|
|
||||||
cp->zipEntryMethodField = fieldOffset
|
|
||||||
(t, zipEntryMethodField);
|
|
||||||
|
|
||||||
intercept(t, zipEntryClass, "initFields", "(J)V",
|
|
||||||
voidPointer(initializeZipEntryFields));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
{ object zipFileClass = resolveClass
|
{ object zipFileClass = resolveClass
|
||||||
(t, root(t, Machine::BootLoader), "java/util/zip/ZipFile", false);
|
(t, root(t, Machine::BootLoader), "java/util/zip/ZipFile", false);
|
||||||
|
|
||||||
@ -1836,19 +1807,22 @@ interceptFileOperations(Thread* t)
|
|||||||
if (zipFileJzfileField) {
|
if (zipFileJzfileField) {
|
||||||
cp->zipFileJzfileField = fieldOffset(t, zipFileJzfileField);
|
cp->zipFileJzfileField = fieldOffset(t, zipFileJzfileField);
|
||||||
|
|
||||||
intercept(t, zipFileClass, "open", "(Ljava/lang/String;IJ)J",
|
intercept(t, zipFileClass, "open", "(Ljava/lang/String;IJZ)J",
|
||||||
voidPointer(openZipFile));
|
voidPointer(openZipFile));
|
||||||
|
|
||||||
intercept(t, zipFileClass, "getTotal", "(J)I",
|
intercept(t, zipFileClass, "getTotal", "(J)I",
|
||||||
voidPointer(getZipFileEntryCount));
|
voidPointer(getZipFileEntryCount));
|
||||||
|
|
||||||
intercept(t, zipFileClass, "getEntry", "(JLjava/lang/String;Z)J",
|
intercept(t, zipFileClass, "getEntry", "(J[BZ)J",
|
||||||
voidPointer(getZipFileEntry));
|
voidPointer(getZipFileEntry));
|
||||||
|
|
||||||
|
intercept(t, zipFileClass, "getEntryBytes", "(JI)[B",
|
||||||
|
voidPointer(getZipFileEntryBytes));
|
||||||
|
|
||||||
intercept(t, zipFileClass, "getNextEntry", "(JI)J",
|
intercept(t, zipFileClass, "getNextEntry", "(JI)J",
|
||||||
voidPointer(getNextZipFileEntry));
|
voidPointer(getNextZipFileEntry));
|
||||||
|
|
||||||
intercept(t, zipFileClass, "getMethod", "(J)I",
|
intercept(t, zipFileClass, "getEntryMethod", "(J)I",
|
||||||
voidPointer(getZipFileEntryMethod));
|
voidPointer(getZipFileEntryMethod));
|
||||||
|
|
||||||
intercept(t, zipFileClass, "freeEntry", "(JJ)V",
|
intercept(t, zipFileClass, "freeEntry", "(JJ)V",
|
||||||
@ -1857,10 +1831,10 @@ interceptFileOperations(Thread* t)
|
|||||||
intercept(t, zipFileClass, "read", "(JJJ[BII)I",
|
intercept(t, zipFileClass, "read", "(JJJ[BII)I",
|
||||||
voidPointer(readZipFileEntry));
|
voidPointer(readZipFileEntry));
|
||||||
|
|
||||||
intercept(t, zipFileClass, "getCSize", "(J)J",
|
intercept(t, zipFileClass, "getEntryCSize", "(J)J",
|
||||||
voidPointer(getZipFileEntryCompressedSize));
|
voidPointer(getZipFileEntryCompressedSize));
|
||||||
|
|
||||||
intercept(t, zipFileClass, "getSize", "(J)J",
|
intercept(t, zipFileClass, "getEntrySize", "(J)J",
|
||||||
voidPointer(getZipFileEntryUncompressedSize));
|
voidPointer(getZipFileEntryUncompressedSize));
|
||||||
|
|
||||||
intercept(t, zipFileClass, "getZipMessage", "(J)Ljava/lang/String;",
|
intercept(t, zipFileClass, "getZipMessage", "(J)Ljava/lang/String;",
|
||||||
@ -2560,6 +2534,13 @@ Avian_sun_misc_Unsafe_putObjectVolatile
|
|||||||
storeLoadMemoryBarrier();
|
storeLoadMemoryBarrier();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern "C" JNIEXPORT void JNICALL
|
||||||
|
Avian_sun_misc_Unsafe_putOrderedObject
|
||||||
|
(Thread* t, object method, uintptr_t* arguments)
|
||||||
|
{
|
||||||
|
Avian_sun_misc_Unsafe_putObjectVolatile(t, method, arguments);
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT int64_t JNICALL
|
extern "C" JNIEXPORT int64_t JNICALL
|
||||||
Avian_sun_misc_Unsafe_compareAndSwapInt
|
Avian_sun_misc_Unsafe_compareAndSwapInt
|
||||||
(Thread*, object, uintptr_t* arguments)
|
(Thread*, object, uintptr_t* arguments)
|
||||||
@ -2782,6 +2763,32 @@ Avian_sun_misc_Unsafe_park
|
|||||||
monitorRelease(t, local::interruptLock(t, t->javaThread));
|
monitorRelease(t, local::interruptLock(t, t->javaThread));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern "C" JNIEXPORT void JNICALL
|
||||||
|
Avian_sun_misc_Unsafe_copyMemory
|
||||||
|
(Thread* t, object, uintptr_t* arguments)
|
||||||
|
{
|
||||||
|
object srcBase = reinterpret_cast<object>(arguments[1]);
|
||||||
|
int64_t srcOffset; memcpy(&srcOffset, arguments + 2, 8);
|
||||||
|
object dstBase = reinterpret_cast<object>(arguments[4]);
|
||||||
|
int64_t dstOffset; memcpy(&dstOffset, arguments + 5, 8);
|
||||||
|
int64_t count; memcpy(&count, arguments + 7, 8);
|
||||||
|
|
||||||
|
PROTECT(t, srcBase);
|
||||||
|
PROTECT(t, dstBase);
|
||||||
|
|
||||||
|
ACQUIRE(t, t->m->referenceLock);
|
||||||
|
|
||||||
|
void* src = srcBase
|
||||||
|
? &cast<uint8_t>(srcBase, srcOffset)
|
||||||
|
: reinterpret_cast<uint8_t*>(srcOffset);
|
||||||
|
|
||||||
|
void* dst = dstBase
|
||||||
|
? &cast<uint8_t>(dstBase, dstOffset)
|
||||||
|
: reinterpret_cast<uint8_t*>(dstOffset);
|
||||||
|
|
||||||
|
memcpy(dst, src, count);
|
||||||
|
}
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
namespace local {
|
namespace local {
|
||||||
@ -3153,7 +3160,7 @@ jvmFillInStackTrace(Thread* t, uintptr_t* arguments)
|
|||||||
{
|
{
|
||||||
jobject throwable = reinterpret_cast<jobject>(arguments[0]);
|
jobject throwable = reinterpret_cast<jobject>(arguments[0]);
|
||||||
|
|
||||||
object trace = getTrace(t, 1);
|
object trace = getTrace(t, 2);
|
||||||
set(t, *throwable, ThrowableTrace, trace);
|
set(t, *throwable, ThrowableTrace, trace);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
@ -3834,10 +3841,9 @@ EXPORT(JVM_FindClassFromClassLoader)(Thread* t, const char* name,
|
|||||||
}
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jclass JNICALL
|
extern "C" JNIEXPORT jclass JNICALL
|
||||||
EXPORT(JVM_FindClassFromBootLoader)(Thread* t, const char* name,
|
EXPORT(JVM_FindClassFromBootLoader)(Thread* t, const char* name)
|
||||||
jboolean throwError)
|
|
||||||
{
|
{
|
||||||
return EXPORT(JVM_FindClassFromClassLoader)(t, name, false, 0, throwError);
|
return EXPORT(JVM_FindClassFromClassLoader)(t, name, false, 0, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jclass JNICALL
|
extern "C" JNIEXPORT jclass JNICALL
|
||||||
@ -4265,9 +4271,9 @@ jvmGetClassDeclaredMethods(Thread* t, uintptr_t* arguments)
|
|||||||
}
|
}
|
||||||
|
|
||||||
object method = makeJmethod
|
object method = makeJmethod
|
||||||
(t, true, *c, i, name, returnType, parameterTypes, exceptionTypes,
|
(t, true, 0, *c, i, name, returnType, parameterTypes, exceptionTypes,
|
||||||
methodFlags(t, vmMethod), signature, 0, annotationTable, 0,
|
methodFlags(t, vmMethod), signature, 0, annotationTable, 0,
|
||||||
annotationDefault, 0, 0, 0, 0, 0);
|
annotationDefault, 0, 0, 0);
|
||||||
|
|
||||||
assert(t, ai < objectArrayLength(t, array));
|
assert(t, ai < objectArrayLength(t, array));
|
||||||
|
|
||||||
@ -4354,8 +4360,8 @@ jvmGetClassDeclaredFields(Thread* t, uintptr_t* arguments)
|
|||||||
}
|
}
|
||||||
|
|
||||||
object field = makeJfield
|
object field = makeJfield
|
||||||
(t, true, *c, i, name, type, fieldFlags
|
(t, true, 0, *c, i, name, type, fieldFlags
|
||||||
(t, vmField), signature, 0, annotationTable, 0, 0, 0, 0, 0, 0);
|
(t, vmField), signature, 0, annotationTable, 0, 0, 0, 0);
|
||||||
|
|
||||||
assert(t, ai < objectArrayLength(t, array));
|
assert(t, ai < objectArrayLength(t, array));
|
||||||
|
|
||||||
@ -4445,8 +4451,8 @@ jvmGetClassDeclaredConstructors(Thread* t, uintptr_t* arguments)
|
|||||||
}
|
}
|
||||||
|
|
||||||
object method = makeJconstructor
|
object method = makeJconstructor
|
||||||
(t, true, *c, i, parameterTypes, exceptionTypes, methodFlags
|
(t, true, 0, *c, i, parameterTypes, exceptionTypes, methodFlags
|
||||||
(t, vmMethod), signature, 0, annotationTable, 0, 0, 0, 0, 0);
|
(t, vmMethod), signature, 0, annotationTable, 0, 0, 0, 0);
|
||||||
|
|
||||||
assert(t, ai < objectArrayLength(t, array));
|
assert(t, ai < objectArrayLength(t, array));
|
||||||
|
|
||||||
@ -5298,8 +5304,11 @@ extern "C" JNIEXPORT jobjectArray JNICALL
|
|||||||
EXPORT(JVM_GetThreadStateNames)(JNIEnv*, jint, jintArray) { abort(); }
|
EXPORT(JVM_GetThreadStateNames)(JNIEnv*, jint, jintArray) { abort(); }
|
||||||
|
|
||||||
extern "C" JNIEXPORT void JNICALL
|
extern "C" JNIEXPORT void JNICALL
|
||||||
EXPORT(JVM_GetVersionInfo)(JNIEnv*, local::jvm_version_info*, size_t)
|
EXPORT(JVM_GetVersionInfo)(JNIEnv*, local::jvm_version_info* info, size_t size)
|
||||||
{ abort(); }
|
{
|
||||||
|
memset(info, 0, size);
|
||||||
|
info->jvm_version = 0x01070000;
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jboolean JNICALL
|
extern "C" JNIEXPORT jboolean JNICALL
|
||||||
EXPORT(JVM_CX8Field)(JNIEnv*, jobject*, jfieldID*, jlong, jlong)
|
EXPORT(JVM_CX8Field)(JNIEnv*, jobject*, jfieldID*, jlong, jlong)
|
||||||
|
@ -219,6 +219,8 @@
|
|||||||
|
|
||||||
(type negativeArraySizeException java/lang/NegativeArraySizeException)
|
(type negativeArraySizeException java/lang/NegativeArraySizeException)
|
||||||
|
|
||||||
|
(type reflectiveOperationException java/lang/ReflectiveOperationException)
|
||||||
|
|
||||||
(type classCastException java/lang/ClassCastException)
|
(type classCastException java/lang/ClassCastException)
|
||||||
|
|
||||||
(type classNotFoundException java/lang/ClassNotFoundException)
|
(type classNotFoundException java/lang/ClassNotFoundException)
|
||||||
|
Loading…
Reference in New Issue
Block a user