diff options
author | 2015-08-10 15:30:07 -0700 | |
---|---|---|
committer | 2015-08-18 11:21:05 -0700 | |
commit | 50fa993d67f8a20322c27c1a77e7efcf826531fc (patch) | |
tree | 76d6b73a9d8a8ef2709aef6c01778af6a0d4ada1 /compiler/jni/quick/calling_convention.cc | |
parent | 4500fcbe682d666a24c2e8f6e0cb90cfb35d3fa3 (diff) |
Svelter libart-compiler
Added new environment variable ART_{TARGET,HOST}_CODEGEN_ARCHS which
may be set to 'all', 'svelte' or a space separated list of architectures.
When compiled with ART_{TARGET,HOST}_CODEGEN_ARCHS='all' (the default
value) dex2oat will be able to generate output for all supported
architectures.
When compiled with ART_TARGET_CODEGEN_ARCHS='svelte'
only the architectures of the TARGET will be included. When
ART_HOST_CODEGEN_ARCHS='svelte' all architectures the target includes
and the host architectures will be included on the host dex2oat.
If a list of architectures is given only those will be included.
Change-Id: I87f4ad0131ab1b37544d8799e947ce4733b6daec
Diffstat (limited to 'compiler/jni/quick/calling_convention.cc')
-rw-r--r-- | compiler/jni/quick/calling_convention.cc | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/compiler/jni/quick/calling_convention.cc b/compiler/jni/quick/calling_convention.cc index bb8136bfe1..cef8c5d03d 100644 --- a/compiler/jni/quick/calling_convention.cc +++ b/compiler/jni/quick/calling_convention.cc @@ -17,12 +17,30 @@ #include "calling_convention.h" #include "base/logging.h" + +#ifdef ART_ENABLE_CODEGEN_arm #include "jni/quick/arm/calling_convention_arm.h" +#endif + +#ifdef ART_ENABLE_CODEGEN_arm64 #include "jni/quick/arm64/calling_convention_arm64.h" +#endif + +#ifdef ART_ENABLE_CODEGEN_mips #include "jni/quick/mips/calling_convention_mips.h" +#endif + +#ifdef ART_ENABLE_CODEGEN_mips64 #include "jni/quick/mips64/calling_convention_mips64.h" +#endif + +#ifdef ART_ENABLE_CODEGEN_x86 #include "jni/quick/x86/calling_convention_x86.h" +#endif + +#ifdef ART_ENABLE_CODEGEN_x86_64 #include "jni/quick/x86_64/calling_convention_x86_64.h" +#endif namespace art { @@ -31,19 +49,31 @@ namespace art { ManagedRuntimeCallingConvention* ManagedRuntimeCallingConvention::Create( bool is_static, bool is_synchronized, const char* shorty, InstructionSet instruction_set) { switch (instruction_set) { +#ifdef ART_ENABLE_CODEGEN_arm case kArm: case kThumb2: return new arm::ArmManagedRuntimeCallingConvention(is_static, is_synchronized, shorty); +#endif +#ifdef ART_ENABLE_CODEGEN_arm64 case kArm64: return new arm64::Arm64ManagedRuntimeCallingConvention(is_static, is_synchronized, shorty); +#endif +#ifdef ART_ENABLE_CODEGEN_mips case kMips: return new mips::MipsManagedRuntimeCallingConvention(is_static, is_synchronized, shorty); +#endif +#ifdef ART_ENABLE_CODEGEN_mips64 case kMips64: return new mips64::Mips64ManagedRuntimeCallingConvention(is_static, is_synchronized, shorty); +#endif +#ifdef ART_ENABLE_CODEGEN_x86 case kX86: return new x86::X86ManagedRuntimeCallingConvention(is_static, is_synchronized, shorty); +#endif +#ifdef ART_ENABLE_CODEGEN_x86_64 case kX86_64: return new x86_64::X86_64ManagedRuntimeCallingConvention(is_static, is_synchronized, shorty); +#endif default: LOG(FATAL) << "Unknown InstructionSet: " << instruction_set; return nullptr; @@ -106,19 +136,31 @@ JniCallingConvention* JniCallingConvention::Create(bool is_static, bool is_synch const char* shorty, InstructionSet instruction_set) { switch (instruction_set) { +#ifdef ART_ENABLE_CODEGEN_arm case kArm: case kThumb2: return new arm::ArmJniCallingConvention(is_static, is_synchronized, shorty); +#endif +#ifdef ART_ENABLE_CODEGEN_arm64 case kArm64: return new arm64::Arm64JniCallingConvention(is_static, is_synchronized, shorty); +#endif +#ifdef ART_ENABLE_CODEGEN_mips case kMips: return new mips::MipsJniCallingConvention(is_static, is_synchronized, shorty); +#endif +#ifdef ART_ENABLE_CODEGEN_mips64 case kMips64: return new mips64::Mips64JniCallingConvention(is_static, is_synchronized, shorty); +#endif +#ifdef ART_ENABLE_CODEGEN_x86 case kX86: return new x86::X86JniCallingConvention(is_static, is_synchronized, shorty); +#endif +#ifdef ART_ENABLE_CODEGEN_x86_64 case kX86_64: return new x86_64::X86_64JniCallingConvention(is_static, is_synchronized, shorty); +#endif default: LOG(FATAL) << "Unknown InstructionSet: " << instruction_set; return nullptr; |