forked from OSchip/llvm-project
31 lines
780 B
Plaintext
31 lines
780 B
Plaintext
|
# RUN: not llc -march=aarch64 -o /dev/null -run-pass=none -verify-machineinstrs %s 2>&1 | FileCheck %s
|
||
|
# REQUIRES: global-isel, aarch64-registered-target
|
||
|
|
||
|
---
|
||
|
name: test_jump_table
|
||
|
legalized: true
|
||
|
tracksRegLiveness: true
|
||
|
jumpTable:
|
||
|
kind: block-address
|
||
|
entries:
|
||
|
- id: 0
|
||
|
blocks: [ '%bb.0' ]
|
||
|
body: |
|
||
|
bb.0:
|
||
|
liveins: $x0
|
||
|
%0:_(s64) = COPY $x0
|
||
|
%1:_(p0) = COPY $x0
|
||
|
; CHECK: Bad machine code: Too few operands
|
||
|
G_BRJT
|
||
|
|
||
|
; CHECK: G_BRJT src operand 0 must be a pointer type
|
||
|
G_BRJT %0, %jump-table.0, %0
|
||
|
|
||
|
; CHECK: G_BRJT src operand 1 must be a jump table index
|
||
|
G_BRJT %1, %0, %0
|
||
|
|
||
|
; CHECK: G_BRJT src operand 2 must be a scalar reg type
|
||
|
G_BRJT %1, %jump-table.0, %1
|
||
|
|
||
|
...
|