[ASan] Do not instrument globals from the llvm.metadata section.
authorAlexander Potapenko <glider@google.com>
Thu, 20 Mar 2014 10:48:34 +0000 (10:48 +0000)
committerAlexander Potapenko <glider@google.com>
Thu, 20 Mar 2014 10:48:34 +0000 (10:48 +0000)
Fixes https://code.google.com/p/address-sanitizer/issues/detail?id=279.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@204331 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/Instrumentation/AddressSanitizer.cpp
test/Instrumentation/AddressSanitizer/do-not-instrument-llvm-metadata.ll [new file with mode: 0644]

index 5c35cc8faf8f9e9170ac0918a9e40a124adc5a4f..a19e1f70631e16d48fe2f2bae97dcc56db8984f1 100644 (file)
@@ -927,6 +927,8 @@ bool AddressSanitizerModule::ShouldInstrumentGlobal(GlobalVariable *G) {
       DEBUG(dbgs() << "Ignoring a cstring literal: " << *G << "\n");
       return false;
     }
+    // Globals from llvm.metadata aren't emitted, do not instrument them.
+    if (Section == "llvm.metadata") return false;
   }
 
   return true;
diff --git a/test/Instrumentation/AddressSanitizer/do-not-instrument-llvm-metadata.ll b/test/Instrumentation/AddressSanitizer/do-not-instrument-llvm-metadata.ll
new file mode 100644 (file)
index 0000000..fbfc096
--- /dev/null
@@ -0,0 +1,12 @@
+; This test checks that we are not instrumenting globals in llvm.metadata.
+; RUN: opt < %s -asan -asan-module -S | FileCheck %s
+
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+@.str_noinst = private unnamed_addr constant [4 x i8] c"aaa\00", section "llvm.metadata"
+@.str_inst = private unnamed_addr constant [4 x i8] c"aaa\00",
+
+; CHECK-NOT: {{asan_gen.*str_noinst}}
+; CHECK: {{asan_gen.*str_inst}}
+; CHECK: @asan.module_ctor