diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2012-12-13 04:17:14 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2012-12-13 04:17:14 +0000 |
commit | 0f207edaa571e1c1ec0d40bf3f568d7ecfd6d673 (patch) | |
tree | 627601af8f4529b5a4f105498cd6f9bfff074ef5 /clang/lib/Driver/Tools.cpp | |
parent | bc8016d06259a0a503d25f82b6c0d51f3c8b65f2 (diff) | |
download | bcm5719-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.cpp | 16 |
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, |