Index: llvm/lib/Target/RISCV/MCTargetDesc/RISCVBaseInfo.h =================================================================== --- llvm/lib/Target/RISCV/MCTargetDesc/RISCVBaseInfo.h +++ llvm/lib/Target/RISCV/MCTargetDesc/RISCVBaseInfo.h @@ -219,11 +219,23 @@ OPERAND_UIMM4, OPERAND_UIMM5, OPERAND_UIMM7, + OPERAND_UIMM7_LSB00, + OPERAND_UIMM8_LSB00, + OPERAND_UIMM8_LSB000, OPERAND_UIMM12, + OPERAND_ZERO, + OPERAND_SIMM5, + OPERAND_SIMM5_PLUS1, + OPERAND_SIMM6, + OPERAND_SIMM6_NONZERO, OPERAND_SIMM12, OPERAND_SIMM12_LSB00000, OPERAND_UIMM20, OPERAND_UIMMLOG2XLEN, + OPERAND_UIMMLOG2XLEN_NONZERO, + OPERAND_UIMM_SHFL, + OPERAND_VTYPEI10, + OPERAND_VTYPEI11, OPERAND_RVKRNUM, OPERAND_LAST_RISCV_IMM = OPERAND_RVKRNUM, // Operand is either a register or uimm5, this is used by V extension pseudo Index: llvm/lib/Target/RISCV/RISCVInstrInfo.cpp =================================================================== --- llvm/lib/Target/RISCV/RISCVInstrInfo.cpp +++ llvm/lib/Target/RISCV/RISCVInstrInfo.cpp @@ -1125,9 +1125,39 @@ CASE_OPERAND_UIMM(4) CASE_OPERAND_UIMM(5) CASE_OPERAND_UIMM(7) + case RISCVOp::OPERAND_UIMM7_LSB00: + Ok = isShiftedUInt<5, 2>(Imm); + break; + case RISCVOp::OPERAND_UIMM8_LSB00: + Ok = isShiftedUInt<6, 2>(Imm); + break; + case RISCVOp::OPERAND_UIMM8_LSB000: + Ok = isShiftedUInt<5, 3>(Imm); + break; CASE_OPERAND_UIMM(12) CASE_OPERAND_UIMM(20) // clang-format on + case RISCVOp::OPERAND_ZERO: + Ok = Imm == 0; + break; + case RISCVOp::OPERAND_SIMM5: + Ok = isInt<5>(Imm); + break; + case RISCVOp::OPERAND_SIMM5_PLUS1: + Ok = (isInt<5>(Imm) && Imm != -16) || Imm == 16; + break; + case RISCVOp::OPERAND_SIMM6: + Ok = isInt<6>(Imm); + break; + case RISCVOp::OPERAND_SIMM6_NONZERO: + Ok = Imm != 0 && isInt<6>(Imm); + break; + case RISCVOp::OPERAND_VTYPEI10: + Ok = isUInt<10>(Imm); + break; + case RISCVOp::OPERAND_VTYPEI11: + Ok = isUInt<11>(Imm); + break; case RISCVOp::OPERAND_SIMM12: Ok = isInt<12>(Imm); break; @@ -1135,10 +1165,17 @@ Ok = isShiftedInt<7, 5>(Imm); break; case RISCVOp::OPERAND_UIMMLOG2XLEN: - if (STI.getTargetTriple().isArch64Bit()) - Ok = isUInt<6>(Imm); - else - Ok = isUInt<5>(Imm); + Ok = STI.getTargetTriple().isArch64Bit() ? isUInt<6>(Imm) + : isUInt<5>(Imm); + break; + case RISCVOp::OPERAND_UIMMLOG2XLEN_NONZERO: + Ok = STI.getTargetTriple().isArch64Bit() ? isUInt<6>(Imm) + : isUInt<5>(Imm); + Ok = Ok && Imm != 0; + break; + case RISCVOp::OPERAND_UIMM_SHFL: + Ok = STI.getTargetTriple().isArch64Bit() ? isUInt<5>(Imm) + : isUInt<4>(Imm); break; case RISCVOp::OPERAND_RVKRNUM: Ok = Imm >= 0 && Imm <= 10; Index: llvm/lib/Target/RISCV/RISCVInstrInfoC.td =================================================================== --- llvm/lib/Target/RISCV/RISCVInstrInfoC.td +++ llvm/lib/Target/RISCV/RISCVInstrInfoC.td @@ -26,6 +26,8 @@ let ParserMatchClass = UImmLog2XLenNonZeroAsmOperand; // TODO: should ensure invalid shamt is rejected when decoding. let DecoderMethod = "decodeUImmOperand<6>"; + let OperandType = "OPERAND_UIMMLOG2XLEN_NONZERO"; + let OperandNamespace = "RISCVOp"; let MCOperandPredicate = [{ int64_t Imm; if (!MCOp.evaluateAsConstantImm(Imm)) @@ -40,6 +42,8 @@ let ParserMatchClass = SImmAsmOperand<6>; let EncoderMethod = "getImmOpValue"; let DecoderMethod = "decodeSImmOperand<6>"; + let OperandType = "OPERAND_SIMM6"; + let OperandNamespace = "RISCVOp"; let MCOperandPredicate = [{ int64_t Imm; if (MCOp.evaluateAsConstantImm(Imm)) @@ -53,6 +57,8 @@ let ParserMatchClass = SImmAsmOperand<6, "NonZero">; let EncoderMethod = "getImmOpValue"; let DecoderMethod = "decodeSImmOperand<6>"; + let OperandType = "OPERAND_SIMM6_NONZERO"; + let OperandNamespace = "RISCVOp"; let MCOperandPredicate = [{ int64_t Imm; if (MCOp.evaluateAsConstantImm(Imm)) @@ -64,6 +70,8 @@ def immzero : Operand, ImmLeaf { let ParserMatchClass = ImmZeroAsmOperand; + let OperandType = "OPERAND_ZERO"; + let OperandNamespace = "RISCVOp"; } def CLUIImmAsmOperand : AsmOperandClass { @@ -100,6 +108,8 @@ let ParserMatchClass = UImmAsmOperand<7, "Lsb00">; let EncoderMethod = "getImmOpValue"; let DecoderMethod = "decodeUImmOperand<7>"; + let OperandType = "OPERAND_UIMM7_LSB00"; + let OperandNamespace = "RISCVOp"; let MCOperandPredicate = [{ int64_t Imm; if (!MCOp.evaluateAsConstantImm(Imm)) @@ -114,6 +124,8 @@ let ParserMatchClass = UImmAsmOperand<8, "Lsb00">; let EncoderMethod = "getImmOpValue"; let DecoderMethod = "decodeUImmOperand<8>"; + let OperandType = "OPERAND_UIMM8_LSB00"; + let OperandNamespace = "RISCVOp"; let MCOperandPredicate = [{ int64_t Imm; if (!MCOp.evaluateAsConstantImm(Imm)) @@ -128,6 +140,8 @@ let ParserMatchClass = UImmAsmOperand<8, "Lsb000">; let EncoderMethod = "getImmOpValue"; let DecoderMethod = "decodeUImmOperand<8>"; + let OperandType = "OPERAND_UIMM8_LSB000"; + let OperandNamespace = "RISCVOp"; let MCOperandPredicate = [{ int64_t Imm; if (!MCOp.evaluateAsConstantImm(Imm)) Index: llvm/lib/Target/RISCV/RISCVInstrInfoV.td =================================================================== --- llvm/lib/Target/RISCV/RISCVInstrInfoV.td +++ llvm/lib/Target/RISCV/RISCVInstrInfoV.td @@ -28,6 +28,14 @@ let ParserMatchClass = VTypeIAsmOperand; let PrintMethod = "printVTypeI"; let DecoderMethod = "decodeUImmOperand<"#VTypeINum#">"; + let OperandType = "OPERAND_VTYPEI" # VTypeINum; + let OperandNamespace = "RISCVOp"; + let MCOperandPredicate = [{ + int64_t Imm; + if (MCOp.evaluateAsConstantImm(Imm)) + return isUInt(Imm); + return MCOp.isBareSymbolRef(); + }]; } def VTypeIOp10 : VTypeIOp<10>; @@ -54,6 +62,8 @@ let ParserMatchClass = SImmAsmOperand<5>; let EncoderMethod = "getImmOpValue"; let DecoderMethod = "decodeSImmOperand<5>"; + let OperandType = "OPERAND_SIMM5"; + let OperandNamespace = "RISCVOp"; let MCOperandPredicate = [{ int64_t Imm; if (MCOp.evaluateAsConstantImm(Imm)) @@ -71,6 +81,8 @@ def simm5_plus1 : Operand, ImmLeaf(Imm) && Imm != -16) || Imm == 16;}]> { let ParserMatchClass = SImm5Plus1AsmOperand; + let OperandType = "OPERAND_SIMM5_PLUS1"; + let OperandNamespace = "RISCVOp"; let MCOperandPredicate = [{ int64_t Imm; if (MCOp.evaluateAsConstantImm(Imm)) Index: llvm/lib/Target/RISCV/RISCVInstrInfoZb.td =================================================================== --- llvm/lib/Target/RISCV/RISCVInstrInfoZb.td +++ llvm/lib/Target/RISCV/RISCVInstrInfoZb.td @@ -71,6 +71,8 @@ }]> { let ParserMatchClass = UImmLog2XLenHalfAsmOperand; let DecoderMethod = "decodeUImmOperand<5>"; + let OperandType = "OPERAND_UIMM_SHFL"; + let OperandNamespace = "RISCVOp"; let MCOperandPredicate = [{ int64_t Imm; if (!MCOp.evaluateAsConstantImm(Imm))