diff options
| author | 2015-04-04 05:02:27 +0000 | |
|---|---|---|
| committer | 2015-04-04 05:02:27 +0000 | |
| commit | 305b44b9488c4ad44d2a1b0749c8bd49835eb216 (patch) | |
| tree | 5add4b36a7e4777119e6b51eff7f83b4d008d568 | |
| parent | 5551eee918af77a8d4980a9993f4c49c05bcf88c (diff) | |
| parent | f29be77f07084e88ae7104a375a1a54fd91de0dd (diff) | |
am f29be77f: am a4f39ed9: am f8cb672f: Merge "Frameworks/base: Pass variant and feature-set to runtime"
* commit 'f29be77f07084e88ae7104a375a1a54fd91de0dd':
Frameworks/base: Pass variant and feature-set to runtime
| -rw-r--r-- | core/jni/AndroidRuntime.cpp | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/core/jni/AndroidRuntime.cpp b/core/jni/AndroidRuntime.cpp index f1b04a5acf5d..88f06970d8b7 100644 --- a/core/jni/AndroidRuntime.cpp +++ b/core/jni/AndroidRuntime.cpp @@ -561,6 +561,10 @@ int AndroidRuntime::startVm(JavaVM** pJavaVM, JNIEnv** pEnv) char dex2oatImageCompilerFilterBuf[sizeof("--compiler-filter=")-1 + PROPERTY_VALUE_MAX]; char dex2oatThreadsBuf[sizeof("-j")-1 + PROPERTY_VALUE_MAX]; char dex2oatThreadsImageBuf[sizeof("-j")-1 + PROPERTY_VALUE_MAX]; + char dex2oat_isa_variant_key[PROPERTY_KEY_MAX]; + char dex2oat_isa_variant[sizeof("--instruction-set-variant=") -1 + PROPERTY_VALUE_MAX]; + char dex2oat_isa_features_key[PROPERTY_KEY_MAX]; + char dex2oat_isa_features[sizeof("--instruction-set-features=") -1 + PROPERTY_VALUE_MAX]; char dex2oatFlagsBuf[PROPERTY_VALUE_MAX]; char dex2oatImageFlagsBuf[PROPERTY_VALUE_MAX]; char extraOptsBuf[PROPERTY_VALUE_MAX]; @@ -739,6 +743,43 @@ int AndroidRuntime::startVm(JavaVM** pJavaVM, JNIEnv** pEnv) parseCompilerOption("dalvik.vm.dex2oat-threads", dex2oatThreadsBuf, "-j", "-Xcompiler-option"); parseCompilerOption("dalvik.vm.image-dex2oat-threads", dex2oatThreadsImageBuf, "-j", "-Ximage-compiler-option"); + + // The runtime will compile a boot image, when necessary, not using installd. Thus, we need to + // pass the instruction-set-features/variant as an image-compiler-option. + // TODO: Find a better way for the instruction-set. +#if defined(__arm__) + constexpr const char* instruction_set = "arm"; +#elif defined(__aarch64__) + constexpr const char* instruction_set = "arm64"; +#elif defined(__mips__) && !defined(__LP64__) + constexpr const char* instruction_set = "mips"; +#elif defined(__mips__) && defined(__LP64__) + constexpr const char* instruction_set = "mips64"; +#elif defined(__i386__) + constexpr const char* instruction_set = "x86"; +#elif defined(__x86_64__) + constexpr const char* instruction_set = "x86_64"; +#else + constexpr const char* instruction_set = "unknown"; +#endif + // Note: it is OK to reuse the buffer, as the values are exactly the same between + // * compiler-option, used for runtime compilation (DexClassLoader) + // * image-compiler-option, used for boot-image compilation on device + + // Copy the variant. + sprintf(dex2oat_isa_variant_key, "dalvik.vm.isa.%s.variant", instruction_set); + parseCompilerOption(dex2oat_isa_variant_key, dex2oat_isa_variant, + "--instruction-set-variant=", "-Ximage-compiler-option"); + parseCompilerOption(dex2oat_isa_variant_key, dex2oat_isa_variant, + "--instruction-set-variant=", "-Xcompiler-option"); + // Copy the features. + sprintf(dex2oat_isa_features_key, "dalvik.vm.isa.%s.features", instruction_set); + parseCompilerOption(dex2oat_isa_features_key, dex2oat_isa_features, + "--instruction-set-features=", "-Ximage-compiler-option"); + parseCompilerOption(dex2oat_isa_features_key, dex2oat_isa_features, + "--instruction-set-features=", "-Xcompiler-option"); + + property_get("dalvik.vm.dex2oat-flags", dex2oatFlagsBuf, ""); parseExtraOpts(dex2oatFlagsBuf, "-Xcompiler-option"); |