mirror of
https://github.com/corda/corda.git
synced 2025-01-22 12:28:11 +00:00
Merge remote-tracking branch 'dicej/android-upgrade'
This commit is contained in:
commit
fbcdfd6dec
18
README.md
18
README.md
@ -370,7 +370,7 @@ the following, starting from the Avian directory:
|
||||
git clone https://android.googlesource.com/platform/system/core \
|
||||
system/core
|
||||
(cd system/core && \
|
||||
git checkout fafcabd0dd4432de3c7f5956edec23f6ed241b56)
|
||||
git checkout 373c77583f9d8eab88e4321d1a2e2af8f5ae8ea7)
|
||||
|
||||
git clone https://android.googlesource.com/platform/external/fdlibm \
|
||||
external/fdlibm
|
||||
@ -380,11 +380,11 @@ the following, starting from the Avian directory:
|
||||
git clone https://android.googlesource.com/platform/external/icu4c \
|
||||
external/icu4c
|
||||
(cd external/icu4c && \
|
||||
git checkout 8fd45e08f1054d80a356ef8aa05659a2ba84707c)
|
||||
git checkout e5311394ca22b280da41cd17059288dab3fb1ea6)
|
||||
|
||||
git clone https://android.googlesource.com/platform/libnativehelper
|
||||
(cd libnativehelper && \
|
||||
git checkout cf5ac0ec696fce7fac6b324ec7d4d6da217e501c)
|
||||
git checkout b14825c7c75420049e03849994265be651cc4a4e)
|
||||
|
||||
git clone https://android.googlesource.com/platform/external/openssl \
|
||||
external/openssl
|
||||
@ -396,10 +396,16 @@ the following, starting from the Avian directory:
|
||||
(cd external/zlib && \
|
||||
git checkout 15b6223aa57a347ce113729253802cb2fdeb4ad0)
|
||||
|
||||
git clone https://github.com/dicej/android-conscrypt external/conscrypt
|
||||
(cd external/conscrypt && \
|
||||
git checkout a96719f834232634e9160873bd4c44834b84eb15)
|
||||
|
||||
git clone git://git.openssl.org/openssl.git openssl-upstream
|
||||
(cd openssl-upstream && git checkout OpenSSL_1_0_1h)
|
||||
|
||||
git clone https://github.com/dicej/android-libcore64 libcore
|
||||
(cd libcore && \
|
||||
git checkout 69a1fd8623b85f978ead36dcf1c6c78c5ff79932)
|
||||
|
||||
curl -Of http://oss.readytalk.com/avian-web/expat-2.1.0.tar.gz
|
||||
(cd external && tar xzf ../expat-2.1.0.tar.gz && mv expat-2.1.0 expat)
|
||||
@ -427,7 +433,11 @@ for x86_64 OS X instead of 'CC="gcc -fPIC" ./config':
|
||||
Note that we use https://github.com/dicej/android-libcore64 above
|
||||
instead of the upstream
|
||||
https://android.googlesource.com/platform/libcore repository, since
|
||||
the former has patches to provide better support for non-Linux platforms.
|
||||
the former has patches to provide better support for non-Linux
|
||||
platforms. We have also forked
|
||||
https://android.googlesource.com/platform/external/conscrypt as
|
||||
https://github.com/dicej/android-conscrypt to patch that project as
|
||||
well.
|
||||
|
||||
Also note that we use the upstream OpenSSL repository and apply the
|
||||
Android patches to it. This is because it is not clear how to build
|
||||
|
@ -576,4 +576,6 @@ public class Classes {
|
||||
private static native void acquireClassLock();
|
||||
|
||||
private static native void releaseClassLock();
|
||||
|
||||
public static native String makeString(byte[] array, int offset, int length);
|
||||
}
|
||||
|
5
classpath/dalvik/system/BaseDexClassLoader.java
Normal file
5
classpath/dalvik/system/BaseDexClassLoader.java
Normal file
@ -0,0 +1,5 @@
|
||||
package dalvik.system;
|
||||
|
||||
public class BaseDexClassLoader extends ClassLoader {
|
||||
public native String getLdLibraryPath();
|
||||
}
|
@ -18,10 +18,12 @@ import avian.Classes;
|
||||
import avian.InnerClassReference;
|
||||
|
||||
import java.lang.reflect.Constructor;
|
||||
import java.lang.reflect.GenericDeclaration;
|
||||
import java.lang.reflect.Method;
|
||||
import java.lang.reflect.Field;
|
||||
import java.lang.reflect.Modifier;
|
||||
import java.lang.reflect.Type;
|
||||
import java.lang.reflect.TypeVariable;
|
||||
import java.lang.reflect.Proxy;
|
||||
import java.lang.reflect.InvocationHandler;
|
||||
import java.lang.reflect.InvocationTargetException;
|
||||
@ -38,7 +40,9 @@ import java.security.ProtectionDomain;
|
||||
import java.security.Permissions;
|
||||
import java.security.AllPermission;
|
||||
|
||||
public final class Class <T> implements Type, AnnotatedElement {
|
||||
public final class Class <T>
|
||||
implements Type, AnnotatedElement, GenericDeclaration
|
||||
{
|
||||
private static final int PrimitiveFlag = 1 << 5;
|
||||
private static final int EnumFlag = 1 << 14;
|
||||
|
||||
@ -96,9 +100,8 @@ public final class Class <T> implements Type, AnnotatedElement {
|
||||
}
|
||||
}
|
||||
|
||||
return new String
|
||||
(replace('/', '.', c.name, 0, c.name.length - 1), 0, c.name.length - 1,
|
||||
false);
|
||||
return Classes.makeString
|
||||
(replace('/', '.', c.name, 0, c.name.length - 1), 0, c.name.length - 1);
|
||||
}
|
||||
|
||||
public String getCanonicalName() {
|
||||
@ -495,6 +498,10 @@ public final class Class <T> implements Type, AnnotatedElement {
|
||||
return (vmClass.flags & Modifier.INTERFACE) != 0;
|
||||
}
|
||||
|
||||
public boolean isAnnotation() {
|
||||
return (vmClass.flags & 0x2000) != 0;
|
||||
}
|
||||
|
||||
public Class getSuperclass() {
|
||||
return (vmClass.super_ == null ? null : SystemClassLoader.getClass(vmClass.super_));
|
||||
}
|
||||
@ -521,9 +528,11 @@ public final class Class <T> implements Type, AnnotatedElement {
|
||||
}
|
||||
|
||||
public URL getResource(String path) {
|
||||
if (! path.startsWith("/")) {
|
||||
String name = new String
|
||||
(vmClass.name, 0, vmClass.name.length - 1, false);
|
||||
if (path.startsWith("/")) {
|
||||
path = path.substring(1);
|
||||
} else {
|
||||
String name = Classes.makeString
|
||||
(vmClass.name, 0, vmClass.name.length - 1);
|
||||
int index = name.lastIndexOf('/');
|
||||
if (index >= 0) {
|
||||
path = name.substring(0, index) + "/" + path;
|
||||
@ -646,4 +655,12 @@ public final class Class <T> implements Type, AnnotatedElement {
|
||||
public ProtectionDomain getProtectionDomain() {
|
||||
return Classes.getProtectionDomain(vmClass);
|
||||
}
|
||||
|
||||
public TypeVariable<?>[] getTypeParameters() {
|
||||
throw new UnsupportedOperationException("not yet implemented");
|
||||
}
|
||||
|
||||
public Type[] getGenericInterfaces() {
|
||||
throw new UnsupportedOperationException("not yet implemented");
|
||||
}
|
||||
}
|
||||
|
@ -19,6 +19,7 @@ import java.util.Collections;
|
||||
import java.util.Enumeration;
|
||||
import java.util.Map;
|
||||
import java.util.HashMap;
|
||||
import java.security.ProtectionDomain;
|
||||
|
||||
public abstract class ClassLoader {
|
||||
private final ClassLoader parent;
|
||||
@ -92,6 +93,12 @@ public abstract class ClassLoader {
|
||||
(avian.Classes.defineVMClass(this, b, offset, length));
|
||||
}
|
||||
|
||||
protected Class defineClass(String name, byte[] b, int offset, int length,
|
||||
ProtectionDomain domain)
|
||||
{
|
||||
return defineClass(name, b, offset, length);
|
||||
}
|
||||
|
||||
protected Class findClass(String name) throws ClassNotFoundException {
|
||||
throw new ClassNotFoundException();
|
||||
}
|
||||
@ -196,6 +203,10 @@ public abstract class ClassLoader {
|
||||
return urls;
|
||||
}
|
||||
|
||||
protected String findLibrary(String name) {
|
||||
return null;
|
||||
}
|
||||
|
||||
static native Class getCaller();
|
||||
|
||||
static native void load(String name, Class caller, boolean mapName);
|
||||
|
@ -44,6 +44,10 @@ public class Constructor<T> extends AccessibleObject implements Member {
|
||||
return method.getModifiers();
|
||||
}
|
||||
|
||||
public boolean isSynthetic() {
|
||||
return method.isSynthetic();
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return method.getName();
|
||||
}
|
||||
@ -70,4 +74,8 @@ public class Constructor<T> extends AccessibleObject implements Member {
|
||||
method.invoke(v, arguments);
|
||||
return v;
|
||||
}
|
||||
|
||||
public Class<?>[] getExceptionTypes() {
|
||||
throw new UnsupportedOperationException("not yet implemented");
|
||||
}
|
||||
}
|
||||
|
@ -57,13 +57,13 @@ public class Field<T> extends AccessibleObject {
|
||||
}
|
||||
|
||||
public static String getName(VMField vmField) {
|
||||
return new String(vmField.name, 0, vmField.name.length - 1, false);
|
||||
return Classes.makeString(vmField.name, 0, vmField.name.length - 1);
|
||||
}
|
||||
|
||||
public Class getType() {
|
||||
return Classes.forCanonicalName
|
||||
(vmField.class_.loader,
|
||||
new String(vmField.spec, 0, vmField.spec.length - 1, false));
|
||||
Classes.makeString(vmField.spec, 0, vmField.spec.length - 1));
|
||||
}
|
||||
|
||||
public Type getGenericType() {
|
||||
|
5
classpath/java/lang/reflect/GenericDeclaration.java
Normal file
5
classpath/java/lang/reflect/GenericDeclaration.java
Normal file
@ -0,0 +1,5 @@
|
||||
package java.lang.reflect;
|
||||
|
||||
public interface GenericDeclaration {
|
||||
TypeVariable<?>[] getTypeParameters();
|
||||
}
|
@ -19,4 +19,6 @@ public interface Member {
|
||||
public int getModifiers();
|
||||
|
||||
public String getName();
|
||||
|
||||
public boolean isSynthetic();
|
||||
}
|
||||
|
@ -52,7 +52,7 @@ public class Method<T> extends AccessibleObject implements Member {
|
||||
}
|
||||
|
||||
public static String getName(VMMethod vmMethod) {
|
||||
return new String(vmMethod.name, 0, vmMethod.name.length - 1, false);
|
||||
return Classes.makeString(vmMethod.name, 0, vmMethod.name.length - 1);
|
||||
}
|
||||
|
||||
private String getSpec() {
|
||||
@ -60,7 +60,7 @@ public class Method<T> extends AccessibleObject implements Member {
|
||||
}
|
||||
|
||||
public static String getSpec(VMMethod vmMethod) {
|
||||
return new String(vmMethod.spec, 0, vmMethod.spec.length - 1, false);
|
||||
return Classes.makeString(vmMethod.spec, 0, vmMethod.spec.length - 1);
|
||||
}
|
||||
|
||||
public Class[] getParameterTypes() {
|
||||
@ -107,8 +107,8 @@ public class Method<T> extends AccessibleObject implements Member {
|
||||
if (vmMethod.spec[i] == ')') {
|
||||
return Classes.forCanonicalName
|
||||
(vmMethod.class_.loader,
|
||||
new String
|
||||
(vmMethod.spec, i + 1, vmMethod.spec.length - i - 2, false));
|
||||
Classes.makeString
|
||||
(vmMethod.spec, i + 1, vmMethod.spec.length - i - 2));
|
||||
}
|
||||
}
|
||||
throw new RuntimeException();
|
||||
@ -149,8 +149,16 @@ public class Method<T> extends AccessibleObject implements Member {
|
||||
return (getModifiers() & 0x80) != 0;
|
||||
}
|
||||
|
||||
public boolean isSynthetic() {
|
||||
return (getModifiers() & 0x1000) != 0;
|
||||
}
|
||||
|
||||
public Object getDefaultValue() {
|
||||
ClassLoader loader = getDeclaringClass().getClassLoader();
|
||||
return Classes.getAnnotationDefaultValue(loader, vmMethod.addendum);
|
||||
}
|
||||
|
||||
public Class<?>[] getExceptionTypes() {
|
||||
throw new UnsupportedOperationException("not yet implemented");
|
||||
}
|
||||
}
|
||||
|
5
classpath/java/lang/reflect/TypeVariable.java
Normal file
5
classpath/java/lang/reflect/TypeVariable.java
Normal file
@ -0,0 +1,5 @@
|
||||
package java.lang.reflect;
|
||||
|
||||
public interface TypeVariable<T extends GenericDeclaration> extends Type {
|
||||
|
||||
}
|
8
classpath/libcore/reflect/AnnotationAccess.java
Normal file
8
classpath/libcore/reflect/AnnotationAccess.java
Normal file
@ -0,0 +1,8 @@
|
||||
package libcore.reflect;
|
||||
|
||||
import java.lang.reflect.AccessibleObject;
|
||||
|
||||
public class AnnotationAccess {
|
||||
public static native AccessibleObject getEnclosingMethodOrConstructor
|
||||
(Class<?> c);
|
||||
}
|
@ -88,6 +88,14 @@ public final class Unsafe {
|
||||
|
||||
public native void putLongVolatile(Object o, long offset, long x);
|
||||
|
||||
public long getLong(Object o, long offset) {
|
||||
return getLongVolatile(o, offset);
|
||||
}
|
||||
|
||||
public void putLong(Object o, long offset, long x) {
|
||||
putLongVolatile(o, offset, x);
|
||||
}
|
||||
|
||||
public native void putOrderedLong(Object o, long offset, long x);
|
||||
|
||||
public native void putOrderedInt(Object o, long offset, int x);
|
||||
|
118
makefile
118
makefile
@ -219,12 +219,14 @@ ifneq ($(android),)
|
||||
classpath-cflags = -DBOOT_JAVAHOME
|
||||
android-cflags = -I$(luni-native) \
|
||||
-I$(android)/libnativehelper/include/nativehelper \
|
||||
-I$(android)/libnativehelper \
|
||||
-I$(android)/system/core/include \
|
||||
-I$(android)/external/zlib \
|
||||
-I$(android)/external/icu4c/i18n \
|
||||
-I$(android)/external/icu4c/common \
|
||||
-I$(android)/external/expat \
|
||||
-I$(android)/external/openssl/include \
|
||||
-I$(android)/external/openssl \
|
||||
-I$(android)/libcore/include \
|
||||
-I$(build)/android-src/external/fdlibm \
|
||||
-I$(build)/android-src \
|
||||
@ -234,33 +236,38 @@ ifneq ($(android),)
|
||||
-DJNI_JARJAR_PREFIX= \
|
||||
-D__DARWIN_UNIX03=1 \
|
||||
-D__PROVIDE_FIXMES \
|
||||
-DSTATIC_LIB \
|
||||
-g3 \
|
||||
-Werror
|
||||
-Werror \
|
||||
-Wno-shift-count-overflow
|
||||
|
||||
luni-cpps := $(shell find $(luni-native) -name '*.cpp')
|
||||
|
||||
libziparchive-native := $(android)/system/core/libziparchive
|
||||
libziparchive-ccs := $(libziparchive-native)/zip_archive.cc
|
||||
|
||||
libutils-native := $(android)/system/core/libutils
|
||||
libutils-cpps := $(libutils-native)/FileMap.cpp
|
||||
|
||||
libnativehelper-native := $(android)/libnativehelper
|
||||
libnativehelper-cpps := $(libnativehelper-native)/JniConstants.cpp \
|
||||
$(libnativehelper-native)/toStringArray.cpp
|
||||
|
||||
crypto-native := $(android)/libcore/crypto/src/main/native
|
||||
|
||||
crypto-native := $(android)/external/conscrypt/src/main/native
|
||||
crypto-cpps := $(crypto-native)/org_conscrypt_NativeCrypto.cpp
|
||||
|
||||
ifeq ($(platform),windows)
|
||||
android-cflags += -D__STDC_CONSTANT_MACROS
|
||||
android-cflags += -D__STDC_CONSTANT_MACROS -DHAVE_WIN32_FILEMAP
|
||||
blacklist = $(luni-native)/java_io_Console.cpp \
|
||||
$(luni-native)/java_lang_ProcessManager.cpp \
|
||||
$(luni-native)/java_math_NativeBN.cpp \
|
||||
$(luni-native)/libcore_net_RawSocket.cpp
|
||||
$(luni-native)/java_lang_ProcessManager.cpp
|
||||
|
||||
icu-libs := $(android)/external/icu4c/lib/sicuin.a \
|
||||
$(android)/external/icu4c/lib/sicuuc.a \
|
||||
$(android)/external/icu4c/lib/sicudt.a
|
||||
platform-lflags := -lgdi32 -lshlwapi -lwsock32
|
||||
else
|
||||
android-cflags += -fPIC -DHAVE_SYS_UIO_H
|
||||
blacklist = $(luni-native)/java_math_NativeBN.cpp
|
||||
android-cflags += -fPIC -DHAVE_SYS_UIO_H -DHAVE_POSIX_FILEMAP
|
||||
blacklist =
|
||||
|
||||
icu-libs := $(android)/external/icu4c/lib/libicui18n.a \
|
||||
$(android)/external/icu4c/lib/libicuuc.a \
|
||||
@ -278,30 +285,61 @@ ifneq ($(android),)
|
||||
-lstdc++
|
||||
|
||||
ifeq ($(platform),linux)
|
||||
android-cflags += -DHAVE_OFF64_T
|
||||
classpath-lflags += -lrt
|
||||
endif
|
||||
|
||||
classpath-objects = \
|
||||
$(call cpp-objects,$(luni-cpps),$(luni-native),$(build)) \
|
||||
$(call cpp-objects,$(crypto-cpps),$(crypto-native),$(build)) \
|
||||
$(call cpp-objects,$(libnativehelper-cpps),$(libnativehelper-native),$(build))
|
||||
$(call cpp-objects,$(libnativehelper-cpps),$(libnativehelper-native),$(build)) \
|
||||
$(call cc-objects,$(libziparchive-ccs),$(libziparchive-native),$(build)) \
|
||||
$(call cpp-objects,$(libutils-cpps),$(libutils-native),$(build))
|
||||
luni-java = $(android)/libcore/luni/src/main/java
|
||||
luni-javas := $(shell find $(luni-java) -name '*.java')
|
||||
|
||||
luni-blacklist = \
|
||||
$(luni-java)/libcore/reflect/AnnotationAccess.java
|
||||
|
||||
luni-javas := \
|
||||
$(filter-out $(luni-blacklist),$(shell find $(luni-java) -name '*.java'))
|
||||
|
||||
luni-nonjavas := $(shell find $(luni-java) -not -type d -not -name '*.java')
|
||||
luni-copied-nonjavas = $(call noop-files,$(luni-nonjavas),$(luni-java),)
|
||||
libdvm-java = $(android)/libcore/libdvm/src/main/java
|
||||
libdvm-javas := $(shell find $(libdvm-java) -name '*.java')
|
||||
crypto-java = $(android)/libcore/crypto/src/main/java
|
||||
|
||||
crypto-java = $(android)/external/conscrypt/src/main/java
|
||||
crypto-javas := $(shell find $(crypto-java) -name '*.java')
|
||||
|
||||
crypto-platform-java = $(android)/external/conscrypt/src/platform/java
|
||||
crypto-platform-javas := $(shell find $(crypto-platform-java) -name '*.java')
|
||||
|
||||
dalvik-java = $(android)/libcore/dalvik/src/main/java
|
||||
dalvik-javas := $(shell find $(dalvik-java) -name '*.java')
|
||||
dalvik-javas := \
|
||||
$(dalvik-java)/dalvik/system/DalvikLogHandler.java \
|
||||
$(dalvik-java)/dalvik/system/CloseGuard.java \
|
||||
$(dalvik-java)/dalvik/system/VMDebug.java \
|
||||
$(dalvik-java)/dalvik/system/BlockGuard.java \
|
||||
$(dalvik-java)/dalvik/system/SocketTagger.java \
|
||||
$(dalvik-java)/dalvik/system/DalvikLogging.java \
|
||||
|
||||
libart-java = $(android)/libcore/libart/src/main/java
|
||||
libart-javas := \
|
||||
$(libart-java)/dalvik/system/VMRuntime.java \
|
||||
$(libart-java)/dalvik/system/VMStack.java \
|
||||
$(libart-java)/java/lang/Thread.java \
|
||||
$(libart-java)/java/lang/ThreadGroup.java \
|
||||
$(libart-java)/java/lang/Enum.java \
|
||||
$(libart-java)/java/lang/String.java \
|
||||
$(libart-java)/java/lang/ref/Reference.java \
|
||||
$(libart-java)/java/lang/reflect/AccessibleObject.java \
|
||||
|
||||
xml-java = $(android)/libcore/xml/src/main/java
|
||||
xml-javas := $(shell find $(xml-java) -name '*.java')
|
||||
android-classes = \
|
||||
$(call java-classes,$(luni-javas),$(luni-java),$(build)/android) \
|
||||
$(call java-classes,$(libdvm-javas),$(libdvm-java),$(build)/android) \
|
||||
$(call java-classes,$(crypto-javas),$(crypto-java),$(build)/android) \
|
||||
$(call java-classes,$(crypto-platform-javas),$(crypto-platform-java),$(build)/android) \
|
||||
$(call java-classes,$(dalvik-javas),$(dalvik-java),$(build)/android) \
|
||||
$(call java-classes,$(libart-javas),$(libart-java),$(build)/android) \
|
||||
$(call java-classes,$(xml-javas),$(xml-java),$(build)/android)
|
||||
classpath = android
|
||||
|
||||
@ -1114,6 +1152,7 @@ endif
|
||||
|
||||
c-objects = $(foreach x,$(1),$(patsubst $(2)/%.c,$(3)/%.o,$(x)))
|
||||
cpp-objects = $(foreach x,$(1),$(patsubst $(2)/%.cpp,$(3)/%.o,$(x)))
|
||||
cc-objects = $(foreach x,$(1),$(patsubst $(2)/%.cc,$(3)/%.o,$(x)))
|
||||
asm-objects = $(foreach x,$(1),$(patsubst $(2)/%.$(asm-format),$(3)/%-asm.o,$(x)))
|
||||
java-classes = $(foreach x,$(1),$(patsubst $(2)/%.java,$(3)/%.class,$(x)))
|
||||
noop-files = $(foreach x,$(1),$(patsubst $(2)/%,$(3)/%,$(x)))
|
||||
@ -1384,13 +1423,23 @@ ifneq ($(classpath),avian)
|
||||
|
||||
ifeq ($(openjdk),)
|
||||
classpath-sources := $(classpath-sources) \
|
||||
$(classpath-src)/dalvik/system/BaseDexClassLoader.java \
|
||||
$(classpath-src)/libcore/reflect/AnnotationAccess.java \
|
||||
$(classpath-src)/sun/reflect/ConstantPool.java \
|
||||
$(classpath-src)/java/lang/ReflectiveOperationException.java \
|
||||
$(classpath-src)/java/net/ProtocolFamily.java \
|
||||
$(classpath-src)/java/net/StandardProtocolFamily.java \
|
||||
$(classpath-src)/sun/misc/Cleaner.java \
|
||||
$(classpath-src)/sun/misc/Unsafe.java \
|
||||
$(classpath-src)/java/lang/reflect/Proxy.java
|
||||
$(classpath-src)/java/lang/Object.java \
|
||||
$(classpath-src)/java/lang/Class.java \
|
||||
$(classpath-src)/java/lang/ClassLoader.java \
|
||||
$(classpath-src)/java/lang/Package.java \
|
||||
$(classpath-src)/java/lang/reflect/Proxy.java \
|
||||
$(classpath-src)/java/lang/reflect/Field.java \
|
||||
$(classpath-src)/java/lang/reflect/SignatureParser.java \
|
||||
$(classpath-src)/java/lang/reflect/Constructor.java \
|
||||
$(classpath-src)/java/lang/reflect/AccessibleObject.java \
|
||||
$(classpath-src)/java/lang/reflect/Method.java
|
||||
endif
|
||||
else
|
||||
classpath-sources := $(shell find $(classpath-src) -name '*.java')
|
||||
@ -1594,14 +1643,20 @@ $(build)/android-src/%.cpp: $(libnativehelper-native)/%.cpp
|
||||
$(build)/android-src/%.cpp: $(crypto-native)/%.cpp
|
||||
cp $(<) $(@)
|
||||
|
||||
$(build)/android-src/%.cpp: $(libziparchive-native)/%.cc
|
||||
cp $(<) $(@)
|
||||
|
||||
$(build)/android-src/%.cpp: $(libutils-native)/%.cpp
|
||||
cp $(<) $(@)
|
||||
|
||||
$(build)/%.o: $(build)/android-src/%.cpp $(build)/android.dep
|
||||
@echo "compiling $(@)"
|
||||
@mkdir -p $(dir $(@))
|
||||
$(cxx) $(android-cflags) $(classpath-extra-cflags) -c \
|
||||
$$($(windows-path) $(<)) $(call output,$(@))
|
||||
|
||||
$(build)/android.dep: $(luni-javas) $(libdvm-javas) $(crypto-javas) \
|
||||
$(dalvik-javas) $(xml-javas) $(luni-nonjavas)
|
||||
$(build)/android.dep: $(luni-javas) $(dalvik-javas) $(libart-javas) \
|
||||
$(xml-javas) $(luni-nonjavas) $(crypto-javas) $(crypto-platform-javas)
|
||||
@echo "compiling luni classes"
|
||||
@mkdir -p $(classpath-build)
|
||||
@mkdir -p $(build)/android
|
||||
@ -1609,11 +1664,26 @@ $(build)/android.dep: $(luni-javas) $(libdvm-javas) $(crypto-javas) \
|
||||
@mkdir -p $(build)/android-src/libexpat
|
||||
cp $(android)/external/fdlibm/fdlibm.h $(build)/android-src/external/fdlibm/
|
||||
cp $(android)/external/expat/lib/expat*.h $(build)/android-src/libexpat/
|
||||
cp -a $(luni-java)/* $(libdvm-java)/* $(crypto-java)/* $(dalvik-java)/* \
|
||||
$(xml-java)/* $(build)/android-src/
|
||||
cp -a $(luni-java)/* $(xml-java)/* $(build)/android-src/
|
||||
rm $(call noop-files,$(luni-blacklist),$(luni-java),$(build)/android-src)
|
||||
(cd $(dalvik-java) && \
|
||||
jar c $(call noop-files,$(dalvik-javas),$(dalvik-java),.)) \
|
||||
| (cd $(build)/android-src && jar x)
|
||||
(cd $(libart-java) && \
|
||||
jar c $(call noop-files,$(libart-javas),$(libart-java),.)) \
|
||||
| (cd $(build)/android-src && jar x)
|
||||
(cd $(crypto-java) && \
|
||||
jar c $(call noop-files,$(crypto-javas),$(crypto-java),.)) \
|
||||
| (cd $(build)/android-src && jar x)
|
||||
(cd $(crypto-platform-java) && \
|
||||
jar c $(call noop-files,$(crypto-platform-javas),$(crypto-platform-java),.)) \
|
||||
| (cd $(build)/android-src && jar x)
|
||||
(cd $(classpath-src) && \
|
||||
jar c $(call noop-files,$(classpath-sources),$(classpath-src),.)) \
|
||||
| (cd $(build)/android-src && jar x)
|
||||
# (cd android && jar c *) | (cd $(build)/android-src && jar x)
|
||||
find $(build)/android-src -name '*.java' > $(build)/android.txt
|
||||
$(javac) -Xmaxerrs 1000 -d $(build)/android -sourcepath $(luni-java) \
|
||||
@$(build)/android.txt
|
||||
$(javac) -Xmaxerrs 1000 -d $(build)/android @$(build)/android.txt
|
||||
rm $(build)/android/sun/misc/Unsafe* \
|
||||
$(build)/android/java/lang/reflect/Proxy*
|
||||
for x in $(luni-copied-nonjavas); \
|
||||
|
@ -15,3 +15,10 @@ void JniConstants::init(_JNIEnv*)
|
||||
{
|
||||
// ignore
|
||||
}
|
||||
|
||||
struct _JavaVM;
|
||||
|
||||
int libconscrypt_JNI_OnLoad(_JavaVM*, void*)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
@ -781,6 +781,116 @@ unsigned classModifiers(Thread* t, GcClass* c)
|
||||
return c->flags();
|
||||
}
|
||||
|
||||
object makeMethod(Thread* t, GcJclass* class_, int index)
|
||||
{
|
||||
GcMethod* method = cast<GcMethod>(
|
||||
t, cast<GcArray>(t, class_->vmClass()->methodTable())->body()[index]);
|
||||
PROTECT(t, method);
|
||||
|
||||
GcClass* c
|
||||
= resolveClass(t, roots(t)->bootLoader(), "java/lang/reflect/Method");
|
||||
PROTECT(t, c);
|
||||
|
||||
object instance = makeNew(t, c);
|
||||
PROTECT(t, instance);
|
||||
|
||||
GcMethod* constructor = resolveMethod(t, c, "<init>", "(Lavian/VMMethod;)V");
|
||||
|
||||
t->m->processor->invoke(t, constructor, instance, method);
|
||||
|
||||
if (method->name()->body()[0] == '<') {
|
||||
object oldInstance = instance;
|
||||
|
||||
c = resolveClass(
|
||||
t, roots(t)->bootLoader(), "java/lang/reflect/Constructor");
|
||||
|
||||
object instance = makeNew(t, c);
|
||||
|
||||
GcMethod* constructor
|
||||
= resolveMethod(t, c, "<init>", "(Ljava/lang/Method;)V");
|
||||
|
||||
t->m->processor->invoke(t, constructor, instance, oldInstance);
|
||||
}
|
||||
|
||||
return instance;
|
||||
}
|
||||
|
||||
int64_t getPrimitive(Thread* t, object instance, int code, int offset)
|
||||
{
|
||||
switch (code) {
|
||||
case ByteField:
|
||||
return fieldAtOffset<int8_t>(instance, offset);
|
||||
case BooleanField:
|
||||
return fieldAtOffset<uint8_t>(instance, offset);
|
||||
case CharField:
|
||||
return fieldAtOffset<uint16_t>(instance, offset);
|
||||
case ShortField:
|
||||
return fieldAtOffset<int16_t>(instance, offset);
|
||||
case IntField:
|
||||
return fieldAtOffset<int32_t>(instance, offset);
|
||||
case LongField:
|
||||
return fieldAtOffset<int64_t>(instance, offset);
|
||||
case FloatField:
|
||||
return fieldAtOffset<uint32_t>(instance, offset);
|
||||
case DoubleField:
|
||||
return fieldAtOffset<uint64_t>(instance, offset);
|
||||
default:
|
||||
abort(t);
|
||||
}
|
||||
}
|
||||
|
||||
void setPrimitive(Thread* t,
|
||||
object instance,
|
||||
int code,
|
||||
int offset,
|
||||
int64_t value)
|
||||
{
|
||||
switch (code) {
|
||||
case ByteField:
|
||||
fieldAtOffset<int8_t>(instance, offset) = static_cast<int8_t>(value);
|
||||
break;
|
||||
case BooleanField:
|
||||
fieldAtOffset<uint8_t>(instance, offset) = static_cast<uint8_t>(value);
|
||||
break;
|
||||
case CharField:
|
||||
fieldAtOffset<uint16_t>(instance, offset) = static_cast<uint16_t>(value);
|
||||
break;
|
||||
case ShortField:
|
||||
fieldAtOffset<int16_t>(instance, offset) = static_cast<int16_t>(value);
|
||||
break;
|
||||
case IntField:
|
||||
fieldAtOffset<int32_t>(instance, offset) = static_cast<int32_t>(value);
|
||||
break;
|
||||
case LongField:
|
||||
fieldAtOffset<int64_t>(instance, offset) = static_cast<int64_t>(value);
|
||||
break;
|
||||
case FloatField:
|
||||
fieldAtOffset<uint32_t>(instance, offset) = static_cast<uint32_t>(value);
|
||||
break;
|
||||
case DoubleField:
|
||||
fieldAtOffset<uint64_t>(instance, offset) = static_cast<uint64_t>(value);
|
||||
break;
|
||||
default:
|
||||
abort(t);
|
||||
}
|
||||
}
|
||||
|
||||
int64_t invokeMethod(Thread* t, GcMethod* method, object instance, object args)
|
||||
{
|
||||
THREAD_RESOURCE0(t, {
|
||||
if (t->exception) {
|
||||
GcThrowable* exception = t->exception;
|
||||
t->exception = makeThrowable(
|
||||
t, GcInvocationTargetException::Type, 0, 0, exception);
|
||||
}
|
||||
});
|
||||
|
||||
unsigned returnCode = method->returnCode();
|
||||
|
||||
return reinterpret_cast<int64_t>(translateInvokeResult(
|
||||
t, returnCode, t->m->processor->invokeArray(t, method, instance, args)));
|
||||
}
|
||||
|
||||
} // namespace vm
|
||||
|
||||
#endif // CLASSPATH_COMMON_H
|
||||
|
@ -164,6 +164,18 @@ extern "C" AVIAN_EXPORT int64_t JNICALL
|
||||
return reinterpret_cast<int64_t>(defineClass(t, loader, buffer, length));
|
||||
}
|
||||
|
||||
extern "C" AVIAN_EXPORT int64_t JNICALL
|
||||
Avian_avian_Classes_makeString(Thread* t, object, uintptr_t* arguments)
|
||||
{
|
||||
GcByteArray* array
|
||||
= cast<GcByteArray>(t, reinterpret_cast<object>(arguments[0]));
|
||||
int offset = arguments[1];
|
||||
int length = arguments[2];
|
||||
|
||||
return reinterpret_cast<int64_t>(
|
||||
t->m->classpath->makeString(t, array, offset, length));
|
||||
}
|
||||
|
||||
extern "C" AVIAN_EXPORT int64_t JNICALL
|
||||
Avian_avian_SystemClassLoader_findLoadedVMClass(Thread* t,
|
||||
object,
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -343,30 +343,8 @@ extern "C" AVIAN_EXPORT int64_t JNICALL
|
||||
object,
|
||||
uintptr_t* arguments)
|
||||
{
|
||||
object instance = reinterpret_cast<object>(arguments[0]);
|
||||
int code = arguments[1];
|
||||
int offset = arguments[2];
|
||||
|
||||
switch (code) {
|
||||
case ByteField:
|
||||
return fieldAtOffset<int8_t>(instance, offset);
|
||||
case BooleanField:
|
||||
return fieldAtOffset<uint8_t>(instance, offset);
|
||||
case CharField:
|
||||
return fieldAtOffset<uint16_t>(instance, offset);
|
||||
case ShortField:
|
||||
return fieldAtOffset<int16_t>(instance, offset);
|
||||
case IntField:
|
||||
return fieldAtOffset<int32_t>(instance, offset);
|
||||
case LongField:
|
||||
return fieldAtOffset<int64_t>(instance, offset);
|
||||
case FloatField:
|
||||
return fieldAtOffset<uint32_t>(instance, offset);
|
||||
case DoubleField:
|
||||
return fieldAtOffset<uint64_t>(instance, offset);
|
||||
default:
|
||||
abort(t);
|
||||
}
|
||||
return getPrimitive(
|
||||
t, reinterpret_cast<object>(arguments[0]), arguments[1], arguments[2]);
|
||||
}
|
||||
|
||||
extern "C" AVIAN_EXPORT int64_t JNICALL
|
||||
@ -374,10 +352,8 @@ extern "C" AVIAN_EXPORT int64_t JNICALL
|
||||
object,
|
||||
uintptr_t* arguments)
|
||||
{
|
||||
object instance = reinterpret_cast<object>(arguments[0]);
|
||||
int offset = arguments[1];
|
||||
|
||||
return reinterpret_cast<int64_t>(fieldAtOffset<object>(instance, offset));
|
||||
return reinterpret_cast<int64_t>(fieldAtOffset<object>(
|
||||
reinterpret_cast<object>(arguments[0]), arguments[1]));
|
||||
}
|
||||
|
||||
extern "C" AVIAN_EXPORT void JNICALL
|
||||
@ -385,40 +361,14 @@ extern "C" AVIAN_EXPORT void JNICALL
|
||||
object,
|
||||
uintptr_t* arguments)
|
||||
{
|
||||
object instance = reinterpret_cast<object>(arguments[0]);
|
||||
int code = arguments[1];
|
||||
int offset = arguments[2];
|
||||
int64_t value;
|
||||
memcpy(&value, arguments + 3, 8);
|
||||
|
||||
switch (code) {
|
||||
case ByteField:
|
||||
fieldAtOffset<int8_t>(instance, offset) = static_cast<int8_t>(value);
|
||||
break;
|
||||
case BooleanField:
|
||||
fieldAtOffset<uint8_t>(instance, offset) = static_cast<uint8_t>(value);
|
||||
break;
|
||||
case CharField:
|
||||
fieldAtOffset<uint16_t>(instance, offset) = static_cast<uint16_t>(value);
|
||||
break;
|
||||
case ShortField:
|
||||
fieldAtOffset<int16_t>(instance, offset) = static_cast<int16_t>(value);
|
||||
break;
|
||||
case IntField:
|
||||
fieldAtOffset<int32_t>(instance, offset) = static_cast<int32_t>(value);
|
||||
break;
|
||||
case LongField:
|
||||
fieldAtOffset<int64_t>(instance, offset) = static_cast<int64_t>(value);
|
||||
break;
|
||||
case FloatField:
|
||||
fieldAtOffset<uint32_t>(instance, offset) = static_cast<uint32_t>(value);
|
||||
break;
|
||||
case DoubleField:
|
||||
fieldAtOffset<uint64_t>(instance, offset) = static_cast<uint64_t>(value);
|
||||
break;
|
||||
default:
|
||||
abort(t);
|
||||
}
|
||||
setPrimitive(t,
|
||||
reinterpret_cast<object>(arguments[0]),
|
||||
arguments[1],
|
||||
arguments[2],
|
||||
value);
|
||||
}
|
||||
|
||||
extern "C" AVIAN_EXPORT void JNICALL
|
||||
@ -426,11 +376,10 @@ extern "C" AVIAN_EXPORT void JNICALL
|
||||
object,
|
||||
uintptr_t* arguments)
|
||||
{
|
||||
object instance = reinterpret_cast<object>(arguments[0]);
|
||||
int offset = arguments[1];
|
||||
object value = reinterpret_cast<object>(arguments[2]);
|
||||
|
||||
setField(t, instance, offset, value);
|
||||
setField(t,
|
||||
reinterpret_cast<object>(arguments[0]),
|
||||
arguments[1],
|
||||
reinterpret_cast<object>(arguments[2]));
|
||||
}
|
||||
|
||||
extern "C" AVIAN_EXPORT int64_t JNICALL
|
||||
@ -438,9 +387,8 @@ extern "C" AVIAN_EXPORT int64_t JNICALL
|
||||
object,
|
||||
uintptr_t* arguments)
|
||||
{
|
||||
GcClass* c = cast<GcClass>(t, reinterpret_cast<object>(arguments[0]));
|
||||
|
||||
return reinterpret_cast<int64_t>(make(t, c));
|
||||
return reinterpret_cast<int64_t>(
|
||||
make(t, cast<GcClass>(t, reinterpret_cast<object>(arguments[0]))));
|
||||
}
|
||||
|
||||
extern "C" AVIAN_EXPORT int64_t JNICALL
|
||||
@ -454,22 +402,10 @@ extern "C" AVIAN_EXPORT int64_t JNICALL
|
||||
object,
|
||||
uintptr_t* arguments)
|
||||
{
|
||||
GcMethod* method = cast<GcMethod>(t, reinterpret_cast<object>(arguments[0]));
|
||||
object instance = reinterpret_cast<object>(arguments[1]);
|
||||
object args = reinterpret_cast<object>(arguments[2]);
|
||||
|
||||
THREAD_RESOURCE0(t, {
|
||||
if (t->exception) {
|
||||
GcThrowable* exception = t->exception;
|
||||
t->exception = makeThrowable(
|
||||
t, GcInvocationTargetException::Type, 0, 0, exception);
|
||||
}
|
||||
});
|
||||
|
||||
unsigned returnCode = method->returnCode();
|
||||
|
||||
return reinterpret_cast<int64_t>(translateInvokeResult(
|
||||
t, returnCode, t->m->processor->invokeArray(t, method, instance, args)));
|
||||
return invokeMethod(t,
|
||||
cast<GcMethod>(t, reinterpret_cast<object>(arguments[0])),
|
||||
reinterpret_cast<object>(arguments[1]),
|
||||
reinterpret_cast<object>(arguments[2]));
|
||||
}
|
||||
|
||||
extern "C" AVIAN_EXPORT int64_t JNICALL
|
||||
@ -809,38 +745,8 @@ extern "C" AVIAN_EXPORT int64_t JNICALL
|
||||
extern "C" AVIAN_EXPORT int64_t JNICALL
|
||||
Avian_avian_Classes_makeMethod(Thread* t, object, uintptr_t* arguments)
|
||||
{
|
||||
GcMethod* method = cast<GcMethod>(
|
||||
t,
|
||||
cast<GcArray>(t,
|
||||
cast<GcJclass>(t, reinterpret_cast<object>(arguments[0]))
|
||||
->vmClass()
|
||||
->methodTable())->body()[arguments[1]]);
|
||||
PROTECT(t, method);
|
||||
|
||||
GcClass* c
|
||||
= resolveClass(t, roots(t)->bootLoader(), "java/lang/reflect/Method");
|
||||
PROTECT(t, c);
|
||||
|
||||
object instance = makeNew(t, c);
|
||||
PROTECT(t, instance);
|
||||
|
||||
GcMethod* constructor = resolveMethod(t, c, "<init>", "(Lavian/VMMethod;)V");
|
||||
|
||||
t->m->processor->invoke(t, constructor, instance, method);
|
||||
|
||||
if (method->name()->body()[0] == '<') {
|
||||
object oldInstance = instance;
|
||||
|
||||
c = resolveClass(
|
||||
t, roots(t)->bootLoader(), "java/lang/reflect/Constructor");
|
||||
|
||||
object instance = makeNew(t, c);
|
||||
|
||||
GcMethod* constructor
|
||||
= resolveMethod(t, c, "<init>", "(Ljava/lang/Method;)V");
|
||||
|
||||
t->m->processor->invoke(t, constructor, instance, oldInstance);
|
||||
}
|
||||
|
||||
return reinterpret_cast<uintptr_t>(instance);
|
||||
return reinterpret_cast<uintptr_t>(
|
||||
makeMethod(t,
|
||||
cast<GcJclass>(t, reinterpret_cast<object>(arguments[0])),
|
||||
arguments[1]));
|
||||
}
|
||||
|
@ -179,6 +179,7 @@
|
||||
(require uint8_t interrupted)
|
||||
(require uint8_t unparked)
|
||||
(alias peer uint64_t eetop)
|
||||
(alias peer uint64_t nativePeer)
|
||||
(require uint64_t peer))
|
||||
|
||||
(type threadGroup java/lang/ThreadGroup)
|
||||
|
@ -316,21 +316,21 @@ public class Misc {
|
||||
expect(staticRan);
|
||||
|
||||
expect(System.getProperty("java.class.path").equals
|
||||
(System.getProperties().get("java.class.path")));
|
||||
(System.getProperties().getProperty("java.class.path")));
|
||||
|
||||
expect(System.getProperty("path.separator").equals
|
||||
(System.getProperties().get("path.separator")));
|
||||
(System.getProperties().getProperty("path.separator")));
|
||||
|
||||
expect(System.getProperty("user.dir").equals
|
||||
(System.getProperties().get("user.dir")));
|
||||
(System.getProperties().getProperty("user.dir")));
|
||||
|
||||
expect(System.getProperty("java.io.tmpdir").equals
|
||||
(System.getProperties().get("java.io.tmpdir")));
|
||||
(System.getProperties().getProperty("java.io.tmpdir")));
|
||||
|
||||
System.setProperty("buzzy.buzzy.bim.bam", "dippy dopey flim flam");
|
||||
|
||||
expect(System.getProperty("buzzy.buzzy.bim.bam").equals
|
||||
(System.getProperties().get("buzzy.buzzy.bim.bam")));
|
||||
(System.getProperties().getProperty("buzzy.buzzy.bim.bam")));
|
||||
|
||||
expect(System.getProperty("buzzy.buzzy.bim.bam").equals
|
||||
("dippy dopey flim flam"));
|
||||
@ -338,7 +338,7 @@ public class Misc {
|
||||
System.getProperties().put("buzzy.buzzy.bim.bam", "yippy yappy yin yang");
|
||||
|
||||
expect(System.getProperty("buzzy.buzzy.bim.bam").equals
|
||||
(System.getProperties().get("buzzy.buzzy.bim.bam")));
|
||||
(System.getProperties().getProperty("buzzy.buzzy.bim.bam")));
|
||||
|
||||
expect(System.getProperty("buzzy.buzzy.bim.bam").equals
|
||||
("yippy yappy yin yang"));
|
||||
|
@ -49,7 +49,7 @@ run make ${flags} process=interpret ${make_target}
|
||||
run make ${flags} mode=debug bootimage=true ${make_target} && \
|
||||
run make ${flags} bootimage=true ${make_target}
|
||||
|
||||
! has_flag openjdk && \
|
||||
(! has_flag openjdk && ! has_flag android) && \
|
||||
run make ${flags} openjdk=$JAVA_HOME ${make_target}
|
||||
|
||||
run make ${flags} tails=true continuations=true heapdump=true ${make_target}
|
||||
|
Loading…
Reference in New Issue
Block a user