From 5ca58a0aca0320b8980921e8ee55112668817939 Mon Sep 17 00:00:00 2001
From: Adrian Prantl <aprantl@apple.com>
Date: Tue, 12 Mar 2013 21:40:00 +0000
Subject: [PATCH] Eliminate backend dependency in CFE testcase.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@176901 91177308-0d34-0410-b5e6-96231b3b80d8
---
 test/CodeGenCXX/debug-info-same-line.cpp | 43 ++++++++++++++++--------
 1 file changed, 29 insertions(+), 14 deletions(-)

diff --git a/test/CodeGenCXX/debug-info-same-line.cpp b/test/CodeGenCXX/debug-info-same-line.cpp
index 6658c883db0..be7c4d86781 100644
--- a/test/CodeGenCXX/debug-info-same-line.cpp
+++ b/test/CodeGenCXX/debug-info-same-line.cpp
@@ -1,8 +1,8 @@
-// RUN: %clang_cc1 -g -emit-obj -o %t %s
-// RUN: llvm-dwarfdump %t | FileCheck %s
-// In the attached test case a post-r166236 clang coalesces two
-// instances of an inlined function in a way that makes it appear as
-// if the function was only inlined once.
+// RUN: %clang_cc1 -g -emit-llvm -o - %s | FileCheck %s
+
+// Make sure that clang outputs distinct debug info for a function
+// that is inlined twice on the same line. Otherwise it would appear
+// as if the function was only inlined once.
 
 #define INLINE inline __attribute__((always_inline))
 
@@ -55,12 +55,27 @@ main(int argc, char const *argv[])
     return 0;
 }
 
-// CHECK: DW_TAG_inlined_subroutine
-// CHECK: DW_TAG_inlined_subroutine
-// CHECK: DW_TAG_inlined_subroutine
-// CHECK: DW_TAG_inlined_subroutine
-// CHECK-NOT: DW_TAG_inlined_subroutine
-// CHECK: DW_AT_call_line {{.*}} (0x2a)
-// CHECK: DW_TAG_inlined_subroutine
-// CHECK-NOT: DW_TAG_inlined_subroutine
-// CHECK: DW_AT_call_line {{.*}} (0x2a)
+// CHECK: define i32 @_Z3fooii(i32 %i, i32 %j)
+// i
+// CHECK: call void @llvm.dbg.declare
+// j
+// CHECK: call void @llvm.dbg.declare
+// x
+// CHECK: call void @llvm.dbg.declare
+// y
+// CHECK: call void @llvm.dbg.declare
+// result
+// CHECK: call void @llvm.dbg.declare
+
+// CHECK: call void @llvm.dbg.declare(metadata !{i32* %{{.*}}}, metadata ![[A_MD:[0-9]+]]), !dbg ![[A_DI:[0-9]+]]
+// CHECK: call void @llvm.dbg.declare(metadata !{i32* %{{.*}}}, metadata ![[B_MD:[0-9]+]]), !dbg ![[B_DI:[0-9]+]]
+// result
+// CHECK: call void @llvm.dbg.declare
+
+// We want to see a distinct !dbg node.
+// CHECK-NOT: call void @llvm.dbg.declare(metadata !{i32* %{{.*}}}, metadata ![[A_MD]]), !dbg ![[A_DI]]
+// CHECK:     call void @llvm.dbg.declare(metadata !{i32* %{{.*}}}, metadata ![[A_MD]]), !dbg !{{.*}}
+// CHECK-NOT: call void @llvm.dbg.declare(metadata !{i32* %{{.*}}}, metadata ![[B_MD]]), !dbg ![[B_DI]]
+// CHECK:     call void @llvm.dbg.declare(metadata !{i32* %{{.*}}}, metadata ![[B_MD]]), !dbg !{{.*}}
+// result
+// CHECK: call void @llvm.dbg.declare
-- 
GitLab