From 0bb0b1ec0e07c0c032085754b7e2f86073abf262 Mon Sep 17 00:00:00 2001 From: Joel Dice Date: Mon, 25 Feb 2013 16:41:46 -0700 Subject: [PATCH] enable use of Android class library on 64-bit systems This involved patching libcore.git to make it 64-bit safe. --- makefile | 4 ++- src/classpath-android.cpp | 57 ++++++++++++++++++++++++++------------- 2 files changed, 41 insertions(+), 20 deletions(-) diff --git a/makefile b/makefile index cbe41b04f6..7bd1e40fe4 100755 --- a/makefile +++ b/makefile @@ -167,7 +167,9 @@ ifneq ($(android),) -fno-exceptions \ -DHAVE_SYS_UIO_H \ -D_FILE_OFFSET_BITS=64 \ - -g3 + -g3 \ + -Werror \ + -fPIC classpath-lflags := $(android)/icu4c/lib/libicuuc.a \ $(android)/icu4c/lib/libicui18n.a \ $(android)/icu4c/lib/libicudata.a \ diff --git a/src/classpath-android.cpp b/src/classpath-android.cpp index bf753540b0..369dc3b5c3 100644 --- a/src/classpath-android.cpp +++ b/src/classpath-android.cpp @@ -401,10 +401,10 @@ class MyClasspath : public Classpath { object instance = makeNew(t, c); PROTECT(t, instance); - object constructor = resolveMethod(t, c, "", "(II)V"); + object constructor = resolveMethod(t, c, "", "(JI)V"); t->m->processor->invoke - (t, constructor, instance, reinterpret_cast(p), + (t, constructor, instance, reinterpret_cast(p), static_cast(capacity)); return instance; @@ -416,10 +416,10 @@ class MyClasspath : public Classpath { PROTECT(t, b); object field = resolveField - (t, objectClass(t, b), "effectiveDirectAddress", "I"); + (t, objectClass(t, b), "effectiveDirectAddress", "J"); return reinterpret_cast - (fieldAtOffset(b, fieldOffset(t, field))); + (fieldAtOffset(b, fieldOffset(t, field))); } virtual int64_t @@ -1536,65 +1536,84 @@ extern "C" JNIEXPORT void JNICALL Avian_libcore_io_Memory_pokeLong (Thread*, object, uintptr_t* arguments) { - int64_t v; memcpy(&v, arguments + 1, 8); - if (arguments[3]) { + int64_t address; memcpy(&address, arguments, 8); + int64_t v; memcpy(&v, arguments + 2, 8); + if (arguments[4]) { v = swapV8(v); } - memcpy(reinterpret_cast(arguments[0]), &v, 8); + memcpy(reinterpret_cast(address), &v, 8); } extern "C" JNIEXPORT int64_t JNICALL Avian_libcore_io_Memory_peekLong (Thread*, object, uintptr_t* arguments) { - int64_t v; memcpy(&v, reinterpret_cast(arguments[0]), 8); - return arguments[1] ? swapV8(v) : v; + int64_t address; memcpy(&address, arguments, 8); + int64_t v; memcpy(&v, reinterpret_cast(address), 8); + return arguments[2] ? swapV8(v) : v; } extern "C" JNIEXPORT void JNICALL Avian_libcore_io_Memory_pokeInt (Thread*, object, uintptr_t* arguments) { - int32_t v = arguments[2] ? swapV4(arguments[1]) : arguments[1]; - memcpy(reinterpret_cast(arguments[0]), &v, 4); + int64_t address; memcpy(&address, arguments, 8); + int32_t v = arguments[3] ? swapV4(arguments[2]) : arguments[2]; + memcpy(reinterpret_cast(address), &v, 4); } extern "C" JNIEXPORT int64_t JNICALL Avian_libcore_io_Memory_peekInt (Thread*, object, uintptr_t* arguments) { - int32_t v; memcpy(&v, reinterpret_cast(arguments[0]), 4); - return arguments[1] ? swapV4(v) : v; + int64_t address; memcpy(&address, arguments, 8); + int32_t v; memcpy(&v, reinterpret_cast(address), 4); + return arguments[2] ? swapV4(v) : v; } extern "C" JNIEXPORT void JNICALL Avian_libcore_io_Memory_pokeShort (Thread*, object, uintptr_t* arguments) { - int16_t v = arguments[2] ? swapV2(arguments[1]) : arguments[1]; - memcpy(reinterpret_cast(arguments[0]), &v, 2); + int64_t address; memcpy(&address, arguments, 8); + int16_t v = arguments[3] ? swapV2(arguments[2]) : arguments[2]; + memcpy(reinterpret_cast(address), &v, 2); } extern "C" JNIEXPORT int64_t JNICALL Avian_libcore_io_Memory_peekShort (Thread*, object, uintptr_t* arguments) { - int16_t v; memcpy(&v, reinterpret_cast(arguments[0]), 2); - return arguments[1] ? swapV2(v) : v; + int64_t address; memcpy(&address, arguments, 8); + int16_t v; memcpy(&v, reinterpret_cast(address), 2); + return arguments[2] ? swapV2(v) : v; } extern "C" JNIEXPORT void JNICALL Avian_libcore_io_Memory_pokeByte (Thread*, object, uintptr_t* arguments) { - *reinterpret_cast(arguments[0]) = arguments[1]; + int64_t address; memcpy(&address, arguments, 8); + *reinterpret_cast(address) = arguments[2]; } extern "C" JNIEXPORT int64_t JNICALL Avian_libcore_io_Memory_peekByte (Thread*, object, uintptr_t* arguments) { - return *reinterpret_cast(arguments[0]); + int64_t address; memcpy(&address, arguments, 8); + return *reinterpret_cast(address); +} + +extern "C" JNIEXPORT void JNICALL +Avian_libcore_io_Memory_peekByteArray +(Thread* t, object, uintptr_t* arguments) +{ + int64_t address; memcpy(&address, arguments, 8); + object array = reinterpret_cast(arguments[2]); + memcpy(&byteArrayBody(t, array, arguments[3]), + reinterpret_cast(address), + arguments[4]); } extern "C" JNIEXPORT int64_t JNICALL