forked from OSchip/llvm-project
[RISCV] simm12_plus1 should not inherit from Operand. NFC
We only use this in Pat patterns, so it just needs to be an ImmLeaf. If we did need it as an instruction operand, the ParserMatchClass, EncoderMethod, and DecoderMethod were probably wrong.
This commit is contained in:
parent
0d7fd9f0d0
commit
5db19cc010
|
@ -157,20 +157,6 @@ def simm12 : Operand<XLenVT>, ImmLeaf<XLenVT, [{return isInt<12>(Imm);}]> {
|
|||
let OperandNamespace = "RISCVOp";
|
||||
}
|
||||
|
||||
// A 12-bit signed immediate plus one where the imm range will be -2047~2048.
|
||||
def simm12_plus1 : Operand<XLenVT>, ImmLeaf<XLenVT,
|
||||
[{return (isInt<12>(Imm) && Imm != -2048) || Imm == 2048;}]> {
|
||||
let ParserMatchClass = SImmAsmOperand<12>;
|
||||
let EncoderMethod = "getImmOpValue";
|
||||
let DecoderMethod = "decodeSImmOperand<12>";
|
||||
let MCOperandPredicate = [{
|
||||
int64_t Imm;
|
||||
if (MCOp.evaluateAsConstantImm(Imm))
|
||||
return (isInt<12>(Imm) && Imm != -2048) || Imm == 2048;
|
||||
return MCOp.isBareSymbolRef();
|
||||
}];
|
||||
}
|
||||
|
||||
// A 13-bit signed immediate where the least significant bit is zero.
|
||||
def simm13_lsb0 : Operand<OtherVT> {
|
||||
let ParserMatchClass = SImmAsmOperand<13, "Lsb0">;
|
||||
|
@ -296,6 +282,10 @@ def ixlenimm_li : Operand<XLenVT> {
|
|||
|
||||
// Standalone (codegen-only) immleaf patterns.
|
||||
|
||||
// A 12-bit signed immediate plus one where the imm range will be -2047~2048.
|
||||
def simm12_plus1 : ImmLeaf<XLenVT,
|
||||
[{return (isInt<12>(Imm) && Imm != -2048) || Imm == 2048;}]>;
|
||||
|
||||
// A 6-bit constant greater than 32.
|
||||
def uimm6gt32 : ImmLeaf<XLenVT, [{
|
||||
return isUInt<6>(Imm) && Imm > 32;
|
||||
|
|
Loading…
Reference in New Issue