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 | 3ca41d4758afa21fe850faf0c035b165a65236b0 (patch) | |
tree | 04268ee19c90069f359ec30ba1b9ee6c01688e23 /clang/lib/Driver/Tools.cpp | |
parent | 9778e7a67c5ebb6a36d84b0080cb1a4f039888e6 (diff) | |
download | bcm5719-llvm-3ca41d4758afa21fe850faf0c035b165a65236b0.tar.gz bcm5719-llvm-3ca41d4758afa21fe850faf0c035b165a65236b0.zip |
Driver/Linux: Fix the ASAN library path to match current compiler-rt
integration.
llvm-svn: 146098
Diffstat (limited to 'clang/lib/Driver/Tools.cpp')
-rw-r--r-- | clang/lib/Driver/Tools.cpp | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/clang/lib/Driver/Tools.cpp b/clang/lib/Driver/Tools.cpp index 2d95aec0800..a8a88e70b18 100644 --- a/clang/lib/Driver/Tools.cpp +++ b/clang/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"); |