blob: baba0cdb315a066a158aef003b1f1a7efd880399 [file] [log] [blame]
Adrian Prantl75ce62a2014-04-01 21:04:18 +00001; RUN: llc -O1 -filetype=obj -o - %s | llvm-dwarfdump -debug-dump=all - | FileCheck %s
2; Generated with -O1 from:
3; int f1();
4; void f2(int*);
5; int f3(int);
6;
7; int foo() {
8; int i = 3;
9; f3(i);
10; i = 7;
11; i = f1();
12; f2(&i);
13; return 0;
14; }
15;
16; Test that we generate valid debug info for optimized code,
Alp Toker16f98b22014-04-09 14:47:27 +000017; particularly variables that are described as constants and passed
Adrian Prantl75ce62a2014-04-01 21:04:18 +000018; by reference.
19; rdar://problem/14874886
20;
21; CHECK: .debug_info contents:
22; CHECK: DW_TAG_variable
23; CHECK-NEXT: DW_AT_name{{.*}}"i"
24; CHECK-NOT: DW_TAG
25; CHECK: DW_AT_location [DW_FORM_data4] ([[LOC:.*]])
26; CHECK: .debug_loc contents:
27; CHECK: [[LOC]]:
Adrian Prantl3bdcb522014-04-11 17:49:47 +000028; consts 0x00000003
Adrian Prantl75ce62a2014-04-01 21:04:18 +000029; CHECK: Beginning address offset: 0x0000000000000{{.*}}
30; CHECK: Ending address offset: [[C1:.*]]
Adrian Prantl3bdcb522014-04-11 17:49:47 +000031; CHECK: Location description: 11 03
32; consts 0x00000007
Adrian Prantl75ce62a2014-04-01 21:04:18 +000033; CHECK: Beginning address offset: [[C1]]
34; CHECK: Ending address offset: [[C2:.*]]
Adrian Prantl3bdcb522014-04-11 17:49:47 +000035; CHECK: Location description: 11 07
Adrian Prantl75ce62a2014-04-01 21:04:18 +000036; rax, piece 0x00000004
37; CHECK: Beginning address offset: [[C2]]
38; CHECK: Ending address offset: [[R1:.*]]
39; CHECK: Location description: 50 93 04
Adrian Prantl32da8892014-04-25 20:49:25 +000040; rdi+0
41; CHECK: Beginning address offset: [[R1]]
42; CHECK: Ending address offset: [[R2:.*]]
43; CHECK: Location description: 75 00
Adrian Prantl75ce62a2014-04-01 21:04:18 +000044;
45target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
46target triple = "x86_64-apple-macosx10.9.0"
47
48; Function Attrs: nounwind ssp uwtable
49define i32 @foo() #0 {
50entry:
51 %i = alloca i32, align 4
52 call void @llvm.dbg.value(metadata !14, i64 0, metadata !10), !dbg !15
53 %call = call i32 @f3(i32 3) #3, !dbg !16
54 call void @llvm.dbg.value(metadata !17, i64 0, metadata !10), !dbg !18
55 %call1 = call i32 (...)* @f1() #3, !dbg !19
56 call void @llvm.dbg.value(metadata !{i32 %call1}, i64 0, metadata !10), !dbg !19
57 store i32 %call1, i32* %i, align 4, !dbg !19, !tbaa !20
Adrian Prantl32da8892014-04-25 20:49:25 +000058 call void @llvm.dbg.value(metadata !{i32* %i}, i64 0, metadata !10), !dbg !24
Adrian Prantl75ce62a2014-04-01 21:04:18 +000059 call void @f2(i32* %i) #3, !dbg !24
60 ret i32 0, !dbg !25
61}
62
63declare i32 @f3(i32)
64
65declare i32 @f1(...)
66
67declare void @f2(i32*)
68
69; Function Attrs: nounwind readnone
70declare void @llvm.dbg.value(metadata, i64, metadata) #2
71
72attributes #0 = { nounwind ssp uwtable }
73attributes #2 = { nounwind readnone }
74attributes #3 = { nounwind }
75
76!llvm.dbg.cu = !{!0}
77!llvm.module.flags = !{!11, !12}
78!llvm.ident = !{!13}
79
80!0 = metadata !{i32 786449, metadata !1, i32 12, metadata !"clang version 3.5.0 ", i1 true, metadata !"", i32 0, metadata !2, metadata !2, metadata !3, metadata !2, metadata !2, metadata !"", i32 1} ; [ DW_TAG_compile_unit ] [dbg-value-const-byref.c] [DW_LANG_C99]
81!1 = metadata !{metadata !"dbg-value-const-byref.c", metadata !""}
82!2 = metadata !{}
83!3 = metadata !{metadata !4}
84!4 = metadata !{i32 786478, metadata !1, metadata !5, metadata !"foo", metadata !"foo", metadata !"", i32 5, metadata !6, i1 false, i1 true, i32 0, i32 0, null, i32 0, i1 true, i32 ()* @foo, null, null, metadata !9, i32 5} ; [ DW_TAG_subprogram ] [line 5] [def] [foo]
85!5 = metadata !{i32 786473, metadata !1} ; [ DW_TAG_file_type ] [dbg-value-const-byref.c]
86!6 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !7, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]
87!7 = metadata !{metadata !8}
88!8 = metadata !{i32 786468, null, null, metadata !"int", i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ] [int] [line 0, size 32, align 32, offset 0, enc DW_ATE_signed]
89!9 = metadata !{metadata !10}
90!10 = metadata !{i32 786688, metadata !4, metadata !"i", metadata !5, i32 6, metadata !8, i32 0, i32 0} ; [ DW_TAG_auto_variable ] [i] [line 6]
91!11 = metadata !{i32 2, metadata !"Dwarf Version", i32 2}
92!12 = metadata !{i32 1, metadata !"Debug Info Version", i32 1}
93!13 = metadata !{metadata !"clang version 3.5.0 "}
94!14 = metadata !{i32 3}
95!15 = metadata !{i32 6, i32 0, metadata !4, null}
96!16 = metadata !{i32 7, i32 0, metadata !4, null}
97!17 = metadata !{i32 7}
98!18 = metadata !{i32 8, i32 0, metadata !4, null} ; [ DW_TAG_imported_declaration ]
99!19 = metadata !{i32 9, i32 0, metadata !4, null}
100!20 = metadata !{metadata !21, metadata !21, i64 0}
101!21 = metadata !{metadata !"int", metadata !22, i64 0}
102!22 = metadata !{metadata !"omnipotent char", metadata !23, i64 0}
103!23 = metadata !{metadata !"Simple C/C++ TBAA"}
104!24 = metadata !{i32 10, i32 0, metadata !4, null}
105!25 = metadata !{i32 11, i32 0, metadata !4, null}