diff options
author | Chandler Carruth <chandlerc@gmail.com> | 2012-01-10 19:47:42 +0000 |
---|---|---|
committer | Chandler Carruth <chandlerc@gmail.com> | 2012-01-10 19:47:42 +0000 |
commit | b43550bf1bd944a16cdae9703cb1c2049b04e6bd (patch) | |
tree | 0faae4a107f3d29d412e4223d5f8cd0a814f9836 | |
parent | 6e6f93a1f16d9804db79390382e9d1f6322cdbfd (diff) |
Add support for the androideabi environment to our triple support, and
for the arm-linux-androideabi triple in particular.
Also use this to do a better job of selecting soft FP settings.
Patch by Evgeniy Stepanov.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@147872 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/CodeGen/TargetInfo.cpp | 2 | ||||
-rw-r--r-- | lib/Driver/ToolChains.cpp | 5 | ||||
-rw-r--r-- | lib/Driver/Tools.cpp | 10 |
3 files changed, 15 insertions, 2 deletions
diff --git a/lib/CodeGen/TargetInfo.cpp b/lib/CodeGen/TargetInfo.cpp index b5916229b0..c9e6fc3de9 100644 --- a/lib/CodeGen/TargetInfo.cpp +++ b/lib/CodeGen/TargetInfo.cpp @@ -2374,7 +2374,7 @@ public: bool isEABI() const { StringRef Env = getContext().getTargetInfo().getTriple().getEnvironmentName(); - return (Env == "gnueabi" || Env == "eabi"); + return (Env == "gnueabi" || Env == "eabi" || Env == "androideabi"); } private: diff --git a/lib/Driver/ToolChains.cpp b/lib/Driver/ToolChains.cpp index 3034ede2ae..3dcdf13f00 100644 --- a/lib/Driver/ToolChains.cpp +++ b/lib/Driver/ToolChains.cpp @@ -1164,7 +1164,10 @@ Generic_GCC::GCCInstallationDetector::GCCInstallationDetector(const Driver &D) SmallVectorImpl<StringRef> &Triples) { if (HostArch == llvm::Triple::arm || HostArch == llvm::Triple::thumb) { static const char *const ARMLibDirs[] = { "/lib" }; - static const char *const ARMTriples[] = { "arm-linux-gnueabi" }; + static const char *const ARMTriples[] = { + "arm-linux-gnueabi", + "arm-linux-androideabi" + }; LibDirs.append(ARMLibDirs, ARMLibDirs + llvm::array_lengthof(ARMLibDirs)); Triples.append(ARMTriples, ARMTriples + llvm::array_lengthof(ARMTriples)); } else if (HostArch == llvm::Triple::x86_64) { diff --git a/lib/Driver/Tools.cpp b/lib/Driver/Tools.cpp index bd3d638afd..a241712da9 100644 --- a/lib/Driver/Tools.cpp +++ b/lib/Driver/Tools.cpp @@ -517,6 +517,7 @@ void Clang::AddARMTargetArgs(const ArgList &Args, } else { // Select the default based on the platform. switch(Triple.getEnvironment()) { + case llvm::Triple::ANDROIDEABI: case llvm::Triple::GNUEABI: ABIName = "aapcs-linux"; break; @@ -589,6 +590,15 @@ void Clang::AddARMTargetArgs(const ArgList &Args, // EABI is always AAPCS, and if it was not marked 'hard', it's softfp FloatABI = "softfp"; break; + case llvm::Triple::ANDROIDEABI: { + StringRef ArchName = + getLLVMArchSuffixForARM(getARMTargetCPU(Args, Triple)); + if (ArchName.startswith("v7")) + FloatABI = "softfp"; + else + FloatABI = "soft"; + break; + } default: // Assume "soft", but warn the user we are guessing. FloatABI = "soft"; |