annotate test/CodeGen/ARM/2011-08-02-MergedGlobalDbg.ll @ 128:c347d3398279 default tip

fix
author mir3636
date Wed, 06 Dec 2017 14:37:17 +0900
parents 803732b1fca8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
1 ; RUN: llc -arm-global-merge -global-merge-group-by-use=false -filetype=obj < %s | llvm-dwarfdump -debug-info -v - | FileCheck %s
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2
77
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
3 ; CHECK: DW_TAG_variable
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
4 ; CHECK-NOT: DW_TAG
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
5 ; CHECK: DW_AT_name {{.*}} "x1"
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
6 ; CHECK-NOT: {{DW_TAG|NULL}}
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
7 ; CHECK: DW_AT_location [DW_FORM_exprloc] (DW_OP_addr [[ADDR:0x[0-9a-fA-F]+]])
77
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
8 ; CHECK: DW_TAG_variable
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
9 ; CHECK-NOT: DW_TAG
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
10 ; CHECK: DW_AT_name {{.*}} "x2"
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
11 ; CHECK-NOT: {{DW_TAG|NULL}}
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
12 ; CHECK: DW_AT_location [DW_FORM_exprloc] (DW_OP_addr [[ADDR]], DW_OP_plus_uconst 0x4)
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
13
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
14 source_filename = "test/CodeGen/ARM/2011-08-02-MergedGlobalDbg.ll"
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 target datalayout = "e-p:32:32:32-i1:8:32-i8:8:32-i16:16:32-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:32:64-v128:32:128-a0:0:32-n32"
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 target triple = "thumbv7-apple-macosx10.7.0"
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
17
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
18 @x1 = internal unnamed_addr global i32 1, align 4, !dbg !0
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
19 @x2 = internal unnamed_addr global i32 2, align 4, !dbg !6
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
20 @x3 = internal unnamed_addr global i32 3, align 4
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 @x4 = internal unnamed_addr global i32 4, align 4
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 @x5 = global i32 0, align 4
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
23
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
24 ; Function Attrs: nounwind optsize ssp
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
25 define i32 @get1(i32 %a) #0 !dbg !10 {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
26 tail call void @llvm.dbg.value(metadata i32 %a, metadata !14, metadata !17), !dbg !18
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
27 %1 = load i32, i32* @x1, align 4, !dbg !19
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
28 tail call void @llvm.dbg.value(metadata i32 %1, metadata !15, metadata !17), !dbg !19
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
29 store i32 %a, i32* @x1, align 4, !dbg !19
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
30 ret i32 %1, !dbg !19
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
32
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
33 ; Function Attrs: nounwind optsize ssp
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
34
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
35 define i32 @get2(i32 %a) #0 !dbg !20 {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
36 tail call void @llvm.dbg.value(metadata i32 %a, metadata !22, metadata !17), !dbg !25
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
37 %1 = load i32, i32* @x2, align 4, !dbg !26
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
38 tail call void @llvm.dbg.value(metadata i32 %1, metadata !23, metadata !17), !dbg !26
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
39 store i32 %a, i32* @x2, align 4, !dbg !26
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
40 ret i32 %1, !dbg !26
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
41 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
42
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
43 ; Function Attrs: nounwind optsize ssp
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
44
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
45 define i32 @get3(i32 %a) #0 !dbg !27 {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
46 tail call void @llvm.dbg.value(metadata i32 %a, metadata !29, metadata !17), !dbg !32
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
47 %1 = load i32, i32* @x3, align 4, !dbg !33
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
48 tail call void @llvm.dbg.value(metadata i32 %1, metadata !30, metadata !17), !dbg !33
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
49 store i32 %a, i32* @x3, align 4, !dbg !33
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 ret i32 %1, !dbg !33
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
52
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
53 ; Function Attrs: nounwind optsize ssp
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
54
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
55 define i32 @get4(i32 %a) #0 !dbg !34 {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
56 tail call void @llvm.dbg.value(metadata i32 %a, metadata !36, metadata !17), !dbg !39
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
57 %1 = load i32, i32* @x4, align 4, !dbg !40
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
58 tail call void @llvm.dbg.value(metadata i32 %1, metadata !37, metadata !17), !dbg !40
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
59 store i32 %a, i32* @x4, align 4, !dbg !40
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
60 ret i32 %1, !dbg !40
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
62
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
63 ; Function Attrs: nounwind optsize ssp
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
65 define i32 @get5(i32 %a) #0 !dbg !41 {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
66 tail call void @llvm.dbg.value(metadata i32 %a, metadata !43, metadata !17), !dbg !46
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
67 %1 = load i32, i32* @x5, align 4, !dbg !47
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
68 tail call void @llvm.dbg.value(metadata i32 %1, metadata !44, metadata !17), !dbg !47
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
69 store i32 %a, i32* @x5, align 4, !dbg !47
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
70 ret i32 %1, !dbg !47
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
71 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
72
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
73 ; Function Attrs: nounwind readnone
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
74
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
75 declare void @llvm.dbg.value(metadata, metadata, metadata) #1
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
76
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
77 attributes #0 = { nounwind optsize ssp }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
78 attributes #1 = { nounwind readnone }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
79
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
80 !llvm.dbg.cu = !{!2}
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
81 !llvm.module.flags = !{!9}
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
82
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
83 !0 = !DIGlobalVariableExpression(var: !1, expr: !DIExpression())
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
84 !1 = !DIGlobalVariable(name: "x1", scope: !2, file: !3, line: 4, type: !8, isLocal: true, isDefinition: true)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
85 !2 = distinct !DICompileUnit(language: DW_LANG_C99, file: !3, producer: "clang", isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug, enums: !4, retainedTypes: !4, globals: !5, imports: !4)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
86 !3 = !DIFile(filename: "ss3.c", directory: "/private/tmp")
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
87 !4 = !{}
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
88 !5 = !{!0, !6}
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
89 !6 = !DIGlobalVariableExpression(var: !7, expr: !DIExpression())
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
90 !7 = !DIGlobalVariable(name: "x2", scope: !2, file: !3, line: 7, type: !8, isLocal: true, isDefinition: true)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
91 !8 = !DIBasicType(name: "int", size: 32, align: 32, encoding: DW_ATE_signed)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
92 !9 = !{i32 1, !"Debug Info Version", i32 3}
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
93 !10 = distinct !DISubprogram(name: "get1", scope: !3, file: !3, line: 5, type: !11, isLocal: false, isDefinition: true, scopeLine: 5, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: true, unit: !2, variables: !13)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
94 !11 = !DISubroutineType(types: !12)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
95 !12 = !{!8}
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
96 !13 = !{!14, !15}
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
97 !14 = !DILocalVariable(name: "a", arg: 1, scope: !10, file: !3, line: 5, type: !8)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
98 !15 = !DILocalVariable(name: "b", scope: !16, file: !3, line: 5, type: !8)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
99 !16 = distinct !DILexicalBlock(scope: !10, file: !3, line: 5, column: 19)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
100 !17 = !DIExpression()
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
101 !18 = !DILocation(line: 5, column: 16, scope: !10)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
102 !19 = !DILocation(line: 5, column: 32, scope: !16)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
103 !20 = distinct !DISubprogram(name: "get2", scope: !3, file: !3, line: 8, type: !11, isLocal: false, isDefinition: true, scopeLine: 8, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: true, unit: !2, variables: !21)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
104 !21 = !{!22, !23}
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
105 !22 = !DILocalVariable(name: "a", arg: 1, scope: !20, file: !3, line: 8, type: !8)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
106 !23 = !DILocalVariable(name: "b", scope: !24, file: !3, line: 8, type: !8)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
107 !24 = distinct !DILexicalBlock(scope: !20, file: !3, line: 8, column: 17)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
108 !25 = !DILocation(line: 8, column: 14, scope: !20)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
109 !26 = !DILocation(line: 8, column: 29, scope: !24)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
110 !27 = distinct !DISubprogram(name: "get3", scope: !3, file: !3, line: 11, type: !11, isLocal: false, isDefinition: true, scopeLine: 11, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: true, unit: !2, variables: !28)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
111 !28 = !{!29, !30}
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
112 !29 = !DILocalVariable(name: "a", arg: 1, scope: !27, file: !3, line: 11, type: !8)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
113 !30 = !DILocalVariable(name: "b", scope: !31, file: !3, line: 11, type: !8)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
114 !31 = distinct !DILexicalBlock(scope: !27, file: !3, line: 11, column: 19)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
115 !32 = !DILocation(line: 11, column: 16, scope: !27)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
116 !33 = !DILocation(line: 11, column: 32, scope: !31)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
117 !34 = distinct !DISubprogram(name: "get4", scope: !3, file: !3, line: 14, type: !11, isLocal: false, isDefinition: true, scopeLine: 14, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: true, unit: !2, variables: !35)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
118 !35 = !{!36, !37}
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
119 !36 = !DILocalVariable(name: "a", arg: 1, scope: !34, file: !3, line: 14, type: !8)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
120 !37 = !DILocalVariable(name: "b", scope: !38, file: !3, line: 14, type: !8)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
121 !38 = distinct !DILexicalBlock(scope: !34, file: !3, line: 14, column: 19)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
122 !39 = !DILocation(line: 14, column: 16, scope: !34)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
123 !40 = !DILocation(line: 14, column: 32, scope: !38)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
124 !41 = distinct !DISubprogram(name: "get5", scope: !3, file: !3, line: 17, type: !11, isLocal: false, isDefinition: true, scopeLine: 17, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: true, unit: !2, variables: !42)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
125 !42 = !{!43, !44}
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
126 !43 = !DILocalVariable(name: "a", arg: 1, scope: !41, file: !3, line: 17, type: !8)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
127 !44 = !DILocalVariable(name: "b", scope: !45, file: !3, line: 17, type: !8)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
128 !45 = distinct !DILexicalBlock(scope: !41, file: !3, line: 17, column: 19)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
129 !46 = !DILocation(line: 17, column: 16, scope: !41)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
130 !47 = !DILocation(line: 17, column: 32, scope: !45)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
131