Home | History | Annotate | Download | only in NVPTX
      1 ; RUN: llc < %s -mtriple=nvptx64-nvidia-cuda | FileCheck %s
      2 
      3 ; // Bitcode int this test case is reduced version of compiled code below:
      4 ;extern "C" {
      5 ;#line 1 "/source/dir/foo.h"
      6 ;__device__ void foo() {}
      7 ;#line 2 "/source/dir/bar.cu"
      8 ;__device__ void bar() {}
      9 ;}
     10 
     11 ; CHECK: .target sm_{{[0-9]+}}//, debug
     12 
     13 ; CHECK: .visible .func foo()
     14 ; CHECK: .loc [[FOO:[0-9]+]] 1 31
     15 ; CHECK:  ret;
     16 ; CHECK: .visible .func bar()
     17 ; CHECK: .loc [[BAR:[0-9]+]] 2 31
     18 ; CHECK:  ret;
     19 
     20 define void @foo() !dbg !4 {
     21 bb:
     22   ret void, !dbg !10
     23 }
     24 
     25 define void @bar() !dbg !7 {
     26 bb:
     27   ret void, !dbg !11
     28 }
     29 
     30 ; CHECK-DAG: .file [[FOO]] "{{.*}}foo.h"
     31 ; CHECK-DAG: .file [[BAR]] "{{.*}}bar.cu"
     32 ; CHECK: // .section .debug_abbrev
     33 ; CHECK: // {
     34 ; CHECK: // .b8 1                                // Abbreviation Code
     35 ; CHECK: // .b8 17                               // DW_TAG_compile_unit
     36 ; CHECK: // .b8 0                                // DW_CHILDREN_no
     37 ; CHECK: // .b8 37                               // DW_AT_producer
     38 ; CHECK: // .b8 8                                // DW_FORM_string
     39 ; CHECK: // .b8 19                               // DW_AT_language
     40 ; CHECK: // .b8 5                                // DW_FORM_data2
     41 ; CHECK: // .b8 3                                // DW_AT_name
     42 ; CHECK: // .b8 8                                // DW_FORM_string
     43 ; CHECK: // .b8 16                               // DW_AT_stmt_list
     44 ; CHECK: // .b8 6                                // DW_FORM_data4
     45 ; CHECK: // .b8 27                               // DW_AT_comp_dir
     46 ; CHECK: // .b8 8                                // DW_FORM_string
     47 ; CHECK: // .b8 17                               // DW_AT_low_pc
     48 ; CHECK: // .b8 1                                // DW_FORM_addr
     49 ; CHECK: // .b8 18                               // DW_AT_high_pc
     50 ; CHECK: // .b8 1                                // DW_FORM_addr
     51 ; CHECK: // .b8 0                                // EOM(1)
     52 ; CHECK: // .b8 0                                // EOM(2)
     53 ; CHECK: // .b8 0                                // EOM(3)
     54 ; CHECK: // }
     55 ; CHECK: // .section .debug_info
     56 ; CHECK: // {
     57 ; CHECK: // .b32 50                              // Length of Unit
     58 ; CHECK: // .b8 2                                // DWARF version number
     59 ; CHECK: // .b8 0
     60 ; CHECK: // .b32 .debug_abbrev                   // Offset Into Abbrev. Section
     61 ; CHECK: // .b8 8                                // Address Size (in bytes)
     62 ; CHECK: // .b8 1                                // Abbrev [1] 0xb:0x2b DW_TAG_compile_unit
     63 ; CHECK: // .b8 0                                // DW_AT_producer
     64 ; CHECK: // .b8 4                                // DW_AT_language
     65 ; CHECK: // .b8 0
     66 ; CHECK: // .b8 98                               // DW_AT_name
     67 ; CHECK: // .b8 97
     68 ; CHECK: // .b8 114
     69 ; CHECK: // .b8 46
     70 ; CHECK: // .b8 99
     71 ; CHECK: // .b8 117
     72 ; CHECK: // .b8 0
     73 ; CHECK: // .b32 .debug_line                     // DW_AT_stmt_list
     74 ; CHECK: // .b8 47                               // DW_AT_comp_dir
     75 ; CHECK: // .b8 115
     76 ; CHECK: // .b8 111
     77 ; CHECK: // .b8 117
     78 ; CHECK: // .b8 114
     79 ; CHECK: // .b8 99
     80 ; CHECK: // .b8 101
     81 ; CHECK: // .b8 47
     82 ; CHECK: // .b8 100
     83 ; CHECK: // .b8 105
     84 ; CHECK: // .b8 114
     85 ; CHECK: // .b8 0
     86 ; CHECK: // .b64 Lfunc_begin0                    // DW_AT_low_pc
     87 ; CHECK: // .b64 Lfunc_end1                      // DW_AT_high_pc
     88 ; CHECK: // }
     89 ; CHECK: // .section .debug_macinfo
     90 ; CHECK: // {
     91 ; CHECK: // .b8 0                                // End Of Macro List Mark
     92 ; CHECK: // }
     93 
     94 !llvm.dbg.cu = !{!0}
     95 !llvm.module.flags = !{!8, !9}
     96 
     97 !0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus, file: !1, producer: "", isOptimized: false, runtimeVersion: 0, emissionKind: LineTablesOnly, enums: !2)
     98 !1 = !DIFile(filename: "bar.cu", directory: "/source/dir")
     99 !2 = !{}
    100 !4 = distinct !DISubprogram(name: "foo", scope: !5, file: !5, line: 1, type: !6, isLocal: false, isDefinition: true, scopeLine: 1, flags: DIFlagPrototyped, isOptimized: false, unit: !0, retainedNodes: !2)
    101 !5 = !DIFile(filename: "foo.h", directory: "/source/dir")
    102 !6 = !DISubroutineType(types: !2)
    103 !7 = distinct !DISubprogram(name: "bar", scope: !1, file: !1, line: 2, type: !6, isLocal: false, isDefinition: true, scopeLine: 2, flags: DIFlagPrototyped, isOptimized: false, unit: !0, retainedNodes: !2)
    104 !8 = !{i32 2, !"Dwarf Version", i32 2}
    105 !9 = !{i32 2, !"Debug Info Version", i32 3}
    106 !10 = !DILocation(line: 1, column: 31, scope: !4)
    107 !11 = !DILocation(line: 2, column: 31, scope: !7)
    108