Home | History | Annotate | Download | only in NVPTX
      1 ; RUN: llc < %s -mtriple=nvptx64-nvidia-cuda | FileCheck %s
      2 
      3 ; CHECK: .target sm_20//, debug
      4 
      5 ; CHECK: .visible .func use_dbg_declare()
      6 ; CHECK: .local .align 8 .b8 __local_depot0[8];
      7 ; CHECK: mov.u64 %SPL, __local_depot0;
      8 ; CHECK: add.u64 %rd1, %SP, 0;
      9 ; CHECK: .loc 1 5 3                   // t.c:5:3
     10 ; CHECK: { // callseq 0, 0
     11 ; CHECK: .reg .b32 temp_param_reg;
     12 ; CHECK: .param .b64 param0;
     13 ; CHECK: st.param.b64 [param0+0], %rd1;
     14 ; CHECK: call.uni
     15 ; CHECK: escape_foo,
     16 ; CHECK: (
     17 ; CHECK: param0
     18 ; CHECK: );
     19 ; CHECK: } // callseq 0
     20 ; CHECK: .loc 1 6 1                   // t.c:6:1
     21 ; CHECK: ret;
     22 ; CHECK: }
     23 
     24 ; CHECK: .file 1 "test{{(/|\\\\)}}t.c"
     25 
     26 ; CHECK: // .section .debug_abbrev
     27 ; CHECK: // {
     28 ; CHECK: // .b8 1                                // Abbreviation Code
     29 ; CHECK: // .b8 17                               // DW_TAG_compile_unit
     30 ; CHECK: // .b8 1                                // DW_CHILDREN_yes
     31 ; CHECK: // .b8 37                               // DW_AT_producer
     32 ; CHECK: // .b8 8                                // DW_FORM_string
     33 ; CHECK: // .b8 19                               // DW_AT_language
     34 ; CHECK: // .b8 5                                // DW_FORM_data2
     35 ; CHECK: // .b8 3                                // DW_AT_name
     36 ; CHECK: // .b8 8                                // DW_FORM_string
     37 ; CHECK: // .b8 16                               // DW_AT_stmt_list
     38 ; CHECK: // .b8 6                                // DW_FORM_data4
     39 ; CHECK: // .b8 27                               // DW_AT_comp_dir
     40 ; CHECK: // .b8 8                                // DW_FORM_string
     41 ; CHECK: // .b8 17                               // DW_AT_low_pc
     42 ; CHECK: // .b8 1                                // DW_FORM_addr
     43 ; CHECK: // .b8 18                               // DW_AT_high_pc
     44 ; CHECK: // .b8 1                                // DW_FORM_addr
     45 ; CHECK: // .b8 0                                // EOM(1)
     46 ; CHECK: // .b8 0                                // EOM(2)
     47 ; CHECK: // .b8 2                                // Abbreviation Code
     48 ; CHECK: // .b8 46                               // DW_TAG_subprogram
     49 ; CHECK: // .b8 1                                // DW_CHILDREN_yes
     50 ; CHECK: // .b8 17                               // DW_AT_low_pc
     51 ; CHECK: // .b8 1                                // DW_FORM_addr
     52 ; CHECK: // .b8 18                               // DW_AT_high_pc
     53 ; CHECK: // .b8 1                                // DW_FORM_addr
     54 ; CHECK: // .b8 64                               // DW_AT_frame_base
     55 ; CHECK: // .b8 10                               // DW_FORM_block1
     56 ; CHECK: // .b8 3                                // DW_AT_name
     57 ; CHECK: // .b8 8                                // DW_FORM_string
     58 ; CHECK: // .b8 58                               // DW_AT_decl_file
     59 ; CHECK: // .b8 11                               // DW_FORM_data1
     60 ; CHECK: // .b8 59                               // DW_AT_decl_line
     61 ; CHECK: // .b8 11                               // DW_FORM_data1
     62 ; CHECK: // .b8 39                               // DW_AT_prototyped
     63 ; CHECK: // .b8 12                               // DW_FORM_flag
     64 ; CHECK: // .b8 63                               // DW_AT_external
     65 ; CHECK: // .b8 12                               // DW_FORM_flag
     66 ; CHECK: // .b8 0                                // EOM(1)
     67 ; CHECK: // .b8 0                                // EOM(2)
     68 ; CHECK: // .b8 3                                // Abbreviation Code
     69 ; CHECK: // .b8 52                               // DW_TAG_variable
     70 ; CHECK: // .b8 0                                // DW_CHILDREN_no
     71 ; CHECK: // .b8 2                                // DW_AT_location
     72 ; CHECK: // .b8 10                               // DW_FORM_block1
     73 ; CHECK: // .b8 3                                // DW_AT_name
     74 ; CHECK: // .b8 8                                // DW_FORM_string
     75 ; CHECK: // .b8 58                               // DW_AT_decl_file
     76 ; CHECK: // .b8 11                               // DW_FORM_data1
     77 ; CHECK: // .b8 59                               // DW_AT_decl_line
     78 ; CHECK: // .b8 11                               // DW_FORM_data1
     79 ; CHECK: // .b8 73                               // DW_AT_type
     80 ; CHECK: // .b8 19                               // DW_FORM_ref4
     81 ; CHECK: // .b8 0                                // EOM(1)
     82 ; CHECK: // .b8 0                                // EOM(2)
     83 ; CHECK: // .b8 4                                // Abbreviation Code
     84 ; CHECK: // .b8 19                               // DW_TAG_structure_type
     85 ; CHECK: // .b8 1                                // DW_CHILDREN_yes
     86 ; CHECK: // .b8 3                                // DW_AT_name
     87 ; CHECK: // .b8 8                                // DW_FORM_string
     88 ; CHECK: // .b8 11                               // DW_AT_byte_size
     89 ; CHECK: // .b8 11                               // DW_FORM_data1
     90 ; CHECK: // .b8 58                               // DW_AT_decl_file
     91 ; CHECK: // .b8 11                               // DW_FORM_data1
     92 ; CHECK: // .b8 59                               // DW_AT_decl_line
     93 ; CHECK: // .b8 11                               // DW_FORM_data1
     94 ; CHECK: // .b8 0                                // EOM(1)
     95 ; CHECK: // .b8 0                                // EOM(2)
     96 ; CHECK: // .b8 5                                // Abbreviation Code
     97 ; CHECK: // .b8 13                               // DW_TAG_member
     98 ; CHECK: // .b8 0                                // DW_CHILDREN_no
     99 ; CHECK: // .b8 3                                // DW_AT_name
    100 ; CHECK: // .b8 8                                // DW_FORM_string
    101 ; CHECK: // .b8 73                               // DW_AT_type
    102 ; CHECK: // .b8 19                               // DW_FORM_ref4
    103 ; CHECK: // .b8 58                               // DW_AT_decl_file
    104 ; CHECK: // .b8 11                               // DW_FORM_data1
    105 ; CHECK: // .b8 59                               // DW_AT_decl_line
    106 ; CHECK: // .b8 11                               // DW_FORM_data1
    107 ; CHECK: // .b8 56                               // DW_AT_data_member_location
    108 ; CHECK: // .b8 10                               // DW_FORM_block1
    109 ; CHECK: // .b8 0                                // EOM(1)
    110 ; CHECK: // .b8 0                                // EOM(2)
    111 ; CHECK: // .b8 6                                // Abbreviation Code
    112 ; CHECK: // .b8 36                               // DW_TAG_base_type
    113 ; CHECK: // .b8 0                                // DW_CHILDREN_no
    114 ; CHECK: // .b8 3                                // DW_AT_name
    115 ; CHECK: // .b8 8                                // DW_FORM_string
    116 ; CHECK: // .b8 62                               // DW_AT_encoding
    117 ; CHECK: // .b8 11                               // DW_FORM_data1
    118 ; CHECK: // .b8 11                               // DW_AT_byte_size
    119 ; CHECK: // .b8 11                               // DW_FORM_data1
    120 ; CHECK: // .b8 0                                // EOM(1)
    121 ; CHECK: // .b8 0                                // EOM(2)
    122 ; CHECK: // .b8 0                                // EOM(3)
    123 ; CHECK: // }
    124 ; CHECK: // .section .debug_info
    125 ; CHECK: // {
    126 ; CHECK: // .b32 135                             // Length of Unit
    127 ; CHECK: // .b8 2                                // DWARF version number
    128 ; CHECK: // .b8 0
    129 ; CHECK: // .b32 .debug_abbrev                   // Offset Into Abbrev. Section
    130 ; CHECK: // .b8 8                                // Address Size (in bytes)
    131 ; CHECK: // .b8 1                                // Abbrev [1] 0xb:0x80 DW_TAG_compile_unit
    132 ; CHECK: // .b8 99                               // DW_AT_producer
    133 ; CHECK: // .b8 108
    134 ; CHECK: // .b8 97
    135 ; CHECK: // .b8 110
    136 ; CHECK: // .b8 103
    137 ; CHECK: // .b8 0
    138 ; CHECK: // .b8 12                               // DW_AT_language
    139 ; CHECK: // .b8 0
    140 ; CHECK: // .b8 116                              // DW_AT_name
    141 ; CHECK: // .b8 46
    142 ; CHECK: // .b8 99
    143 ; CHECK: // .b8 0
    144 ; CHECK: // .b32 .debug_line                     // DW_AT_stmt_list
    145 ; CHECK: // .b8 116                              // DW_AT_comp_dir
    146 ; CHECK: // .b8 101
    147 ; CHECK: // .b8 115
    148 ; CHECK: // .b8 116
    149 ; CHECK: // .b8 0
    150 ; CHECK: // .b64 Lfunc_begin0                    // DW_AT_low_pc
    151 ; CHECK: // .b64 Lfunc_end0                      // DW_AT_high_pc
    152 ; CHECK: // .b8 2                                // Abbrev [2] 0x31:0x3d DW_TAG_subprogram
    153 ; CHECK: // .b64 Lfunc_begin0                    // DW_AT_low_pc
    154 ; CHECK: // .b64 Lfunc_end0                      // DW_AT_high_pc
    155 ; CHECK: // .b8 1                                // DW_AT_frame_base
    156 ; CHECK: // .b8 156
    157 ; CHECK: // .b8 117                              // DW_AT_name
    158 ; CHECK: // .b8 115
    159 ; CHECK: // .b8 101
    160 ; CHECK: // .b8 95
    161 ; CHECK: // .b8 100
    162 ; CHECK: // .b8 98
    163 ; CHECK: // .b8 103
    164 ; CHECK: // .b8 95
    165 ; CHECK: // .b8 100
    166 ; CHECK: // .b8 101
    167 ; CHECK: // .b8 99
    168 ; CHECK: // .b8 108
    169 ; CHECK: // .b8 97
    170 ; CHECK: // .b8 114
    171 ; CHECK: // .b8 101
    172 ; CHECK: // .b8 0
    173 ; CHECK: // .b8 1                                // DW_AT_decl_file
    174 ; CHECK: // .b8 3                                // DW_AT_decl_line
    175 ; CHECK: // .b8 1                                // DW_AT_prototyped
    176 ; CHECK: // .b8 1                                // DW_AT_external
    177 ; CHECK: // .b8 3                                // Abbrev [3] 0x58:0x15 DW_TAG_variable
    178 ; CHECK: // .b8 11                               // DW_AT_location
    179 ; CHECK: // .b8 3
    180 ; CHECK: // .b64 __local_depot0
    181 ; CHECK: // .b8 35
    182 ; CHECK: // .b8 0
    183 ; CHECK: // .b8 111                              // DW_AT_name
    184 ; CHECK: // .b8 0
    185 ; CHECK: // .b8 1                                // DW_AT_decl_file
    186 ; CHECK: // .b8 4                                // DW_AT_decl_line
    187 ; CHECK: // .b32 110                             // DW_AT_type
    188 ; CHECK: // .b8 0                                // End Of Children Mark
    189 ; CHECK: // .b8 4                                // Abbrev [4] 0x6e:0x15 DW_TAG_structure_type
    190 ; CHECK: // .b8 70                               // DW_AT_name
    191 ; CHECK: // .b8 111
    192 ; CHECK: // .b8 111
    193 ; CHECK: // .b8 0
    194 ; CHECK: // .b8 4                                // DW_AT_byte_size
    195 ; CHECK: // .b8 1                                // DW_AT_decl_file
    196 ; CHECK: // .b8 1                                // DW_AT_decl_line
    197 ; CHECK: // .b8 5                                // Abbrev [5] 0x76:0xc DW_TAG_member
    198 ; CHECK: // .b8 120                              // DW_AT_name
    199 ; CHECK: // .b8 0
    200 ; CHECK: // .b32 131                             // DW_AT_type
    201 ; CHECK: // .b8 1                                // DW_AT_decl_file
    202 ; CHECK: // .b8 1                                // DW_AT_decl_line
    203 ; CHECK: // .b8 2                                // DW_AT_data_member_location
    204 ; CHECK: // .b8 35
    205 ; CHECK: // .b8 0
    206 ; CHECK: // .b8 0                                // End Of Children Mark
    207 ; CHECK: // .b8 6                                // Abbrev [6] 0x83:0x7 DW_TAG_base_type
    208 ; CHECK: // .b8 105                              // DW_AT_name
    209 ; CHECK: // .b8 110
    210 ; CHECK: // .b8 116
    211 ; CHECK: // .b8 0
    212 ; CHECK: // .b8 5                                // DW_AT_encoding
    213 ; CHECK: // .b8 4                                // DW_AT_byte_size
    214 ; CHECK: // .b8 0                                // End Of Children Mark
    215 ; CHECK: // }
    216 
    217 %struct.Foo = type { i32 }
    218 
    219 ; Function Attrs: noinline nounwind uwtable
    220 define void @use_dbg_declare() #0 !dbg !7 {
    221 entry:
    222   %o = alloca %struct.Foo, align 4
    223   call void @llvm.dbg.declare(metadata %struct.Foo* %o, metadata !10, metadata !15), !dbg !16
    224   call void @escape_foo(%struct.Foo* %o), !dbg !17
    225   ret void, !dbg !18
    226 }
    227 
    228 ; Function Attrs: nounwind readnone speculatable
    229 declare void @llvm.dbg.declare(metadata, metadata, metadata) #1
    230 
    231 declare void @escape_foo(%struct.Foo*)
    232 
    233 attributes #0 = { noinline nounwind uwtable }
    234 attributes #1 = { nounwind readnone speculatable }
    235 
    236 !llvm.dbg.cu = !{!0}
    237 !llvm.module.flags = !{!3, !4, !5}
    238 !llvm.ident = !{!6}
    239 
    240 !0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1, producer: "clang", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !2)
    241 !1 = !DIFile(filename: "t.c", directory: "test")
    242 !2 = !{}
    243 !3 = !{i32 2, !"Dwarf Version", i32 2}
    244 !4 = !{i32 2, !"Debug Info Version", i32 3}
    245 !5 = !{i32 1, !"wchar_size", i32 4}
    246 !6 = !{!"clang"}
    247 !7 = distinct !DISubprogram(name: "use_dbg_declare", scope: !1, file: !1, line: 3, type: !8, isLocal: false, isDefinition: true, scopeLine: 3, flags: DIFlagPrototyped, isOptimized: false, unit: !0, retainedNodes: !2)
    248 !8 = !DISubroutineType(types: !9)
    249 !9 = !{null}
    250 !10 = !DILocalVariable(name: "o", scope: !7, file: !1, line: 4, type: !11)
    251 !11 = distinct !DICompositeType(tag: DW_TAG_structure_type, name: "Foo", file: !1, line: 1, size: 32, elements: !12)
    252 !12 = !{!13}
    253 !13 = !DIDerivedType(tag: DW_TAG_member, name: "x", scope: !11, file: !1, line: 1, baseType: !14, size: 32)
    254 !14 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)
    255 !15 = !DIExpression()
    256 !16 = !DILocation(line: 4, column: 14, scope: !7)
    257 !17 = !DILocation(line: 5, column: 3, scope: !7)
    258 !18 = !DILocation(line: 6, column: 1, scope: !7)
    259