]> granicus.if.org Git - clang/commitdiff
Revert "Revert rL346454: Fix a use-after-free introduced by r344915."
authorAdrian Prantl <aprantl@apple.com>
Fri, 9 Nov 2018 21:17:38 +0000 (21:17 +0000)
committerAdrian Prantl <aprantl@apple.com>
Fri, 9 Nov 2018 21:17:38 +0000 (21:17 +0000)
This un-reverts commit 346454 with a relaxed CHECK for Windows.

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

lib/CodeGen/CGDebugInfo.cpp
test/CodeGen/ubsan-debuglog-return.c [new file with mode: 0644]

index 1d999e446ccbf1013993f4fb6057c66a06e55ed5..81cc07dddd1029d3ef903a29c0bfa2e98f264b46 100644 (file)
@@ -3538,7 +3538,7 @@ void CGDebugInfo::EmitLocation(CGBuilderTy &Builder, SourceLocation Loc) {
   // Update our current location
   setLocation(Loc);
 
-  if (CurLoc.isInvalid() || CurLoc.isMacroID())
+  if (CurLoc.isInvalid() || CurLoc.isMacroID() || LexicalBlockStack.empty())
     return;
 
   llvm::MDNode *Scope = LexicalBlockStack.back();
diff --git a/test/CodeGen/ubsan-debuglog-return.c b/test/CodeGen/ubsan-debuglog-return.c
new file mode 100644 (file)
index 0000000..23a1326
--- /dev/null
@@ -0,0 +1,10 @@
+// RUN: %clang_cc1 -x c -debug-info-kind=line-tables-only -emit-llvm -fsanitize=returns-nonnull-attribute -o - %s | FileCheck %s
+// The UBSAN function call in the epilogue needs to have a debug location.
+
+__attribute__((returns_nonnull)) void *allocate() {}
+
+// CHECK: define {{.*}}nonnull i8* @allocate(){{.*}} !dbg
+// CHECK: call void @__ubsan_handle_nonnull_return_v1_abort
+// CHECK-SAME:  !dbg ![[LOC:[0-9]+]]
+// CHECK: ret i8*
+// CHECK-SAME:  !dbg ![[LOC]]