diff options
author | Daniel Dunbar <daniel@zuster.org> | 2011-12-07 23:22:17 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2011-12-07 23:22:17 +0000 |
commit | 8cd0d25df91d7172bfd0ed6013f89ad0083ce301 (patch) | |
tree | 2f1006d4482a19d0e11b7191f51ef19b5e079e43 /lib/Driver/Tools.cpp | |
parent | c24767c9dd869ba0e78c2d4c86d86ed24b8e401e (diff) |
Driver/Linux: Fix the ASAN library path to match current compiler-rt
integration.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@146098 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Driver/Tools.cpp')
-rw-r--r-- | lib/Driver/Tools.cpp | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/lib/Driver/Tools.cpp b/lib/Driver/Tools.cpp index 2d95aec080..a8a88e70b1 100644 --- a/lib/Driver/Tools.cpp +++ b/lib/Driver/Tools.cpp @@ -1109,11 +1109,13 @@ static void addAsanRTLinux(const ToolChain &TC, const ArgList &Args, !Args.hasFlag(options::OPT_faddress_sanitizer, options::OPT_fno_address_sanitizer, false)) return; - // LibAsan is "../lib/clang/linux/ArchName/libclang_rt.asan.a" - llvm::SmallString<128> LibAsan = - llvm::sys::path::parent_path(StringRef(TC.getDriver().Dir)); - llvm::sys::path::append(LibAsan, "lib", "clang", "linux", TC.getArchName()); - llvm::sys::path::append(LibAsan, "libclang_rt.asan.a"); + + // LibAsan is "libclang_rt.asan-<ArchName>.a" in the Linux library resource + // directory. + llvm::SmallString<128> LibAsan(TC.getDriver().ResourceDir); + llvm::sys::path::append(LibAsan, "lib", "linux", + (Twine("libclang_rt.asan-") + + TC.getArchName() + ".a")); CmdArgs.push_back(Args.MakeArgString(LibAsan)); CmdArgs.push_back("-lpthread"); CmdArgs.push_back("-ldl"); |