[MIParser] Set RegClassOrRegBank during instruction parsing
[llvm-complete.git] / test / DebugInfo / WebAssembly / dbg-value-move-reg-stackify.mir
blobaf36dc12d2e2eb95a1947c896ee7be249f4e208e
1 # RUN: llc < %s -run-pass=wasm-reg-stackify -x=mir 2>&1 | FileCheck %s
3 # CHECK: body:
4 # CHECK: %1:i32 = I32_WRAP_I64 %0,
5 # CHECK-NEXT: DBG_VALUE %1,
6 # CHECK-NEXT: %1:i32 = CALL_i32 @bar,
7 # CHECK-NEXT: DBG_VALUE %1,
8 # CHECK-NEXT: %[[NEWREG:.*]]:i32 = CALL_i32 @bar,
9 # CHECK-NEXT: DBG_VALUE %[[NEWREG]],
10 # CHECK-NEXT: CALL_VOID @foo, %[[NEWREG]],
12 --- |
13   target datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128"
14   target triple = "wasm32-unknown-unknown"
16   declare void @foo(i32)
17   declare i32 @bar()
19   define void @test(i64 %arg) {
20     unreachable
21   }
23   !llvm.dbg.cu = !{!0}
24   !llvm.module.flags = !{!4}
25   !0 = distinct !DICompileUnit(language: DW_LANG_Rust, file: !2, producer: "clang LLVM (rustc version 1.30.0-dev)", isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug, enums: !1, globals: !1)
26   !1 = !{}
27   !2 = !DIFile(filename: "<unknown>", directory: "")
28   !3 = distinct !DICompositeType(tag: DW_TAG_structure_type, name: "&str", file: !2, size: 64, align: 32, elements: !{}, identifier: "111094d970b097647de579f9c509ef08")
29   !4 = !{i32 2, !"Debug Info Version", i32 3}
30   !5 = distinct !DILexicalBlock(scope: !6, file: !2, line: 357, column: 8)
31   !6 = distinct !DISubprogram(name: "testfoo", linkageName: "_testba", scope: !7, file: !2, line: 353, type: !8, isLocal: true, isDefinition: true, scopeLine: 353, flags: DIFlagPrototyped, isOptimized: true, unit: !0, templateParams: !1, retainedNodes: !9)
32   !7 = !DINamespace(name: "ptr", scope: null)
33   !8 = !DISubroutineType(types: !1)
34   !9 = !{!10}
35   !10 = !DILocalVariable(name: "val0", scope: !5, file: !2, line: 357, type: !3, align: 4)
36   !11 = !DILocalVariable(name: "val1", scope: !5, file: !2, line: 358, type: !3, align: 4)
37   !12 = !DILocalVariable(name: "val2", scope: !5, file: !2, line: 359, type: !3, align: 4)
38   !13 = !DILocation(line: 357, column: 12, scope: !5)
39   !14 = !DILocation(line: 358, column: 12, scope: !5)
40   !15 = !DILocation(line: 359, column: 12, scope: !5)
42 ---
43 name: test
44 liveins:
45   - { reg: '$arguments' }
46 tracksRegLiveness: true
47 body: |
48   bb.0:
49     liveins: $arguments
50     %0:i64 = ARGUMENT_i64 0, implicit $arguments
51     %1:i32 = I32_WRAP_I64 %0:i64, implicit-def dead $arguments
52     DBG_VALUE %1:i32, $noreg, !10, !DIExpression(), debug-location !13; <unknown>:357:12 line no:357
53     %1:i32 = CALL_i32 @bar, implicit-def dead $arguments, implicit $sp32, implicit $sp64
54     DBG_VALUE %1:i32, $noreg, !11, !DIExpression(), debug-location !14; <unknown>:357:12 line no:357
55     %1:i32 = CALL_i32 @bar, implicit-def dead $arguments, implicit $sp32, implicit $sp64
56     DBG_VALUE %1:i32, $noreg, !12, !DIExpression(), debug-location !15; <unknown>:357:12 line no:357
57     CALL_VOID @foo, %1:i32, implicit-def dead $arguments, implicit $sp32, implicit $sp64
58     RETURN implicit-def dead $arguments
60 ...