18d866c53733970018625279de174a565913b6e2
[oota-llvm.git] / test / CodeGen / ARM / 2011-08-02-MergedGlobalDbg.ll
1 ; RUN: llc -filetype=obj < %s | llvm-dwarfdump -debug-dump=info - | FileCheck %s
2
3 ; Check debug info output for merged global.
4 ; DW_AT_location
5 ; 0x03 DW_OP_addr
6 ; 0x.. .long __MergedGlobals
7 ; 0x10 DW_OP_constu
8 ; 0x.. offset
9 ; 0x22 DW_OP_plus
10
11 ; CHECK: DW_TAG_variable
12 ; CHECK-NOT: DW_TAG
13 ; CHECK:    DW_AT_name {{.*}} "x1"
14 ; CHECK-NOT: {{DW_TAG|NULL}}
15 ; CHECK:    DW_AT_location [DW_FORM_exprloc]        (<0x8> 03 [[ADDR:.. .. .. ..]] 10 00 22  )
16 ; CHECK: DW_TAG_variable
17 ; CHECK-NOT: DW_TAG
18 ; CHECK:    DW_AT_name {{.*}} "x2"
19 ; CHECK-NOT: {{DW_TAG|NULL}}
20 ; CHECK:    DW_AT_location [DW_FORM_exprloc]        (<0x8> 03 [[ADDR]] 10 04 22  )
21
22 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"
23 target triple = "thumbv7-apple-macosx10.7.0"
24
25 @x1 = internal unnamed_addr global i32 1, align 4
26 @x2 = internal unnamed_addr global i32 2, align 4
27 @x3 = internal unnamed_addr global i32 3, align 4
28 @x4 = internal unnamed_addr global i32 4, align 4
29 @x5 = global i32 0, align 4
30
31 define i32 @get1(i32 %a) nounwind optsize ssp {
32   tail call void @llvm.dbg.value(metadata i32 %a, i64 0, metadata !10, metadata !{!"0x102"}), !dbg !30
33   %1 = load i32* @x1, align 4, !dbg !31
34   tail call void @llvm.dbg.value(metadata i32 %1, i64 0, metadata !11, metadata !{!"0x102"}), !dbg !31
35   store i32 %a, i32* @x1, align 4, !dbg !31
36   ret i32 %1, !dbg !31
37 }
38
39 define i32 @get2(i32 %a) nounwind optsize ssp {
40   tail call void @llvm.dbg.value(metadata i32 %a, i64 0, metadata !13, metadata !{!"0x102"}), !dbg !32
41   %1 = load i32* @x2, align 4, !dbg !33
42   tail call void @llvm.dbg.value(metadata i32 %1, i64 0, metadata !14, metadata !{!"0x102"}), !dbg !33
43   store i32 %a, i32* @x2, align 4, !dbg !33
44   ret i32 %1, !dbg !33
45 }
46
47 define i32 @get3(i32 %a) nounwind optsize ssp {
48   tail call void @llvm.dbg.value(metadata i32 %a, i64 0, metadata !16, metadata !{!"0x102"}), !dbg !34
49   %1 = load i32* @x3, align 4, !dbg !35
50   tail call void @llvm.dbg.value(metadata i32 %1, i64 0, metadata !17, metadata !{!"0x102"}), !dbg !35
51   store i32 %a, i32* @x3, align 4, !dbg !35
52   ret i32 %1, !dbg !35
53 }
54
55 define i32 @get4(i32 %a) nounwind optsize ssp {
56   tail call void @llvm.dbg.value(metadata i32 %a, i64 0, metadata !19, metadata !{!"0x102"}), !dbg !36
57   %1 = load i32* @x4, align 4, !dbg !37
58   tail call void @llvm.dbg.value(metadata i32 %1, i64 0, metadata !20, metadata !{!"0x102"}), !dbg !37
59   store i32 %a, i32* @x4, align 4, !dbg !37
60   ret i32 %1, !dbg !37
61 }
62
63 define i32 @get5(i32 %a) nounwind optsize ssp {
64   tail call void @llvm.dbg.value(metadata i32 %a, i64 0, metadata !27, metadata !{!"0x102"}), !dbg !38
65   %1 = load i32* @x5, align 4, !dbg !39
66   tail call void @llvm.dbg.value(metadata i32 %1, i64 0, metadata !28, metadata !{!"0x102"}), !dbg !39
67   store i32 %a, i32* @x5, align 4, !dbg !39
68   ret i32 %1, !dbg !39
69 }
70
71 declare void @llvm.dbg.value(metadata, i64, metadata, metadata) nounwind readnone
72
73 !llvm.dbg.cu = !{!0}
74 !llvm.module.flags = !{!49}
75
76 !0 = !{!"0x11\0012\00clang\001\00\000\00\001", !47, !48, !48, !40, !41,  !48} ; [ DW_TAG_compile_unit ]
77 !1 = !{!"0x2e\00get1\00get1\00\005\000\001\000\006\00256\001\005", !47, !2, !3, null, i32 (i32)* @get1, null, null, !42} ; [ DW_TAG_subprogram ] [line 5] [def] [get1]
78 !2 = !{!"0x29", !47} ; [ DW_TAG_file_type ]
79 !3 = !{!"0x15\00\000\000\000\000\000\000", !47, !2, null, !4, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]
80 !4 = !{!5}
81 !5 = !{!"0x24\00int\000\0032\0032\000\000\005", null, !0} ; [ DW_TAG_base_type ]
82 !6 = !{!"0x2e\00get2\00get2\00\008\000\001\000\006\00256\001\008", !47, !2, !3, null, i32 (i32)* @get2, null, null, !43} ; [ DW_TAG_subprogram ] [line 8] [def] [get2]
83 !7 = !{!"0x2e\00get3\00get3\00\0011\000\001\000\006\00256\001\0011", !47, !2, !3, null, i32 (i32)* @get3, null, null, !44} ; [ DW_TAG_subprogram ] [line 11] [def] [get3]
84 !8 = !{!"0x2e\00get4\00get4\00\0014\000\001\000\006\00256\001\0014", !47, !2, !3, null, i32 (i32)* @get4, null, null, !45} ; [ DW_TAG_subprogram ] [line 14] [def] [get4]
85 !9 = !{!"0x2e\00get5\00get5\00\0017\000\001\000\006\00256\001\0017", !47, !2, !3, null, i32 (i32)* @get5, null, null, !46} ; [ DW_TAG_subprogram ] [line 17] [def] [get5]
86 !10 = !{!"0x101\00a\0016777221\000", !1, !2, !5} ; [ DW_TAG_arg_variable ]
87 !11 = !{!"0x100\00b\005\000", !12, !2, !5} ; [ DW_TAG_auto_variable ]
88 !12 = !{!"0xb\005\0019\000", !47, !1} ; [ DW_TAG_lexical_block ]
89 !13 = !{!"0x101\00a\0016777224\000", !6, !2, !5} ; [ DW_TAG_arg_variable ]
90 !14 = !{!"0x100\00b\008\000", !15, !2, !5} ; [ DW_TAG_auto_variable ]
91 !15 = !{!"0xb\008\0017\001", !47, !6} ; [ DW_TAG_lexical_block ]
92 !16 = !{!"0x101\00a\0016777227\000", !7, !2, !5} ; [ DW_TAG_arg_variable ]
93 !17 = !{!"0x100\00b\0011\000", !18, !2, !5} ; [ DW_TAG_auto_variable ]
94 !18 = !{!"0xb\0011\0019\002", !47, !7} ; [ DW_TAG_lexical_block ]
95 !19 = !{!"0x101\00a\0016777230\000", !8, !2, !5} ; [ DW_TAG_arg_variable ]
96 !20 = !{!"0x100\00b\0014\000", !21, !2, !5} ; [ DW_TAG_auto_variable ]
97 !21 = !{!"0xb\0014\0019\003", !47, !8} ; [ DW_TAG_lexical_block ]
98 !25 = !{!"0x34\00x1\00x1\00\004\001\001", !0, !2, !5, i32* @x1, null} ; [ DW_TAG_variable ]
99 !26 = !{!"0x34\00x2\00x2\00\007\001\001", !0, !2, !5, i32* @x2, null} ; [ DW_TAG_variable ]
100 !27 = !{!"0x101\00a\0016777233\000", !9, !2, !5} ; [ DW_TAG_arg_variable ]
101 !28 = !{!"0x100\00b\0017\000", !29, !2, !5} ; [ DW_TAG_auto_variable ]
102 !29 = !{!"0xb\0017\0019\004", !47, !9} ; [ DW_TAG_lexical_block ]
103 !30 = !{i32 5, i32 16, !1, null}
104 !31 = !{i32 5, i32 32, !12, null}
105 !32 = !{i32 8, i32 14, !6, null}
106 !33 = !{i32 8, i32 29, !15, null}
107 !34 = !{i32 11, i32 16, !7, null}
108 !35 = !{i32 11, i32 32, !18, null}
109 !36 = !{i32 14, i32 16, !8, null}
110 !37 = !{i32 14, i32 32, !21, null}
111 !38 = !{i32 17, i32 16, !9, null}
112 !39 = !{i32 17, i32 32, !29, null}
113 !40 = !{!1, !6, !7, !8, !9}
114 !41 = !{!25, !26}
115 !42 = !{!10, !11}
116 !43 = !{!13, !14}
117 !44 = !{!16, !17}
118 !45 = !{!19, !20}
119 !46 = !{!27, !28}
120 !47 = !{!"ss3.c", !"/private/tmp"}
121 !48 = !{}
122 !49 = !{i32 1, !"Debug Info Version", i32 2}