summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon Atanasyan <simon@atanasyan.com>2014-06-25 05:00:59 +0000
committerSimon Atanasyan <simon@atanasyan.com>2014-06-25 05:00:59 +0000
commit7925371bbe385085182e24f9049b72ca5302099d (patch)
treedc5a26234c793d2bfec78cbe79763897b3f5470e
parentd706ede5483a198a60f7d435d1898dcca6222d91 (diff)
downloadclang-7925371bbe385085182e24f9049b72ca5302099d.tar.gz
clang-7925371bbe385085182e24f9049b72ca5302099d.tar.bz2
clang-7925371bbe385085182e24f9049b72ca5302099d.tar.xz
[Driver] Follow-up to r211598, r211663. Do not build a dynamic linker
path using sub-strings concatenation. Return the whole string explicitly. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@211665 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Driver/Tools.cpp12
1 files changed, 6 insertions, 6 deletions
diff --git a/lib/Driver/Tools.cpp b/lib/Driver/Tools.cpp
index 4ccb86365f..48528d9265 100644
--- a/lib/Driver/Tools.cpp
+++ b/lib/Driver/Tools.cpp
@@ -6929,8 +6929,8 @@ static void AddLibgcc(const llvm::Triple &Triple, const Driver &D,
CmdArgs.push_back("-ldl");
}
-static Twine getLinuxDynamicLinker(const ArgList &Args,
- const toolchains::Linux &ToolChain) {
+static StringRef getLinuxDynamicLinker(const ArgList &Args,
+ const toolchains::Linux &ToolChain) {
if (ToolChain.getTriple().getEnvironment() == llvm::Triple::Android) {
if (ToolChain.getTriple().isArch64Bit())
return "/system/bin/linker64";
@@ -6964,11 +6964,11 @@ static Twine getLinuxDynamicLinker(const ArgList &Args,
return "/lib/ld.so.1";
} else if (ToolChain.getArch() == llvm::Triple::mips64 ||
ToolChain.getArch() == llvm::Triple::mips64el) {
- Twine LinkerFile =
- mips::isNaN2008(Args) ? "ld-linux-mipsn8.so.1" : "ld.so.1";
if (mips::hasMipsAbiArg(Args, "n32"))
- return "/lib32/" + LinkerFile;
- return "/lib64/" + LinkerFile;
+ return mips::isNaN2008(Args) ? "/lib32/ld-linux-mipsn8.so.1"
+ : "/lib32/ld.so.1";
+ return mips::isNaN2008(Args) ? "/lib64/ld-linux-mipsn8.so.1"
+ : "/lib64/ld.so.1";
} else if (ToolChain.getArch() == llvm::Triple::ppc)
return "/lib/ld.so.1";
else if (ToolChain.getArch() == llvm::Triple::ppc64 ||