Home | History | Annotate | Download | only in CodeGenCXX
      1 // Test -fsanitize-memory-use-after-dtor
      2 // RUN: %clang_cc1 -fsanitize=memory -fsanitize-memory-use-after-dtor -std=c++11 -triple=x86_64-pc-linux -emit-llvm -o - %s | FileCheck %s
      3 
      4 // The no_sanitize_memory attribute, when applied to a destructor,
      5 // represses emission of sanitizing callback
      6 
      7 template <class T> class Vector {
      8  public:
      9   int size;
     10   ~Vector() {}
     11 };
     12 
     13 struct No_San {
     14   Vector<int> v;
     15   int x;
     16   No_San() { }
     17   __attribute__((no_sanitize_memory)) ~No_San() = default;
     18 };
     19 
     20 int main() {
     21   No_San *ns = new No_San();
     22   ns->~No_San();
     23   return 0;
     24 }
     25 
     26 // Repressing the sanitization attribute results in no msan
     27 // instrumentation of the destructor
     28 // CHECK: define {{.*}}No_SanD1Ev{{.*}} [[ATTRIBUTE:#[0-9]+]]
     29 // CHECK-NOT: call void {{.*}}sanitizer_dtor_callback
     30 // CHECK: ret void
     31 
     32 // CHECK: define {{.*}}No_SanD2Ev{{.*}} [[ATTRIBUTE:#[0-9]+]]
     33 // CHECK-NOT: call void {{.*}}sanitizer_dtor_callback
     34 // CHECK: call void {{.*}}VectorIiED2Ev
     35 // CHECK-NOT: call void {{.*}}sanitizer_dtor_callback
     36 // CHECK: ret void
     37 
     38 // CHECK: define {{.*}}VectorIiED2Ev
     39 // CHECK: call void {{.*}}sanitizer_dtor_callback
     40 // CHECK: ret void
     41 
     42 // When attribute is repressed, the destructor does not emit any tail calls
     43 // CHECK-NOT: attributes [[ATTRIBUTE]] = {{.*}} sanitize_memory
     44