| // RUN: not llvm-tblgen -gen-instr-info -I %p/../../include %s 2>&1 | FileCheck %s |
| |
| // This test verifies that TableGen is displaying an error when mapped instruction |
| // does not contain a field listed under RowFields. |
| |
| include "llvm/Target/Target.td" |
| |
| class SimpleReg<string n> : Register<n> { |
| let Namespace = "Simple"; |
| } |
| def R0 : SimpleReg<"r0">; |
| def SimpleRegClass : RegisterClass<"Simple",[i32],0,(add R0)>; |
| def SimpleInstrInfo : InstrInfo; |
| |
| def SimpleTarget : Target { |
| let InstructionSet = SimpleInstrInfo; |
| } |
| |
| class SimpleRel; |
| |
| def REL_DEF : InstrMapping { |
| let FilterClass = "SimpleRel"; |
| let RowFields = ["BaseName"]; |
| let ColFields = ["Col"]; |
| let KeyCol = ["KeyCol"]; |
| let ValueCols = [["ValCol"]]; |
| } |
| |
| class INSTR_DEF : Instruction { |
| let Namespace = "Simple"; |
| let OutOperandList = (outs); |
| let InOperandList = (ins); |
| string Basename = ""; |
| string Col = ""; |
| } |
| |
| def SimpleInstr : SimpleRel, INSTR_DEF; |
| |
| // CHECK: error: No value "BaseName" found in "SimpleInstr" instruction description. |
| // CHECK: def SimpleInstr : SimpleRel, INSTR_DEF; |