summaryrefslogtreecommitdiffstats
path: root/clang/lib/Driver/ToolChains/Clang.cpp
diff options
context:
space:
mode:
authorVladimir Stefanovic <vladimir.stefanovic@rt-rk.com>2019-01-18 19:54:51 +0000
committerVladimir Stefanovic <vladimir.stefanovic@rt-rk.com>2019-01-18 19:54:51 +0000
commit99113a0ccf3dd77ccc1b3c6fd7bff986e6f376fe (patch)
treebad5a0c2d142b121d6c12de7e256f5682dd72db1 /clang/lib/Driver/ToolChains/Clang.cpp
parenteaa421d1f9c3748c550e2a91fcb134a3d2a8ebff (diff)
downloadbcm5719-llvm-99113a0ccf3dd77ccc1b3c6fd7bff986e6f376fe.tar.gz
bcm5719-llvm-99113a0ccf3dd77ccc1b3c6fd7bff986e6f376fe.zip
[mips] Add '-mrelax-pic-calls', '-mno-relax-pic-calls'
These two options enable/disable emission of R_{MICRO}MIPS_JALR fixups along with PIC calls. The linker may then try to turn PIC calls into direct jumps. By default, these fixups do get emitted by the backend, use '-mno-relax-pic-calls' to omit them. Differential revision: https://reviews.llvm.org/D56878 llvm-svn: 351579
Diffstat (limited to 'clang/lib/Driver/ToolChains/Clang.cpp')
-rw-r--r--clang/lib/Driver/ToolChains/Clang.cpp8
1 files changed, 8 insertions, 0 deletions
diff --git a/clang/lib/Driver/ToolChains/Clang.cpp b/clang/lib/Driver/ToolChains/Clang.cpp
index 75f16898dfa..589f53b1192 100644
--- a/clang/lib/Driver/ToolChains/Clang.cpp
+++ b/clang/lib/Driver/ToolChains/Clang.cpp
@@ -1716,6 +1716,14 @@ void Clang::AddMIPSTargetArgs(const ArgList &Args,
} else
D.Diag(diag::warn_target_unsupported_compact_branches) << CPUName;
}
+
+ if (Arg *A = Args.getLastArg(options::OPT_mrelax_pic_calls,
+ options::OPT_mno_relax_pic_calls)) {
+ if (A->getOption().matches(options::OPT_mno_relax_pic_calls)) {
+ CmdArgs.push_back("-mllvm");
+ CmdArgs.push_back("-mips-jalr-reloc=0");
+ }
+ }
}
void Clang::AddPPCTargetArgs(const ArgList &Args,
OpenPOWER on IntegriCloud