Follow up to d0858bffa11, add missing REQUIRES x86
[llvm-project.git] / llvm / test / tools / dxil-dis / debug-info.ll
blob92dc65481e825fda8752388c9fe8db8ab0a48992
1 ; RUN: llc --filetype=obj %s -o - | dxil-dis -o - | FileCheck %s
2 target triple = "dxil-unknown-shadermodel6.7-library"
3 target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
5 ; CHECK: define float @fma(float, float, float) unnamed_addr #0 !dbg [[Fn:[!][0-9]+]]
6 ; Function Attrs: norecurse nounwind readnone willreturn
7 define dso_local float @fma(float %0, float %1, float %2) local_unnamed_addr #0 !dbg !6 {
8 ; CHECK-NEXT: call void @llvm.dbg.value(metadata float %0, metadata [[VarX:[!][0-9]+]], metadata [[Expr:[!][0-9]+]]), !dbg [[Line1:[!][0-9]+]]
9 ; CHECK-NEXT: call void @llvm.dbg.value(metadata float %1, metadata [[VarY:[!][0-9]+]], metadata [[Expr]]), !dbg [[Line1]]
10 ; CHECK-NEXT: call void @llvm.dbg.value(metadata float %2, metadata [[VarZ:[!][0-9]+]], metadata [[Expr]]), !dbg [[Line1]]
11   call void @llvm.dbg.value(metadata float %0, metadata !11, metadata !DIExpression()), !dbg !14
12   call void @llvm.dbg.value(metadata float %1, metadata !12, metadata !DIExpression()), !dbg !14
13   call void @llvm.dbg.value(metadata float %2, metadata !13, metadata !DIExpression()), !dbg !14
14 ; CHECK-NEXT: %4 = fmul float %0, %1, !dbg [[Line2:[!][0-9]+]]
15 ; CHECK-NEXT: %5 = fadd float %4, %2, !dbg [[Line3:[!][0-9]+]]
16   %4 = fmul float %0, %1, !dbg !15
17   %5 = fadd float %4, %2, !dbg !16
18   ret float %5, !dbg !17
21 ; Function Attrs: nofree nosync nounwind readnone speculatable willreturn
22 declare void @llvm.dbg.value(metadata, metadata, metadata) #1
24 attributes #0 = { norecurse nounwind readnone willreturn }
25 attributes #1 = { nofree nosync nounwind readnone speculatable willreturn }
27 !llvm.dbg.cu = !{!0}
28 !llvm.module.flags = !{!3, !4}
29 !llvm.ident = !{!5}
31 ; Other tests verify that we come back with reasonable structure for the debug
32 ; info types, this test just needs to ensure they are there.
33 ; The patch this is paired with fixes a bug where function debug info wasn't
34 ; being emitted correctly even though other tests verified the MD would be
35 ; emitted if it was referenced as module metadata.
37 ; CHECK:      !0 = distinct !DICompileUnit
38 ; CHECK-NEXT: !1 = !DIFile(filename:
39 ; CHECK:      [[Fn]] = distinct !DISubprogram(name: "fma",
40 ; CHECK:      [[VarX]] = !DILocalVariable(tag:
41 ; CHECK:      [[VarY]] = !DILocalVariable(tag:
42 ; CHECK:      [[VarZ]] = !DILocalVariable(tag:
43 ; CHECK-NEXT: [[Expr]] = !DIExpression()
44 ; CHECK-NEXT: [[Line1]] = !DILocation(line:
45 ; CHECK-NEXT: [[Line2]] = !DILocation(line:
46 ; CHECK-NEXT: [[Line3]] = !DILocation(line:
47 ; CHECK-NEXT: {{[!][0-9]+}} = !DILocation(line:
49 !0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1, isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug, enums: !2, splitDebugInlining: false, nameTableKind: None)
50 !1 = !DIFile(filename: "in.c", directory: "dir")
51 !2 = !{}
52 !3 = !{i32 7, !"Dwarf Version", i32 2}
53 !4 = !{i32 2, !"Debug Info Version", i32 3}
54 !5 = !{!"Some Compiler"}
55 !6 = distinct !DISubprogram(name: "fma", scope: !1, file: !1, line: 1, type: !7, scopeLine: 1, flags: DIFlagPrototyped, spFlags: DISPFlagDefinition | DISPFlagOptimized, unit: !0, retainedNodes: !10)
56 !7 = !DISubroutineType(types: !8)
57 !8 = !{!9, !9, !9, !9}
58 !9 = !DIBasicType(name: "float", size: 32, encoding: DW_ATE_float)
59 !10 = !{!11, !12, !13}
60 !11 = !DILocalVariable(name: "x", arg: 1, scope: !6, file: !1, line: 1, type: !9)
61 !12 = !DILocalVariable(name: "y", arg: 2, scope: !6, file: !1, line: 1, type: !9)
62 !13 = !DILocalVariable(name: "z", arg: 3, scope: !6, file: !1, line: 1, type: !9)
63 !14 = !DILocation(line: 0, scope: !6)
64 !15 = !DILocation(line: 2, column: 12, scope: !6)
65 !16 = !DILocation(line: 2, column: 16, scope: !6)
66 !17 = !DILocation(line: 2, column: 3, scope: !6)