r178538 - [ASan] Emit lifetime markers for local variables in -fsanitize=use-after-scope mode

Alexey Samsonov samsonov at google.com
Tue Apr 2 06:19:46 PDT 2013


Author: samsonov
Date: Tue Apr  2 08:19:46 2013
New Revision: 178538

URL: http://llvm.org/viewvc/llvm-project?rev=178538&view=rev
Log:
[ASan] Emit lifetime markers for local variables in -fsanitize=use-after-scope mode

Added:
    cfe/trunk/test/CodeGen/sanitize-use-after-scope.c
Modified:
    cfe/trunk/lib/CodeGen/CGDecl.cpp

Modified: cfe/trunk/lib/CodeGen/CGDecl.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGDecl.cpp?rev=178538&r1=178537&r2=178538&view=diff
==============================================================================
--- cfe/trunk/lib/CodeGen/CGDecl.cpp (original)
+++ cfe/trunk/lib/CodeGen/CGDecl.cpp Tue Apr  2 08:19:46 2013
@@ -786,6 +786,9 @@ static bool shouldUseMemSetPlusStoresToI
 /// Should we use the LLVM lifetime intrinsics for the given local variable?
 static bool shouldUseLifetimeMarkers(CodeGenFunction &CGF, const VarDecl &D,
                                      unsigned Size) {
+  // Always emit lifetime markers in -fsanitize=use-after-scope mode.
+  if (CGF.getLangOpts().Sanitize.UseAfterScope)
+    return true;
   // For now, only in optimized builds.
   if (CGF.CGM.getCodeGenOpts().OptimizationLevel == 0)
     return false;

Added: cfe/trunk/test/CodeGen/sanitize-use-after-scope.c
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/sanitize-use-after-scope.c?rev=178538&view=auto
==============================================================================
--- cfe/trunk/test/CodeGen/sanitize-use-after-scope.c (added)
+++ cfe/trunk/test/CodeGen/sanitize-use-after-scope.c Tue Apr  2 08:19:46 2013
@@ -0,0 +1,22 @@
+// RUN: %clang_cc1 -S -emit-llvm -o - -fsanitize=address,use-after-scope %s \
+// RUN:     | FileCheck %s -check-prefix=USE-AFTER-SCOPE
+// RUN: %clang_cc1 -S -emit-llvm -o - -fsanitize=address %s \
+// RUN:     | FileCheck %s -check-prefix=ADDRESS-ONLY
+
+extern int bar(char *A, int n);
+
+// ADDRESS-ONLY-NOT: @llvm.lifetime.start
+int foo (int n) {
+  if (n) {
+    // USE-AFTER-SCOPE: @llvm.lifetime.start(i64 10, i8* {{.*}})
+    char A[10];
+    return bar(A, 1);
+    // USE-AFTER-SCOPE: @llvm.lifetime.end(i64 10, i8* {{.*}})
+  } else {
+    // USE-AFTER-SCOPE: @llvm.lifetime.start(i64 20, i8* {{.*}})
+    char A[20];
+    return bar(A, 2);
+    // USE-AFTER-SCOPE: @llvm.lifetime.end(i64 20, i8* {{.*}})
+  }
+}
+





More information about the cfe-commits mailing list