// RUN: llvm-tblgen -gen-disassembler -I %p/../../../include %s | FileCheck %s include "llvm/Target/Target.td" class I : Instruction { let InOperandList = (ins i32imm:$op); let OutOperandList = (outs); } // Check that we don't try to read the second byte without ruling out // 1-byte encodings first. This should actually be a decoding conflict, // but DecoderEmitter heuristics decide that I8_0 and I8_1 are more specific // than the rest and give them priority. // _______0 I8_0 // _______1 I8_1 // 00000000 ________ I16_0 // 00000001 ________ I16_1 // 00000010 ________ I16_2 // CHECK: switch Inst[0] // CHECK: decode to I8_0 // CHECK: decode to I8_1 // CHECK: switch Inst[15:8] // CHECK: decode to I16_0 // CHECK: decode to I16_1 def I8_0 : I { dag Inst = (descend (operand "$op", 7), 0b0); } def I8_1 : I { dag Inst = (descend (operand "$op", 7), 0b1); } def I16_0 : I { dag Inst = (descend 0b00000000, (operand "$op", 8)); } def I16_1 : I { dag Inst = (descend 0b00000001, (operand "$op", 8)); } def I16_2 : I { dag Inst = (descend 0b00000010, (operand "$op", 8)); } def II : InstrInfo; def MyTarget : Target { let InstructionSet = II; }