annotate llvm/test/Transforms/GVN/dbg-redundant-load.ll @ 150:1d019706d866

LLVM10
author anatofuz
date Thu, 13 Feb 2020 15:10:13 +0900
parents
children 1f2b6ac9f198
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 ; RUN: opt -gvn -S < %s | FileCheck %s
anatofuz
parents:
diff changeset
2
anatofuz
parents:
diff changeset
3 ; Check that the redundant load from %if.then is removed.
anatofuz
parents:
diff changeset
4 ; Also, check that the debug location associated to load %0 still refers to
anatofuz
parents:
diff changeset
5 ; line 3 and not line 6.
anatofuz
parents:
diff changeset
6
anatofuz
parents:
diff changeset
7 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 ; CHECK: @test_redundant_load(
anatofuz
parents:
diff changeset
10 ; CHECK-LABEL: entry:
anatofuz
parents:
diff changeset
11 ; CHECK-NEXT: load i32, i32* %Y, align 4, !dbg ![[LOC:[0-9]+]]
anatofuz
parents:
diff changeset
12 ; CHECK-LABEL: if.then:
anatofuz
parents:
diff changeset
13 ; CHECK-NOT: load
anatofuz
parents:
diff changeset
14 ; CHECK-LABEL: if.end:
anatofuz
parents:
diff changeset
15 ; CHECK: ![[LOC]] = !DILocation(line: 3, scope: !{{.*}})
anatofuz
parents:
diff changeset
16
anatofuz
parents:
diff changeset
17 define i32 @test_redundant_load(i32 %X, i32* %Y) !dbg !6 {
anatofuz
parents:
diff changeset
18 entry:
anatofuz
parents:
diff changeset
19 %0 = load i32, i32* %Y, align 4, !dbg !8
anatofuz
parents:
diff changeset
20 %cmp = icmp sgt i32 %X, -1, !dbg !9
anatofuz
parents:
diff changeset
21 br i1 %cmp, label %if.then, label %if.end, !dbg !9
anatofuz
parents:
diff changeset
22
anatofuz
parents:
diff changeset
23 if.then: ; preds = %entry
anatofuz
parents:
diff changeset
24 %1 = load i32, i32* %Y, align 4, !dbg !10
anatofuz
parents:
diff changeset
25 %add = add nsw i32 %0, %1, !dbg !10
anatofuz
parents:
diff changeset
26 call void @foo(), !dbg !11
anatofuz
parents:
diff changeset
27 br label %if.end, !dbg !12
anatofuz
parents:
diff changeset
28
anatofuz
parents:
diff changeset
29 if.end: ; preds = %if.then, %entry
anatofuz
parents:
diff changeset
30 %Result.0 = phi i32 [ %add, %if.then ], [ %0, %entry ]
anatofuz
parents:
diff changeset
31 ret i32 %Result.0, !dbg !13
anatofuz
parents:
diff changeset
32 }
anatofuz
parents:
diff changeset
33
anatofuz
parents:
diff changeset
34 declare void @foo()
anatofuz
parents:
diff changeset
35
anatofuz
parents:
diff changeset
36 !llvm.dbg.cu = !{!0}
anatofuz
parents:
diff changeset
37 !llvm.module.flags = !{!3, !4, !5}
anatofuz
parents:
diff changeset
38
anatofuz
parents:
diff changeset
39 !0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus, file: !1, isOptimized: false, runtimeVersion: 0, emissionKind: LineTablesOnly, enums: !2)
anatofuz
parents:
diff changeset
40 !1 = !DIFile(filename: "test.cpp", directory: "")
anatofuz
parents:
diff changeset
41 !2 = !{}
anatofuz
parents:
diff changeset
42 !3 = !{i32 2, !"Dwarf Version", i32 4}
anatofuz
parents:
diff changeset
43 !4 = !{i32 2, !"Debug Info Version", i32 3}
anatofuz
parents:
diff changeset
44 !5 = !{i32 1, !"PIC Level", i32 2}
anatofuz
parents:
diff changeset
45 !6 = distinct !DISubprogram(name: "test_redundant_load", scope: !1, file: !1, line: 2, type: !7, isLocal: false, isDefinition: true, scopeLine: 2, flags: DIFlagPrototyped, isOptimized: false, unit: !0, retainedNodes: !2)
anatofuz
parents:
diff changeset
46 !7 = !DISubroutineType(types: !2)
anatofuz
parents:
diff changeset
47 !8 = !DILocation(line: 3, scope: !6)
anatofuz
parents:
diff changeset
48 !9 = !DILocation(line: 5, scope: !6)
anatofuz
parents:
diff changeset
49 !10 = !DILocation(line: 6, scope: !6)
anatofuz
parents:
diff changeset
50 !11 = !DILocation(line: 7, scope: !6)
anatofuz
parents:
diff changeset
51 !12 = !DILocation(line: 8, scope: !6)
anatofuz
parents:
diff changeset
52 !13 = !DILocation(line: 10, scope: !6)