From 3ca41d4758afa21fe850faf0c035b165a65236b0 Mon Sep 17 00:00:00 2001 From: Daniel Dunbar Date: Wed, 7 Dec 2011 23:22:17 +0000 Subject: Driver/Linux: Fix the ASAN library path to match current compiler-rt integration. llvm-svn: 146098 --- clang/lib/Driver/Tools.cpp | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) (limited to 'clang/lib/Driver/Tools.cpp') 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-.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"); -- cgit v1.2.3