Skip to content

Commit 966867a

Browse files
committed
[Assignment Tracking][22/*] Add loop-deletion test
The Assignment Tracking debug-info feature is outlined in this RFC: https://discourse.llvm.org/t/ rfc-assignment-tracking-a-better-way-of-specifying-variable-locations-in-ir This test covers the NFC-for-normal-debug-info change D133303. Reviewed By: jmorse Differential Revision: https://reviews.llvm.org/D133319
1 parent de034cf commit 966867a

File tree

1 file changed

+79
-0
lines changed
  • llvm/test/DebugInfo/Generic/assignment-tracking/loop-deletion

1 file changed

+79
-0
lines changed
Lines changed: 79 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,79 @@
1+
; RUN: opt %s -passes=loop-deletion -S -o - -experimental-assignment-tracking \
2+
; RUN: | FileCheck %s
3+
4+
;; $ cat test.cpp:
5+
;; void esc(int*);
6+
;; void fun() {
7+
;; int Counter = 0;
8+
;; for (; Counter < 2; Counter++) {}
9+
;; esc(&Counter);
10+
;; }
11+
;;
12+
;; IR grabbed before loop-deletion in:
13+
;; $ clang++ -O2 -g -Xclang -fexperimental-assignment-tracking
14+
;;
15+
;; for.cond is a dead loop - the debug intrinsic inside will be moved to the
16+
;; exit block (and made undef) and then the loop will be deleted. Ensure that
17+
;; the dbg.assign intrinsic doesn't get transformed into a dbg.value by
18+
;; mistake.
19+
20+
; CHECK: for.end:
21+
; CHECK-NEXT: call void @llvm.dbg.assign(metadata i32 undef,{{.+}}, metadata !DIExpression({{.+}}), metadata ![[ID:[0-9]+]], metadata ptr %Counter, metadata !DIExpression())
22+
; CHECK-NEXT: store i32 2, ptr %Counter, align 4,{{.*}}!DIAssignID ![[ID]]
23+
24+
define dso_local void @_Z3funv() local_unnamed_addr #0 !dbg !7 {
25+
entry:
26+
%Counter = alloca i32, align 4, !DIAssignID !13
27+
call void @llvm.dbg.assign(metadata i1 undef, metadata !11, metadata !DIExpression(), metadata !13, metadata ptr %Counter, metadata !DIExpression()), !dbg !14
28+
call void @llvm.dbg.assign(metadata i32 0, metadata !11, metadata !DIExpression(), metadata !16, metadata ptr %Counter, metadata !DIExpression()), !dbg !14
29+
br label %for.cond, !dbg !17
30+
31+
for.cond: ; preds = %for.cond, %entry
32+
call void @llvm.dbg.assign(metadata i32 undef, metadata !11, metadata !DIExpression(DW_OP_plus_uconst, 1, DW_OP_stack_value), metadata !16, metadata ptr %Counter, metadata !DIExpression()), !dbg !14
33+
br i1 false, label %for.cond, label %for.end, !dbg !18, !llvm.loop !20
34+
35+
for.end: ; preds = %for.cond
36+
store i32 2, ptr %Counter, align 4, !dbg !14, !DIAssignID !16
37+
call void @_Z3escPi(ptr noundef nonnull %Counter), !dbg !27
38+
ret void, !dbg !28
39+
}
40+
41+
declare void @llvm.lifetime.start.p0i8(i64 immarg, ptr nocapture)
42+
declare !dbg !29 dso_local void @_Z3escPi(ptr noundef) local_unnamed_addr
43+
declare void @llvm.lifetime.end.p0i8(i64 immarg, ptr nocapture)
44+
declare void @llvm.dbg.assign(metadata, metadata, metadata, metadata, metadata, metadata)
45+
46+
!llvm.dbg.cu = !{!0}
47+
!llvm.module.flags = !{!2, !3, !4, !5}
48+
!llvm.ident = !{!6}
49+
50+
!0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus_14, file: !1, producer: "clang version 14.0.0", isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug, splitDebugInlining: false, nameTableKind: None)
51+
!1 = !DIFile(filename: "test.cpp", directory: "/")
52+
!2 = !{i32 7, !"Dwarf Version", i32 5}
53+
!3 = !{i32 2, !"Debug Info Version", i32 3}
54+
!4 = !{i32 1, !"wchar_size", i32 4}
55+
!5 = !{i32 7, !"uwtable", i32 1}
56+
!6 = !{!"clang version 14.0.0)"}
57+
!7 = distinct !DISubprogram(name: "fun", linkageName: "_Z3funv", scope: !1, file: !1, line: 2, type: !8, scopeLine: 2, flags: DIFlagPrototyped | DIFlagAllCallsDescribed, spFlags: DISPFlagDefinition | DISPFlagOptimized, unit: !0, retainedNodes: !10)
58+
!8 = !DISubroutineType(types: !9)
59+
!9 = !{null}
60+
!10 = !{!11}
61+
!11 = !DILocalVariable(name: "Counter", scope: !7, file: !1, line: 3, type: !12)
62+
!12 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)
63+
!13 = distinct !DIAssignID()
64+
!14 = !DILocation(line: 0, scope: !7)
65+
!15 = !DILocation(line: 3, column: 3, scope: !7)
66+
!16 = distinct !DIAssignID()
67+
!17 = !DILocation(line: 4, column: 3, scope: !7)
68+
!18 = !DILocation(line: 4, column: 3, scope: !19)
69+
!19 = distinct !DILexicalBlock(scope: !7, file: !1, line: 4, column: 3)
70+
!20 = distinct !{!20, !18, !21, !22}
71+
!21 = !DILocation(line: 4, column: 35, scope: !19)
72+
!22 = !{!"llvm.loop.mustprogress"}
73+
!27 = !DILocation(line: 5, column: 3, scope: !7)
74+
!28 = !DILocation(line: 6, column: 1, scope: !7)
75+
!29 = !DISubprogram(name: "esc", linkageName: "_Z3escPi", scope: !1, file: !1, line: 1, type: !30, flags: DIFlagPrototyped, spFlags: DISPFlagOptimized, retainedNodes: !33)
76+
!30 = !DISubroutineType(types: !31)
77+
!31 = !{null, !32}
78+
!32 = !DIDerivedType(tag: DW_TAG_pointer_type, baseType: !12, size: 64)
79+
!33 = !{}

0 commit comments

Comments
 (0)