]> granicus.if.org Git - clang/commitdiff
Link in the ubsan runtime when building shared objects.
authorNick Lewycky <nicholas@mxc.ca>
Tue, 13 Aug 2013 22:32:35 +0000 (22:32 +0000)
committerNick Lewycky <nicholas@mxc.ca>
Tue, 13 Aug 2013 22:32:35 +0000 (22:32 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@188325 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Driver/Tools.cpp
test/Driver/sanitizer-ld.c

index a6be76ea3a3fdb943332edb57ce5b1a5699daebc..2ae23aec8e159c721557769483b884e6d71c8816 100644 (file)
@@ -1734,9 +1734,6 @@ static void addLsanRTLinux(const ToolChain &TC, const ArgList &Args,
 static void addUbsanRTLinux(const ToolChain &TC, const ArgList &Args,
                             ArgStringList &CmdArgs, bool IsCXX,
                             bool HasOtherSanitizerRt) {
-  if (Args.hasArg(options::OPT_shared))
-    return;
-
   // Need a copy of sanitizer_common. This could come from another sanitizer
   // runtime; if we're not including one, include our own copy.
   if (!HasOtherSanitizerRt)
index bfc9edbfb3931a6c6dcb2eaa5dee351671abf37a..691b44bba2624fbfede2f1cd12d64fead89bbaf4 100644 (file)
 // RUN:     -shared \
 // RUN:   | FileCheck --check-prefix=CHECK-UBSAN-LINUX-SHARED %s
 // CHECK-UBSAN-LINUX-SHARED: "{{.*}}ld{{(.exe)?}}"
-// CHECK-UBSAN-LINUX-SHARED-NOT: libclang_rt.ubsan-i386.a"
+// CHECK-UBSAN-LINUX-SHARED: libclang_rt.ubsan-i386.a"
 
 // RUN: %clang -no-canonical-prefixes %s -### -o %t.o 2>&1 \
 // RUN:     -target x86_64-unknown-linux -fsanitize=leak \