Home | History | Annotate | Download | only in DebugInfo
      1 ; REQUIRES: object-emission
      2 
      3 ; RUN: %llc_dwarf -O0 -filetype=obj < %s > %t
      4 ; RUN: llvm-dwarfdump %t | FileCheck %s
      5 ; CHECK: debug_info contents
      6 ; CHECK: [[NS1:0x[0-9a-f]*]]:{{ *}}DW_TAG_namespace
      7 ; CHECK-NEXT: DW_AT_name{{.*}} = "A"
      8 ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F1:[0-9]]])
      9 ; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x03)
     10 ; CHECK-NOT: NULL
     11 ; CHECK: [[NS2:0x[0-9a-f]*]]:{{ *}}DW_TAG_namespace
     12 ; CHECK-NEXT: DW_AT_name{{.*}} = "B"
     13 ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F2:[0-9]]])
     14 ; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x01)
     15 ; CHECK-NOT: NULL
     16 ; CHECK: [[I:0x[0-9a-f]*]]:{{ *}}DW_TAG_variable
     17 ; CHECK-NEXT: DW_AT_name{{.*}}= "i"
     18 ; CHECK-NOT: NULL
     19 ; CHECK: [[FOO:0x[0-9a-f]*]]:{{ *}}DW_TAG_structure_type
     20 ; CHECK-NEXT: DW_AT_name{{.*}}= "foo"
     21 ; CHECK-NEXT: DW_AT_declaration
     22 ; CHECK-NOT: NULL
     23 ; CHECK: [[BAR:0x[0-9a-f]*]]:{{ *}}DW_TAG_structure_type
     24 ; CHECK-NEXT: DW_AT_name{{.*}}= "bar"
     25 ; CHECK: NULL
     26 ; CHECK: [[FUNC1:.*]]: DW_TAG_subprogram
     27 ; CHECK-NOT: DW_TAG
     28 ; CHECK: DW_AT_MIPS_linkage_name
     29 ; CHECK-NOT: DW_TAG
     30 ; CHECK: DW_AT_name{{.*}}= "f1"
     31 ; CHECK: DW_TAG_subprogram
     32 ; CHECK-NOT: DW_TAG
     33 ; CHECK: DW_AT_MIPS_linkage_name
     34 ; CHECK-NOT: DW_TAG
     35 ; CHECK: DW_AT_name{{.*}}= "f1"
     36 ; CHECK: NULL
     37 
     38 ; CHECK-NOT: NULL
     39 ; CHECK: DW_TAG_imported_module
     40 ; This is a bug, it should be in F2 but it inherits the file from its
     41 ; enclosing scope
     42 ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F1]])
     43 ; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x08)
     44 ; CHECK-NEXT: DW_AT_import{{.*}}=> {[[NS2]]})
     45 ; CHECK: NULL
     46 ; CHECK-NOT: NULL
     47 
     48 ; CHECK: DW_TAG_imported_module
     49 ; Same bug as above, this should be F2, not F1
     50 ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F1]])
     51 ; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x0b)
     52 ; CHECK-NEXT: DW_AT_import{{.*}}=> {[[NS1]]})
     53 ; CHECK-NOT: NULL
     54 
     55 ; CHECK: DW_TAG_subprogram
     56 ; CHECK-NOT: DW_TAG
     57 ; CHECK: DW_AT_MIPS_linkage_name
     58 ; CHECK-NOT: DW_TAG
     59 ; CHECK: DW_AT_name{{.*}}= "func"
     60 ; CHECK-NOT: NULL
     61 ; CHECK: DW_TAG_imported_module
     62 ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F2]])
     63 ; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x12)
     64 ; CHECK-NEXT: DW_AT_import{{.*}}=> {[[NS1]]})
     65 ; CHECK-NOT: NULL
     66 ; CHECK: DW_TAG_imported_declaration
     67 ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F2]])
     68 ; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x13)
     69 ; CHECK-NEXT: DW_AT_import{{.*}}=> {[[FOO]]})
     70 ; CHECK-NOT: NULL
     71 ; CHECK: DW_TAG_imported_declaration
     72 ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F2]])
     73 ; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x14)
     74 ; CHECK-NEXT: DW_AT_import{{.*}}=> {[[BAR]]})
     75 ; CHECK-NOT: NULL
     76 ; CHECK: DW_TAG_imported_declaration
     77 ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F2]])
     78 ; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x15)
     79 ; CHECK-NEXT: DW_AT_import{{.*}}=> {[[FUNC1]]})
     80 ; CHECK-NOT: NULL
     81 ; CHECK: DW_TAG_imported_declaration
     82 ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F2]])
     83 ; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x16)
     84 ; CHECK-NEXT: DW_AT_import{{.*}}=> {[[I]]})
     85 ; CHECK-NOT: NULL
     86 ; CHECK: [[X:0x[0-9a-f]*]]:{{ *}}DW_TAG_imported_declaration
     87 ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F2]])
     88 ; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x18)
     89 ; CHECK-NEXT: DW_AT_import{{.*}}=> {[[NS1]]})
     90 ; CHECK-NEXT: DW_AT_name{{.*}}"X"
     91 ; CHECK-NOT: NULL
     92 ; CHECK: DW_TAG_imported_declaration
     93 ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F2]])
     94 ; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x19)
     95 ; CHECK-NEXT: DW_AT_import{{.*}}=> {[[X]]})
     96 ; CHECK-NEXT: DW_AT_name{{.*}}"Y"
     97 ; CHECK-NOT: NULL
     98 ; CHECK: DW_TAG_lexical_block
     99 ; CHECK-NOT: NULL
    100 ; CHECK: DW_TAG_imported_module
    101 ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F2]])
    102 ; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x0f)
    103 ; CHECK-NEXT: DW_AT_import{{.*}}=> {[[NS2]]})
    104 ; CHECK: NULL
    105 ; CHECK: NULL
    106 ; CHECK: NULL
    107 
    108 ; CHECK: file_names[  [[F1]]]{{.*}}debug-info-namespace.cpp
    109 ; CHECK: file_names[  [[F2]]]{{.*}}foo.cpp
    110 
    111 ; IR generated from clang/test/CodeGenCXX/debug-info-namespace.cpp, file paths
    112 ; changed to protect the guilty. The C++ source code is:
    113 ; namespace A {
    114 ; #line 1 "foo.cpp"
    115 ; namespace B {
    116 ; int i;
    117 ; void f1() { }
    118 ; void f1(int) { }
    119 ; struct foo;
    120 ; struct bar { };
    121 ; }
    122 ; using namespace B;
    123 ; }
    124 ;
    125 ; using namespace A;
    126 ;
    127 ; int func(bool b) {
    128 ;   if (b) {
    129 ;     using namespace A::B;
    130 ;     return i;
    131 ;   }
    132 ;   using namespace A;
    133 ;   using B::foo;
    134 ;   using B::bar;
    135 ;   using B::f1;
    136 ;   using B::i;
    137 ;   bar x;
    138 ;   namespace X = A;
    139 ;   namespace Y = X;
    140 ;   return i + X::B::i + Y::B::i;
    141 ; }
    142 
    143 %"struct.A::B::bar" = type { i8 }
    144 
    145 @_ZN1A1B1iE = global i32 0, align 4
    146 
    147 ; Function Attrs: nounwind uwtable
    148 define void @_ZN1A1B2f1Ev() #0 {
    149 entry:
    150   ret void, !dbg !41
    151 }
    152 
    153 ; Function Attrs: nounwind uwtable
    154 define void @_ZN1A1B2f1Ei(i32) #0 {
    155 entry:
    156   %.addr = alloca i32, align 4
    157   store i32 %0, i32* %.addr, align 4
    158   call void @llvm.dbg.declare(metadata !{i32* %.addr}, metadata !42), !dbg !43
    159   ret void, !dbg !43
    160 }
    161 
    162 ; Function Attrs: nounwind readnone
    163 declare void @llvm.dbg.declare(metadata, metadata) #1
    164 
    165 ; Function Attrs: nounwind uwtable
    166 define i32 @_Z4funcb(i1 zeroext %b) #0 {
    167 entry:
    168   %retval = alloca i32, align 4
    169   %b.addr = alloca i8, align 1
    170   %x = alloca %"struct.A::B::bar", align 1
    171   %frombool = zext i1 %b to i8
    172   store i8 %frombool, i8* %b.addr, align 1
    173   call void @llvm.dbg.declare(metadata !{i8* %b.addr}, metadata !44), !dbg !45
    174   %0 = load i8* %b.addr, align 1, !dbg !46
    175   %tobool = trunc i8 %0 to i1, !dbg !46
    176   br i1 %tobool, label %if.then, label %if.end, !dbg !46
    177 
    178 if.then:                                          ; preds = %entry
    179   %1 = load i32* @_ZN1A1B1iE, align 4, !dbg !47
    180   store i32 %1, i32* %retval, !dbg !47
    181   br label %return, !dbg !47
    182 
    183 if.end:                                           ; preds = %entry
    184   call void @llvm.dbg.declare(metadata !{%"struct.A::B::bar"* %x}, metadata !48), !dbg !49
    185   %2 = load i32* @_ZN1A1B1iE, align 4, !dbg !50
    186   %3 = load i32* @_ZN1A1B1iE, align 4, !dbg !50
    187   %add = add nsw i32 %2, %3, !dbg !50
    188   %4 = load i32* @_ZN1A1B1iE, align 4, !dbg !50
    189   %add1 = add nsw i32 %add, %4, !dbg !50
    190   store i32 %add1, i32* %retval, !dbg !50
    191   br label %return, !dbg !50
    192 
    193 return:                                           ; preds = %if.end, %if.then
    194   %5 = load i32* %retval, !dbg !51
    195   ret i32 %5, !dbg !51
    196 }
    197 
    198 attributes #0 = { nounwind uwtable "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "unsafe-fp-math"="false" "use-soft-float"="false" }
    199 attributes #1 = { nounwind readnone }
    200 
    201 !llvm.dbg.cu = !{!0}
    202 !llvm.module.flags = !{!52}
    203 
    204 !0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.4 ", i1 false, metadata !"", i32 0, metadata !2, metadata !2, metadata !3, metadata !19, metadata !21, metadata !""} ; [ DW_TAG_compile_unit ] [/usr/local/google/home/blaikie/dev/llvm/build/clang/debug//usr/local/google/home/blaikie/dev/llvm/src/tools/clang/test/CodeGenCXX/debug-info-namespace.cpp] [DW_LANG_C_plus_plus]
    205 !1 = metadata !{metadata !"/usr/local/google/home/blaikie/dev/llvm/src/tools/clang/test/CodeGenCXX/debug-info-namespace.cpp", metadata !"/usr/local/google/home/blaikie/dev/llvm/build/clang/debug"}
    206 !2 = metadata !{}
    207 !3 = metadata !{metadata !4, metadata !10, metadata !14}
    208 !4 = metadata !{i32 786478, metadata !5, metadata !6, metadata !"f1", metadata !"f1", metadata !"_ZN1A1B2f1Ev", i32 3, metadata !8, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, void ()* @_ZN1A1B2f1Ev, null, null, metadata !2, i32 3} ; [ DW_TAG_subprogram ] [line 3] [def] [f1]
    209 !5 = metadata !{metadata !"foo.cpp", metadata !"/usr/local/google/home/blaikie/dev/llvm/build/clang/debug"}
    210 !6 = metadata !{i32 786489, metadata !5, metadata !7, metadata !"B", i32 1} ; [ DW_TAG_namespace ] [B] [line 1]
    211 !7 = metadata !{i32 786489, metadata !1, null, metadata !"A", i32 3} ; [ DW_TAG_namespace ] [A] [line 3]
    212 !8 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !9, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]
    213 !9 = metadata !{null}
    214 !10 = metadata !{i32 786478, metadata !5, metadata !6, metadata !"f1", metadata !"f1", metadata !"_ZN1A1B2f1Ei", i32 4, metadata !11, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, void (i32)* @_ZN1A1B2f1Ei, null, null, metadata !2, i32 4} ; [ DW_TAG_subprogram ] [line 4] [def] [f1]
    215 !11 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !12, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]
    216 !12 = metadata !{null, metadata !13}
    217 !13 = 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]
    218 !14 = metadata !{i32 786478, metadata !5, metadata !15, metadata !"func", metadata !"func", metadata !"_Z4funcb", i32 13, metadata !16, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, i32 (i1)* @_Z4funcb, null, null, metadata !2, i32 13} ; [ DW_TAG_subprogram ] [line 13] [def] [func]
    219 !15 = metadata !{i32 786473, metadata !5}         ; [ DW_TAG_file_type ] [/usr/local/google/home/blaikie/dev/llvm/build/clang/debug/foo.cpp]
    220 !16 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !17, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]
    221 !17 = metadata !{metadata !13, metadata !18}
    222 !18 = metadata !{i32 786468, null, null, metadata !"bool", i32 0, i64 8, i64 8, i64 0, i32 0, i32 2} ; [ DW_TAG_base_type ] [bool] [line 0, size 8, align 8, offset 0, enc DW_ATE_boolean]
    223 !19 = metadata !{metadata !20}
    224 !20 = metadata !{i32 786484, i32 0, metadata !6, metadata !"i", metadata !"i", metadata !"_ZN1A1B1iE", metadata !15, i32 2, metadata !13, i32 0, i32 1, i32* @_ZN1A1B1iE, null} ; [ DW_TAG_variable ] [i] [line 2] [def]
    225 !21 = metadata !{metadata !22, metadata !23, metadata !24, metadata !26, metadata !27, metadata !29, metadata !37, metadata !38, metadata !39, metadata !40}
    226 !22 = metadata !{i32 786490, metadata !7, metadata !6, i32 8} ; [ DW_TAG_imported_module ]
    227 !23 = metadata !{i32 786490, metadata !0, metadata !7, i32 11} ; [ DW_TAG_imported_module ]
    228 !24 = metadata !{i32 786490, metadata !25, metadata !6, i32 15} ; [ DW_TAG_imported_module ]
    229 !25 = metadata !{i32 786443, metadata !5, metadata !14, i32 14, i32 0, i32 0} ; [ DW_TAG_lexical_block ] [/usr/local/google/home/blaikie/dev/llvm/build/clang/debug/foo.cpp]
    230 !26 = metadata !{i32 786490, metadata !14, metadata !7, i32 18} ; [ DW_TAG_imported_module ]
    231 !27 = metadata !{i32 786440, metadata !14, metadata !28, i32 19} ; [ DW_TAG_imported_declaration ]
    232 !28 = metadata !{i32 786451, metadata !5, metadata !6, metadata !"foo", i32 5, i64 0, i64 0, i32 0, i32 4, null, null, i32 0, null, null, null} ; [ DW_TAG_structure_type ] [foo] [line 5, size 0, align 0, offset 0] [decl] [from ]
    233 !29 = metadata !{i32 786440, metadata !14, metadata !30, i32 20} ; [ DW_TAG_imported_declaration ]
    234 !30 = metadata !{i32 786451, metadata !5, metadata !6, metadata !"bar", i32 6, i64 8, i64 8, i32 0, i32 0, null, metadata !31, i32 0, null, null, null} ; [ DW_TAG_structure_type ] [bar] [line 6, size 8, align 8, offset 0] [def] [from ]
    235 !31 = metadata !{metadata !32}
    236 !32 = metadata !{i32 786478, metadata !5, metadata !30, metadata !"bar", metadata !"bar", metadata !"", i32 6, metadata !33, i1 false, i1 false, i32 0, i32 0, null, i32 320, i1 false, null, null, i32 0, metadata !36, i32 6} ; [ DW_TAG_subprogram ] [line 6] [bar]
    237 !33 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !34, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]
    238 !34 = metadata !{null, metadata !35}
    239 !35 = metadata !{i32 786447, i32 0, null, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 1088, metadata !30} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [artificial] [from bar]
    240 !36 = metadata !{i32 786468}
    241 !37 = metadata !{i32 786440, metadata !14, metadata !10, i32 21} ; [ DW_TAG_imported_declaration ]
    242 !38 = metadata !{i32 786440, metadata !14, metadata !20, i32 22} ; [ DW_TAG_imported_declaration ]
    243 !39 = metadata !{i32 786440, metadata !14, metadata !7, i32 24, metadata !"X"} ; [ DW_TAG_imported_declaration ]
    244 !40 = metadata !{i32 786440, metadata !14, metadata !39, i32 25, metadata !"Y"} ; [ DW_TAG_imported_declaration ]
    245 !41 = metadata !{i32 3, i32 0, metadata !4, null}
    246 !42 = metadata !{i32 786689, metadata !10, metadata !"", metadata !15, i32 16777220, metadata !13, i32 0, i32 0} ; [ DW_TAG_arg_variable ] [line 4]
    247 !43 = metadata !{i32 4, i32 0, metadata !10, null}
    248 !44 = metadata !{i32 786689, metadata !14, metadata !"b", metadata !15, i32 16777229, metadata !18, i32 0, i32 0} ; [ DW_TAG_arg_variable ] [b] [line 13]
    249 !45 = metadata !{i32 13, i32 0, metadata !14, null}
    250 !46 = metadata !{i32 14, i32 0, metadata !14, null}
    251 !47 = metadata !{i32 16, i32 0, metadata !25, null}
    252 !48 = metadata !{i32 786688, metadata !14, metadata !"x", metadata !15, i32 23, metadata !30, i32 0, i32 0} ; [ DW_TAG_auto_variable ] [x] [line 23]
    253 !49 = metadata !{i32 23, i32 0, metadata !14, null}
    254 !50 = metadata !{i32 26, i32 0, metadata !14, null}
    255 !51 = metadata !{i32 27, i32 0, metadata !14, null}
    256 !52 = metadata !{i32 1, metadata !"Debug Info Version", i32 1}
    257