1 # RUN: not --crash llc -march=amdgcn -run-pass=legalizer -o /dev/null %s 2>&1 | FileCheck %s
3 # CHECK: LLVM ERROR: unable to legalize instruction: %3:_(p0) = G_JUMP_TABLE %jump-table.0 (in function: jt_test)
5 # FIXME: This could probably be smaller, but the jump table MIR parsing is very crashy.
8 define i32 @jt_test(i32 %x) {
10 switch i32 %x, label %return [
21 sw.bb: ; preds = %entry, %entry, %entry, %entry, %entry
22 %add = add nsw i32 %x, 42
25 sw.bb1: ; preds = %entry, %entry, %entry
26 %mul = mul nsw i32 %x, 3
29 return: ; preds = %sw.bb1, %sw.bb, %entry
30 %retval.0 = phi i32 [ %mul, %sw.bb1 ], [ %add, %sw.bb ], [ 0, %entry ]
37 tracksRegLiveness: true
42 blocks: [ '%bb.3', '%bb.3', '%bb.3', '%bb.4', '%bb.4', '%bb.4',
43 '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4',
44 '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4',
45 '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4',
46 '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4',
47 '%bb.2', '%bb.2', '%bb.4', '%bb.4', '%bb.4', '%bb.4',
48 '%bb.2', '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4',
49 '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4',
50 '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.2', '%bb.4',
51 '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4',
52 '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4',
53 '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.4', '%bb.2' ]
58 %0:_(s32) = COPY $sgpr0
59 %1:_(s32) = G_CONSTANT i32 0
60 %2:_(s1) = G_ICMP intpred(ugt), %0, %1
61 %3:_(p0) = G_JUMP_TABLE %jump-table.0
66 successors: %bb.3(0x2aaaaaab), %bb.4(0x2aaaaaab), %bb.2(0x2aaaaaab)