forked from OSchip/llvm-project
31 lines
780 B
YAML
31 lines
780 B
YAML
# 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
|
|
|
|
...
|