From 4db79b9be62606c8ea6c717a9415e2439928c22f Mon Sep 17 00:00:00 2001 From: Joel Dice Date: Wed, 2 Mar 2011 08:35:45 -0700 Subject: [PATCH] implement various sun.misc.Unsafe and JVM_* methods --- src/classpath-openjdk.cpp | 67 +++++++++++++++++++++++++++++++++++++-- 1 file changed, 65 insertions(+), 2 deletions(-) diff --git a/src/classpath-openjdk.cpp b/src/classpath-openjdk.cpp index 61bbc06dbf..64e50d4599 100644 --- a/src/classpath-openjdk.cpp +++ b/src/classpath-openjdk.cpp @@ -1585,6 +1585,16 @@ Avian_sun_misc_Unsafe_getIntVolatile return result; } +extern "C" JNIEXPORT int64_t JNICALL +Avian_sun_misc_Unsafe_getLong__Ljava_lang_Object_2J +(Thread*, object, uintptr_t* arguments) +{ + object o = reinterpret_cast(arguments[1]); + int64_t offset; memcpy(&offset, arguments + 2, 8); + + return cast(o, offset); +} + extern "C" JNIEXPORT int64_t JNICALL Avian_sun_misc_Unsafe_getLongVolatile (Thread* t, object, uintptr_t* arguments) @@ -1666,6 +1676,19 @@ Avian_sun_misc_Unsafe_getObjectVolatile return value; } +extern "C" JNIEXPORT void JNICALL +Avian_sun_misc_Unsafe_putObjectVolatile +(Thread* t, object, uintptr_t* arguments) +{ + object o = reinterpret_cast(arguments[1]); + int64_t offset; memcpy(&offset, arguments + 2, 8); + object value = reinterpret_cast(arguments[4]); + + storeStoreMemoryBarrier(); + set(t, o, offset, reinterpret_cast(value)); + storeLoadMemoryBarrier(); +} + extern "C" JNIEXPORT int64_t JNICALL Avian_sun_misc_Unsafe_compareAndSwapInt (Thread*, object, uintptr_t* arguments) @@ -1744,6 +1767,16 @@ Avian_sun_misc_Unsafe_setMemory memset(reinterpret_cast(p), v, count); } +extern "C" JNIEXPORT void JNICALL +Avian_sun_misc_Unsafe_putByte__JB +(Thread*, object, uintptr_t* arguments) +{ + int64_t p; memcpy(&p, arguments + 1, 8); + int8_t v = arguments[3]; + + *reinterpret_cast(p) = v; +} + extern "C" JNIEXPORT void JNICALL Avian_sun_misc_Unsafe_putLong__JJ (Thread*, object, uintptr_t* arguments) @@ -2489,7 +2522,34 @@ EXPORT(JVM_AllocateNewArray)(Thread*, jobject, jclass, jint) { abort(); } extern "C" JNIEXPORT jobject JNICALL -EXPORT(JVM_LatestUserDefinedLoader)(Thread*) { abort(); } +EXPORT(JVM_LatestUserDefinedLoader)(Thread* t) +{ + ENTER(t, Thread::ActiveState); + + class Visitor: public Processor::StackVisitor { + public: + Visitor(Thread* t): + t(t), loader(0) + { } + + virtual bool visit(Processor::StackWalker* walker) { + object loader = classLoader(t, methodClass(t, walker->method())); + if (loader and loader != root(t, Machine::BootLoader)) { + this->loader = loader; + return false; + } else { + return true; + } + } + + Thread* t; + object loader; + } v(t); + + t->m->processor->walkStack(t, &v); + + return makeLocalReference(t, v.loader); +} extern "C" JNIEXPORT jclass JNICALL EXPORT(JVM_LoadClass0)(Thread*, jobject, jclass, @@ -3764,7 +3824,10 @@ EXPORT(JVM_SendTo)(jint, char*, int, int, struct sockaddr*, int) { abort(); } extern "C" JNIEXPORT jint JNICALL -EXPORT(JVM_SocketAvailable)(jint, jint*) { abort(); } +EXPORT(JVM_SocketAvailable)(jint socket, jint* count) +{ + return ioctl(socket, FIONREAD, count) < 0 ? 0 : 1; +} extern "C" JNIEXPORT jint JNICALL EXPORT(JVM_GetSockName)(jint socket, struct sockaddr* address,