summaryrefslogtreecommitdiffstats
path: root/contrib/llvm/patches/patch-r262262-clang-r198311-sparc.diff
diff options
context:
space:
mode:
Diffstat (limited to 'contrib/llvm/patches/patch-r262262-clang-r198311-sparc.diff')
-rw-r--r--contrib/llvm/patches/patch-r262262-clang-r198311-sparc.diff31
1 files changed, 31 insertions, 0 deletions
diff --git a/contrib/llvm/patches/patch-r262262-clang-r198311-sparc.diff b/contrib/llvm/patches/patch-r262262-clang-r198311-sparc.diff
new file mode 100644
index 0000000..751b976
--- /dev/null
+++ b/contrib/llvm/patches/patch-r262262-clang-r198311-sparc.diff
@@ -0,0 +1,31 @@
+Pull in r198311 from upstream clang trunk (by Roman Divacky):
+
+ In the FreeBSD assembler driver, inform the sparc assembler that we're producing
+ PIC code.
+
+Introduced here: http://svn.freebsd.org/changeset/base/262262
+
+Index: tools/clang/lib/Driver/Tools.cpp
+===================================================================
+--- tools/clang/lib/Driver/Tools.cpp
++++ tools/clang/lib/Driver/Tools.cpp
+@@ -5785,6 +5785,19 @@ void freebsd::Assemble::ConstructJob(Compilation &
+ default:
+ CmdArgs.push_back("-matpcs");
+ }
++ } else if (getToolChain().getArch() == llvm::Triple::sparc ||
++ getToolChain().getArch() == llvm::Triple::sparcv9) {
++ Arg *LastPICArg = Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
++ options::OPT_fpic, options::OPT_fno_pic,
++ options::OPT_fPIE, options::OPT_fno_PIE,
++ options::OPT_fpie, options::OPT_fno_pie);
++ if (LastPICArg &&
++ (LastPICArg->getOption().matches(options::OPT_fPIC) ||
++ LastPICArg->getOption().matches(options::OPT_fpic) ||
++ LastPICArg->getOption().matches(options::OPT_fPIE) ||
++ LastPICArg->getOption().matches(options::OPT_fpie))) {
++ CmdArgs.push_back("-KPIC");
++ }
+ }
+
+ Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
OpenPOWER on IntegriCloud