Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / CodeGen / SystemZ / mverify-optypes.mir
blobb9d53f44e9eb15653b28d3d23f87bae77d54f1d5
1 # RUN: not --crash llc -mtriple=s390x-linux-gnu -mcpu=z14 -run-pass=none -o - %s \
2 # RUN:  2>&1 | FileCheck %s
4 # Test that the machine verifier catches wrong operand types.
6 --- |
7   define anyregcc i64 @fun() { ret i64 0  }
8   @gsrc = global i16 2
9 ...
10 ---
11 name:            fun
12 alignment:       16
13 tracksRegLiveness: true
14 registers:
15   - { id: 0, class: gr64bit }
16 frameInfo:
17   maxAlignment:    1
18 machineFunctionInfo: {}
19 body:             |
20   bb.0 (%ir-block.0):
21     liveins: $r2l
22     %0:gr64bit = LGHI $r2l
23     %1:addr64bit = LLILL $r2l
24     %2:addr64bit = LGFI $r2l
25     %3:addr64bit = LGFI 0
27     %3:addr64bit = AG %3, %1, 0, %2, implicit-def dead $cc
28     %3:addr64bit = AG %3, %1, %0, %2, implicit-def dead $cc
29     %3:addr64bit = AG %3, %1, 0, 2, implicit-def dead $cc
31     %4:addr64bit = LARL @gsrc
32     %4:addr64bit = LARL $r2l
34     MVCImm %4, 0, %3, 0, 1680, implicit-def $cc
35     MVCImm %4, 0, %3, 0, %1, implicit-def $cc
37     BCR 0, 0, $r2d, implicit $cc
38     BCR 0, $r2d, $r2d, implicit $cc
39     Return implicit $r2d
41 ...
43 # CHECK: *** Bad machine code: Expected a non-register operand. ***
44 # CHECK: - instruction: %0:gr64bit = LGHI $r2l
45 # CHECK: - operand 1:   $r2l
47 # CHECK: *** Bad machine code: Expected a non-register operand. ***
48 # CHECK: - instruction: %1:addr64bit = LLILL $r2l
49 # CHECK: - operand 1:   $r2l
51 # CHECK: *** Bad machine code: Expected a non-register operand. ***
52 # CHECK: - instruction: %2:addr64bit = LGFI $r2l
53 # CHECK: - operand 1:   $r2l
55 # CHECK: *** Bad machine code: Addressing mode operands corrupt! ***
56 # CHECK: - instruction: %3:addr64bit = AG %3:addr64bit(tied-def 0), %1:addr64bit, %0:gr64bit, %2:addr64bit, implicit-def dead $cc
58 # CHECK: *** Bad machine code: Addressing mode operands corrupt! ***
59 # CHECK: - instruction: %3:addr64bit = AG %3:addr64bit(tied-def 0), %1:addr64bit, 0, 2, implicit-def dead $cc
61 # CHECK: *** Bad machine code: Expected a non-register operand. ***
62 # CHECK: - instruction: %4:addr64bit = LARL $r2l
63 # CHECK: - operand 1:   $r2l
65 # CHECK: *** Bad machine code: Expected a non-register operand. ***
66 # CHECK: - instruction: MVCImm %4:addr64bit, 0, %3:addr64bit, 0, %1:addr64bit, implicit-def $cc
67 # CHECK: - operand 4:   %1:addr64bit
69 # CHECK: *** Bad machine code: Expected a non-register operand. ***
70 # CHECK: - instruction: BCR 0, $r2d, $r2d, implicit $cc
71 # CHECK: - operand 1:   $r2d