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.
7 define anyregcc i64 @fun() { ret i64 0 }
13 tracksRegLiveness: true
15 - { id: 0, class: gr64bit }
18 machineFunctionInfo: {}
22 %0:gr64bit = LGHI $r2l
23 %1:addr64bit = LLILL $r2l
24 %2:addr64bit = LGFI $r2l
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 MVCLoop %4, 0, %3, 0, 1680, %0, implicit-def $cc
35 MVCLoop %4, 0, %3, 0, %1, %0, implicit-def $cc
37 BCR 0, 0, $r2d, implicit $cc
38 BCR 0, $r2d, $r2d, implicit $cc
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: MVCLoop %4:addr64bit, 0, %3:addr64bit, 0, %1:addr64bit, %0:gr64bit, 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