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 | c89aa9d96468e763c27da8668e4201e657dc2a4f (patch) | |
| tree | 2e75a102c8c2bf346ebe405fd69616f521cf2704 /clang/lib/Driver/Tools.cpp | |
| parent | 9a7510af462f417f82b676af2dc7daace752ee21 (diff) | |
| download | bcm5719-llvm-c89aa9d96468e763c27da8668e4201e657dc2a4f.tar.gz bcm5719-llvm-c89aa9d96468e763c27da8668e4201e657dc2a4f.zip | |
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.
llvm-svn: 147872
Diffstat (limited to 'clang/lib/Driver/Tools.cpp')
| -rw-r--r-- | clang/lib/Driver/Tools.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/clang/lib/Driver/Tools.cpp b/clang/lib/Driver/Tools.cpp index bd3d638afd5..a241712da96 100644 --- a/clang/lib/Driver/Tools.cpp +++ b/clang/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"; |

