|
@@ -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";
|