summaryrefslogtreecommitdiffstats
path: root/clang/lib/Driver/Tools.cpp
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2012-12-13 04:17:14 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2012-12-13 04:17:14 +0000
commit0f207edaa571e1c1ec0d40bf3f568d7ecfd6d673 (patch)
tree627601af8f4529b5a4f105498cd6f9bfff074ef5 /clang/lib/Driver/Tools.cpp
parentbc8016d06259a0a503d25f82b6c0d51f3c8b65f2 (diff)
downloadbcm5719-llvm-0f207edaa571e1c1ec0d40bf3f568d7ecfd6d673.tar.gz
bcm5719-llvm-0f207edaa571e1c1ec0d40bf3f568d7ecfd6d673.zip
Initial support for FreeBSD on ARM.
Patch by Andrew Turner. llvm-svn: 170096
Diffstat (limited to 'clang/lib/Driver/Tools.cpp')
-rw-r--r--clang/lib/Driver/Tools.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/clang/lib/Driver/Tools.cpp b/clang/lib/Driver/Tools.cpp
index ee86da6c340..2737c1a88a8 100644
--- a/clang/lib/Driver/Tools.cpp
+++ b/clang/lib/Driver/Tools.cpp
@@ -662,6 +662,11 @@ static StringRef getARMFloatABI(const Driver &D,
break;
}
+ case llvm::Triple::FreeBSD:
+ // FreeBSD defaults to soft float
+ FloatABI = "soft";
+ break;
+
default:
switch(Triple.getEnvironment()) {
case llvm::Triple::GNUEABIHF:
@@ -4944,6 +4949,17 @@ void freebsd::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
LastPICArg->getOption().matches(options::OPT_fpie))) {
CmdArgs.push_back("-KPIC");
}
+ } else if (getToolChain().getArch() == llvm::Triple::arm ||
+ getToolChain().getArch() == llvm::Triple::thumb) {
+ CmdArgs.push_back("-mfpu=softvfp");
+ switch(getToolChain().getTriple().getEnvironment()) {
+ case llvm::Triple::GNUEABI:
+ case llvm::Triple::EABI:
+ break;
+
+ default:
+ CmdArgs.push_back("-matpcs");
+ }
}
Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
OpenPOWER on IntegriCloud