forked from OSchip/llvm-project
[RISCV] Move instruction information into the RISCVII namespace (NFC)
Move instruction attributes into the `RISCVII` namespace and add associated helper functions. Differential Revision: https://reviews.llvm.org/D102268
This commit is contained in:
parent
1556540372
commit
3a64b7080d
|
@ -1589,9 +1589,9 @@ OperandMatchResultTy RISCVAsmParser::parseVTypeI(OperandVector &Operands) {
|
||||||
|
|
||||||
unsigned SewLog2 = Log2_32(Sew / 8);
|
unsigned SewLog2 = Log2_32(Sew / 8);
|
||||||
unsigned LmulLog2 = Log2_32(Lmul);
|
unsigned LmulLog2 = Log2_32(Lmul);
|
||||||
RISCVVSEW VSEW = static_cast<RISCVVSEW>(SewLog2);
|
RISCVII::VSEW VSEW = static_cast<RISCVII::VSEW>(SewLog2);
|
||||||
RISCVVLMUL VLMUL =
|
RISCVII::VLMUL VLMUL =
|
||||||
static_cast<RISCVVLMUL>(Fractional ? 8 - LmulLog2 : LmulLog2);
|
static_cast<RISCVII::VLMUL>(Fractional ? 8 - LmulLog2 : LmulLog2);
|
||||||
|
|
||||||
unsigned VTypeI =
|
unsigned VTypeI =
|
||||||
RISCVVType::encodeVTYPE(VLMUL, VSEW, TailAgnostic, MaskAgnostic);
|
RISCVVType::encodeVTYPE(VLMUL, VSEW, TailAgnostic, MaskAgnostic);
|
||||||
|
@ -2479,8 +2479,8 @@ bool RISCVAsmParser::validateInstruction(MCInst &Inst,
|
||||||
}
|
}
|
||||||
|
|
||||||
const MCInstrDesc &MCID = MII.get(Inst.getOpcode());
|
const MCInstrDesc &MCID = MII.get(Inst.getOpcode());
|
||||||
unsigned Constraints =
|
RISCVII::VConstraintType Constraints =
|
||||||
(MCID.TSFlags & RISCVII::ConstraintMask) >> RISCVII::ConstraintShift;
|
RISCVII::getConstraint(MCID.TSFlags);
|
||||||
if (Constraints == RISCVII::NoConstraint)
|
if (Constraints == RISCVII::NoConstraint)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
|
|
@ -99,26 +99,26 @@ void validate(const Triple &TT, const FeatureBitset &FeatureBits) {
|
||||||
} // namespace RISCVFeatures
|
} // namespace RISCVFeatures
|
||||||
|
|
||||||
void RISCVVType::printVType(unsigned VType, raw_ostream &OS) {
|
void RISCVVType::printVType(unsigned VType, raw_ostream &OS) {
|
||||||
RISCVVSEW VSEW = getVSEW(VType);
|
RISCVII::VSEW VSEW = getVSEW(VType);
|
||||||
RISCVVLMUL VLMUL = getVLMUL(VType);
|
RISCVII::VLMUL VLMUL = getVLMUL(VType);
|
||||||
|
|
||||||
unsigned Sew = 1 << (static_cast<unsigned>(VSEW) + 3);
|
unsigned Sew = 1 << (static_cast<unsigned>(VSEW) + 3);
|
||||||
OS << "e" << Sew;
|
OS << "e" << Sew;
|
||||||
|
|
||||||
switch (VLMUL) {
|
switch (VLMUL) {
|
||||||
case RISCVVLMUL::LMUL_RESERVED:
|
case RISCVII::VLMUL::LMUL_RESERVED:
|
||||||
llvm_unreachable("Unexpected LMUL value!");
|
llvm_unreachable("Unexpected LMUL value!");
|
||||||
case RISCVVLMUL::LMUL_1:
|
case RISCVII::VLMUL::LMUL_1:
|
||||||
case RISCVVLMUL::LMUL_2:
|
case RISCVII::VLMUL::LMUL_2:
|
||||||
case RISCVVLMUL::LMUL_4:
|
case RISCVII::VLMUL::LMUL_4:
|
||||||
case RISCVVLMUL::LMUL_8: {
|
case RISCVII::VLMUL::LMUL_8: {
|
||||||
unsigned LMul = 1 << static_cast<unsigned>(VLMUL);
|
unsigned LMul = 1 << static_cast<unsigned>(VLMUL);
|
||||||
OS << ",m" << LMul;
|
OS << ",m" << LMul;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case RISCVVLMUL::LMUL_F2:
|
case RISCVII::VLMUL::LMUL_F2:
|
||||||
case RISCVVLMUL::LMUL_F4:
|
case RISCVII::VLMUL::LMUL_F4:
|
||||||
case RISCVVLMUL::LMUL_F8: {
|
case RISCVII::VLMUL::LMUL_F8: {
|
||||||
unsigned LMul = 1 << (8 - static_cast<unsigned>(VLMUL));
|
unsigned LMul = 1 << (8 - static_cast<unsigned>(VLMUL));
|
||||||
OS << ",mf" << LMul;
|
OS << ",mf" << LMul;
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -45,8 +45,9 @@ enum {
|
||||||
InstFormatOther = 17,
|
InstFormatOther = 17,
|
||||||
|
|
||||||
InstFormatMask = 31,
|
InstFormatMask = 31,
|
||||||
|
InstFormatShift = 0,
|
||||||
|
|
||||||
ConstraintShift = 5,
|
ConstraintShift = InstFormatShift + 5,
|
||||||
ConstraintMask = 0b111 << ConstraintShift,
|
ConstraintMask = 0b111 << ConstraintShift,
|
||||||
|
|
||||||
VLMulShift = ConstraintShift + 3,
|
VLMulShift = ConstraintShift + 3,
|
||||||
|
@ -78,13 +79,70 @@ enum {
|
||||||
};
|
};
|
||||||
|
|
||||||
// Match with the definitions in RISCVInstrFormatsV.td
|
// Match with the definitions in RISCVInstrFormatsV.td
|
||||||
enum RVVConstraintType {
|
enum VConstraintType {
|
||||||
NoConstraint = 0,
|
NoConstraint = 0,
|
||||||
VS2Constraint = 0b001,
|
VS2Constraint = 0b001,
|
||||||
VS1Constraint = 0b010,
|
VS1Constraint = 0b010,
|
||||||
VMConstraint = 0b100,
|
VMConstraint = 0b100,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum VSEW {
|
||||||
|
SEW_8 = 0,
|
||||||
|
SEW_16,
|
||||||
|
SEW_32,
|
||||||
|
SEW_64,
|
||||||
|
SEW_128,
|
||||||
|
SEW_256,
|
||||||
|
SEW_512,
|
||||||
|
SEW_1024,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum VLMUL {
|
||||||
|
LMUL_1 = 0,
|
||||||
|
LMUL_2,
|
||||||
|
LMUL_4,
|
||||||
|
LMUL_8,
|
||||||
|
LMUL_RESERVED,
|
||||||
|
LMUL_F8,
|
||||||
|
LMUL_F4,
|
||||||
|
LMUL_F2
|
||||||
|
};
|
||||||
|
|
||||||
|
// Helper functions to read TSFlags.
|
||||||
|
/// \returns the format of the instruction.
|
||||||
|
static inline unsigned getFormat(uint64_t TSFlags) {
|
||||||
|
return (TSFlags & InstFormatMask) >> InstFormatShift;
|
||||||
|
}
|
||||||
|
/// \returns the constraint for the instruction.
|
||||||
|
static inline VConstraintType getConstraint(uint64_t TSFlags) {
|
||||||
|
return static_cast<VConstraintType>
|
||||||
|
((TSFlags & ConstraintMask) >> ConstraintShift);
|
||||||
|
}
|
||||||
|
/// \returns the LMUL for the instruction.
|
||||||
|
static inline VLMUL getLMul(uint64_t TSFlags) {
|
||||||
|
return static_cast<VLMUL>((TSFlags & VLMulMask) >> VLMulShift);
|
||||||
|
}
|
||||||
|
/// \returns true if there is a dummy mask operand for the instruction.
|
||||||
|
static inline bool hasDummyMaskOp(uint64_t TSFlags) {
|
||||||
|
return TSFlags & HasDummyMaskOpMask;
|
||||||
|
}
|
||||||
|
/// \returns true if tail agnostic is enforced for the instruction.
|
||||||
|
static inline bool doesForceTailAgnostic(uint64_t TSFlags) {
|
||||||
|
return TSFlags & ForceTailAgnosticMask;
|
||||||
|
}
|
||||||
|
/// \returns true if there is a merge operand for the instruction.
|
||||||
|
static inline bool hasMergeOp(uint64_t TSFlags) {
|
||||||
|
return TSFlags & HasMergeOpMask;
|
||||||
|
}
|
||||||
|
/// \returns true if there is a SEW operand for the instruction.
|
||||||
|
static inline bool hasSEWOp(uint64_t TSFlags) {
|
||||||
|
return TSFlags & HasSEWOpMask;
|
||||||
|
}
|
||||||
|
/// \returns true if there is a VL operand for the instruction.
|
||||||
|
static inline bool hasVLOp(uint64_t TSFlags) {
|
||||||
|
return TSFlags & HasVLOpMask;
|
||||||
|
}
|
||||||
|
|
||||||
// RISC-V Specific Machine Operand Flags
|
// RISC-V Specific Machine Operand Flags
|
||||||
enum {
|
enum {
|
||||||
MO_None = 0,
|
MO_None = 0,
|
||||||
|
@ -260,28 +318,6 @@ void validate(const Triple &TT, const FeatureBitset &FeatureBits);
|
||||||
|
|
||||||
} // namespace RISCVFeatures
|
} // namespace RISCVFeatures
|
||||||
|
|
||||||
enum class RISCVVSEW {
|
|
||||||
SEW_8 = 0,
|
|
||||||
SEW_16,
|
|
||||||
SEW_32,
|
|
||||||
SEW_64,
|
|
||||||
SEW_128,
|
|
||||||
SEW_256,
|
|
||||||
SEW_512,
|
|
||||||
SEW_1024,
|
|
||||||
};
|
|
||||||
|
|
||||||
enum class RISCVVLMUL {
|
|
||||||
LMUL_1 = 0,
|
|
||||||
LMUL_2,
|
|
||||||
LMUL_4,
|
|
||||||
LMUL_8,
|
|
||||||
LMUL_RESERVED,
|
|
||||||
LMUL_F8,
|
|
||||||
LMUL_F4,
|
|
||||||
LMUL_F2
|
|
||||||
};
|
|
||||||
|
|
||||||
namespace RISCVVType {
|
namespace RISCVVType {
|
||||||
// Is this a SEW value that can be encoded into the VTYPE format.
|
// Is this a SEW value that can be encoded into the VTYPE format.
|
||||||
inline static bool isValidSEW(unsigned SEW) {
|
inline static bool isValidSEW(unsigned SEW) {
|
||||||
|
@ -302,7 +338,7 @@ inline static bool isValidLMUL(unsigned LMUL, bool Fractional) {
|
||||||
// 6 | vta | Vector tail agnostic
|
// 6 | vta | Vector tail agnostic
|
||||||
// 5:3 | vsew[2:0] | Standard element width (SEW) setting
|
// 5:3 | vsew[2:0] | Standard element width (SEW) setting
|
||||||
// 2:0 | vlmul[2:0] | Vector register group multiplier (LMUL) setting
|
// 2:0 | vlmul[2:0] | Vector register group multiplier (LMUL) setting
|
||||||
inline static unsigned encodeVTYPE(RISCVVLMUL VLMUL, RISCVVSEW VSEW,
|
inline static unsigned encodeVTYPE(RISCVII::VLMUL VLMUL, RISCVII::VSEW VSEW,
|
||||||
bool TailAgnostic, bool MaskAgnostic) {
|
bool TailAgnostic, bool MaskAgnostic) {
|
||||||
unsigned VLMULBits = static_cast<unsigned>(VLMUL);
|
unsigned VLMULBits = static_cast<unsigned>(VLMUL);
|
||||||
unsigned VSEWBits = static_cast<unsigned>(VSEW);
|
unsigned VSEWBits = static_cast<unsigned>(VSEW);
|
||||||
|
@ -315,14 +351,14 @@ inline static unsigned encodeVTYPE(RISCVVLMUL VLMUL, RISCVVSEW VSEW,
|
||||||
return VTypeI;
|
return VTypeI;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline static RISCVVLMUL getVLMUL(unsigned VType) {
|
inline static RISCVII::VLMUL getVLMUL(unsigned VType) {
|
||||||
unsigned VLMUL = VType & 0x7;
|
unsigned VLMUL = VType & 0x7;
|
||||||
return static_cast<RISCVVLMUL>(VLMUL);
|
return static_cast<RISCVII::VLMUL>(VLMUL);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline static RISCVVSEW getVSEW(unsigned VType) {
|
inline static RISCVII::VSEW getVSEW(unsigned VType) {
|
||||||
unsigned VSEW = (VType >> 3) & 0x7;
|
unsigned VSEW = (VType >> 3) & 0x7;
|
||||||
return static_cast<RISCVVSEW>(VSEW);
|
return static_cast<RISCVII::VSEW>(VSEW);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline static bool isTailAgnostic(unsigned VType) { return VType & 0x40; }
|
inline static bool isTailAgnostic(unsigned VType) { return VType & 0x40; }
|
||||||
|
|
|
@ -270,7 +270,7 @@ unsigned RISCVMCCodeEmitter::getImmOpValue(const MCInst &MI, unsigned OpNo,
|
||||||
const MCOperand &MO = MI.getOperand(OpNo);
|
const MCOperand &MO = MI.getOperand(OpNo);
|
||||||
|
|
||||||
MCInstrDesc const &Desc = MCII.get(MI.getOpcode());
|
MCInstrDesc const &Desc = MCII.get(MI.getOpcode());
|
||||||
unsigned MIFrm = Desc.TSFlags & RISCVII::InstFormatMask;
|
unsigned MIFrm = RISCVII::getFormat(Desc.TSFlags);
|
||||||
|
|
||||||
// If the destination is an immediate, there is nothing to do.
|
// If the destination is an immediate, there is nothing to do.
|
||||||
if (MO.isImm())
|
if (MO.isImm())
|
||||||
|
|
|
@ -108,18 +108,18 @@ static SDValue createM4Tuple(SelectionDAG &CurDAG, ArrayRef<SDValue> Regs,
|
||||||
}
|
}
|
||||||
|
|
||||||
static SDValue createTuple(SelectionDAG &CurDAG, ArrayRef<SDValue> Regs,
|
static SDValue createTuple(SelectionDAG &CurDAG, ArrayRef<SDValue> Regs,
|
||||||
unsigned NF, RISCVVLMUL LMUL) {
|
unsigned NF, RISCVII::VLMUL LMUL) {
|
||||||
switch (LMUL) {
|
switch (LMUL) {
|
||||||
default:
|
default:
|
||||||
llvm_unreachable("Invalid LMUL.");
|
llvm_unreachable("Invalid LMUL.");
|
||||||
case RISCVVLMUL::LMUL_F8:
|
case RISCVII::VLMUL::LMUL_F8:
|
||||||
case RISCVVLMUL::LMUL_F4:
|
case RISCVII::VLMUL::LMUL_F4:
|
||||||
case RISCVVLMUL::LMUL_F2:
|
case RISCVII::VLMUL::LMUL_F2:
|
||||||
case RISCVVLMUL::LMUL_1:
|
case RISCVII::VLMUL::LMUL_1:
|
||||||
return createM1Tuple(CurDAG, Regs, NF);
|
return createM1Tuple(CurDAG, Regs, NF);
|
||||||
case RISCVVLMUL::LMUL_2:
|
case RISCVII::VLMUL::LMUL_2:
|
||||||
return createM2Tuple(CurDAG, Regs, NF);
|
return createM2Tuple(CurDAG, Regs, NF);
|
||||||
case RISCVVLMUL::LMUL_4:
|
case RISCVII::VLMUL::LMUL_4:
|
||||||
return createM4Tuple(CurDAG, Regs, NF);
|
return createM4Tuple(CurDAG, Regs, NF);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -166,7 +166,7 @@ void RISCVDAGToDAGISel::selectVLSEG(SDNode *Node, bool IsMasked,
|
||||||
unsigned NF = Node->getNumValues() - 1;
|
unsigned NF = Node->getNumValues() - 1;
|
||||||
MVT VT = Node->getSimpleValueType(0);
|
MVT VT = Node->getSimpleValueType(0);
|
||||||
unsigned ScalarSize = VT.getScalarSizeInBits();
|
unsigned ScalarSize = VT.getScalarSizeInBits();
|
||||||
RISCVVLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
RISCVII::VLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
||||||
|
|
||||||
unsigned CurOp = 2;
|
unsigned CurOp = 2;
|
||||||
SmallVector<SDValue, 8> Operands;
|
SmallVector<SDValue, 8> Operands;
|
||||||
|
@ -207,7 +207,7 @@ void RISCVDAGToDAGISel::selectVLSEGFF(SDNode *Node, bool IsMasked) {
|
||||||
MVT VT = Node->getSimpleValueType(0);
|
MVT VT = Node->getSimpleValueType(0);
|
||||||
MVT XLenVT = Subtarget->getXLenVT();
|
MVT XLenVT = Subtarget->getXLenVT();
|
||||||
unsigned ScalarSize = VT.getScalarSizeInBits();
|
unsigned ScalarSize = VT.getScalarSizeInBits();
|
||||||
RISCVVLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
RISCVII::VLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
||||||
|
|
||||||
unsigned CurOp = 2;
|
unsigned CurOp = 2;
|
||||||
SmallVector<SDValue, 7> Operands;
|
SmallVector<SDValue, 7> Operands;
|
||||||
|
@ -251,7 +251,7 @@ void RISCVDAGToDAGISel::selectVLXSEG(SDNode *Node, bool IsMasked,
|
||||||
unsigned NF = Node->getNumValues() - 1;
|
unsigned NF = Node->getNumValues() - 1;
|
||||||
MVT VT = Node->getSimpleValueType(0);
|
MVT VT = Node->getSimpleValueType(0);
|
||||||
unsigned ScalarSize = VT.getScalarSizeInBits();
|
unsigned ScalarSize = VT.getScalarSizeInBits();
|
||||||
RISCVVLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
RISCVII::VLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
||||||
|
|
||||||
unsigned CurOp = 2;
|
unsigned CurOp = 2;
|
||||||
SmallVector<SDValue, 8> Operands;
|
SmallVector<SDValue, 8> Operands;
|
||||||
|
@ -270,7 +270,7 @@ void RISCVDAGToDAGISel::selectVLXSEG(SDNode *Node, bool IsMasked,
|
||||||
assert(VT.getVectorElementCount() == IndexVT.getVectorElementCount() &&
|
assert(VT.getVectorElementCount() == IndexVT.getVectorElementCount() &&
|
||||||
"Element count mismatch");
|
"Element count mismatch");
|
||||||
|
|
||||||
RISCVVLMUL IndexLMUL = RISCVTargetLowering::getLMUL(IndexVT);
|
RISCVII::VLMUL IndexLMUL = RISCVTargetLowering::getLMUL(IndexVT);
|
||||||
unsigned IndexScalarSize = IndexVT.getScalarSizeInBits();
|
unsigned IndexScalarSize = IndexVT.getScalarSizeInBits();
|
||||||
const RISCV::VLXSEGPseudo *P = RISCV::getVLXSEGPseudo(
|
const RISCV::VLXSEGPseudo *P = RISCV::getVLXSEGPseudo(
|
||||||
NF, IsMasked, IsOrdered, IndexScalarSize, static_cast<unsigned>(LMUL),
|
NF, IsMasked, IsOrdered, IndexScalarSize, static_cast<unsigned>(LMUL),
|
||||||
|
@ -302,7 +302,7 @@ void RISCVDAGToDAGISel::selectVSSEG(SDNode *Node, bool IsMasked,
|
||||||
NF--;
|
NF--;
|
||||||
MVT VT = Node->getOperand(2)->getSimpleValueType(0);
|
MVT VT = Node->getOperand(2)->getSimpleValueType(0);
|
||||||
unsigned ScalarSize = VT.getScalarSizeInBits();
|
unsigned ScalarSize = VT.getScalarSizeInBits();
|
||||||
RISCVVLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
RISCVII::VLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
||||||
SmallVector<SDValue, 8> Regs(Node->op_begin() + 2, Node->op_begin() + 2 + NF);
|
SmallVector<SDValue, 8> Regs(Node->op_begin() + 2, Node->op_begin() + 2 + NF);
|
||||||
SDValue StoreVal = createTuple(*CurDAG, Regs, NF, LMUL);
|
SDValue StoreVal = createTuple(*CurDAG, Regs, NF, LMUL);
|
||||||
|
|
||||||
|
@ -332,7 +332,7 @@ void RISCVDAGToDAGISel::selectVSXSEG(SDNode *Node, bool IsMasked,
|
||||||
--NF;
|
--NF;
|
||||||
MVT VT = Node->getOperand(2)->getSimpleValueType(0);
|
MVT VT = Node->getOperand(2)->getSimpleValueType(0);
|
||||||
unsigned ScalarSize = VT.getScalarSizeInBits();
|
unsigned ScalarSize = VT.getScalarSizeInBits();
|
||||||
RISCVVLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
RISCVII::VLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
||||||
SmallVector<SDValue, 8> Regs(Node->op_begin() + 2, Node->op_begin() + 2 + NF);
|
SmallVector<SDValue, 8> Regs(Node->op_begin() + 2, Node->op_begin() + 2 + NF);
|
||||||
SDValue StoreVal = createTuple(*CurDAG, Regs, NF, LMUL);
|
SDValue StoreVal = createTuple(*CurDAG, Regs, NF, LMUL);
|
||||||
|
|
||||||
|
@ -347,7 +347,7 @@ void RISCVDAGToDAGISel::selectVSXSEG(SDNode *Node, bool IsMasked,
|
||||||
assert(VT.getVectorElementCount() == IndexVT.getVectorElementCount() &&
|
assert(VT.getVectorElementCount() == IndexVT.getVectorElementCount() &&
|
||||||
"Element count mismatch");
|
"Element count mismatch");
|
||||||
|
|
||||||
RISCVVLMUL IndexLMUL = RISCVTargetLowering::getLMUL(IndexVT);
|
RISCVII::VLMUL IndexLMUL = RISCVTargetLowering::getLMUL(IndexVT);
|
||||||
unsigned IndexScalarSize = IndexVT.getScalarSizeInBits();
|
unsigned IndexScalarSize = IndexVT.getScalarSizeInBits();
|
||||||
const RISCV::VSXSEGPseudo *P = RISCV::getVSXSEGPseudo(
|
const RISCV::VSXSEGPseudo *P = RISCV::getVSXSEGPseudo(
|
||||||
NF, IsMasked, IsOrdered, IndexScalarSize, static_cast<unsigned>(LMUL),
|
NF, IsMasked, IsOrdered, IndexScalarSize, static_cast<unsigned>(LMUL),
|
||||||
|
@ -455,37 +455,37 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
switch (RISCVTargetLowering::getLMUL(Src1VT)) {
|
switch (RISCVTargetLowering::getLMUL(Src1VT)) {
|
||||||
default:
|
default:
|
||||||
llvm_unreachable("Unexpected LMUL!");
|
llvm_unreachable("Unexpected LMUL!");
|
||||||
case RISCVVLMUL::LMUL_F8:
|
case RISCVII::VLMUL::LMUL_F8:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF8 : RISCV::PseudoVMSLT_VX_MF8;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF8 : RISCV::PseudoVMSLT_VX_MF8;
|
||||||
VMNANDOpcode = RISCV::PseudoVMNAND_MM_MF8;
|
VMNANDOpcode = RISCV::PseudoVMNAND_MM_MF8;
|
||||||
break;
|
break;
|
||||||
case RISCVVLMUL::LMUL_F4:
|
case RISCVII::VLMUL::LMUL_F4:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF4 : RISCV::PseudoVMSLT_VX_MF4;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF4 : RISCV::PseudoVMSLT_VX_MF4;
|
||||||
VMNANDOpcode = RISCV::PseudoVMNAND_MM_MF4;
|
VMNANDOpcode = RISCV::PseudoVMNAND_MM_MF4;
|
||||||
break;
|
break;
|
||||||
case RISCVVLMUL::LMUL_F2:
|
case RISCVII::VLMUL::LMUL_F2:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF2 : RISCV::PseudoVMSLT_VX_MF2;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF2 : RISCV::PseudoVMSLT_VX_MF2;
|
||||||
VMNANDOpcode = RISCV::PseudoVMNAND_MM_MF2;
|
VMNANDOpcode = RISCV::PseudoVMNAND_MM_MF2;
|
||||||
break;
|
break;
|
||||||
case RISCVVLMUL::LMUL_1:
|
case RISCVII::VLMUL::LMUL_1:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M1 : RISCV::PseudoVMSLT_VX_M1;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M1 : RISCV::PseudoVMSLT_VX_M1;
|
||||||
VMNANDOpcode = RISCV::PseudoVMNAND_MM_M1;
|
VMNANDOpcode = RISCV::PseudoVMNAND_MM_M1;
|
||||||
break;
|
break;
|
||||||
case RISCVVLMUL::LMUL_2:
|
case RISCVII::VLMUL::LMUL_2:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M2 : RISCV::PseudoVMSLT_VX_M2;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M2 : RISCV::PseudoVMSLT_VX_M2;
|
||||||
VMNANDOpcode = RISCV::PseudoVMNAND_MM_M2;
|
VMNANDOpcode = RISCV::PseudoVMNAND_MM_M2;
|
||||||
break;
|
break;
|
||||||
case RISCVVLMUL::LMUL_4:
|
case RISCVII::VLMUL::LMUL_4:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M4 : RISCV::PseudoVMSLT_VX_M4;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M4 : RISCV::PseudoVMSLT_VX_M4;
|
||||||
VMNANDOpcode = RISCV::PseudoVMNAND_MM_M4;
|
VMNANDOpcode = RISCV::PseudoVMNAND_MM_M4;
|
||||||
break;
|
break;
|
||||||
case RISCVVLMUL::LMUL_8:
|
case RISCVII::VLMUL::LMUL_8:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M8 : RISCV::PseudoVMSLT_VX_M8;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M8 : RISCV::PseudoVMSLT_VX_M8;
|
||||||
VMNANDOpcode = RISCV::PseudoVMNAND_MM_M8;
|
VMNANDOpcode = RISCV::PseudoVMNAND_MM_M8;
|
||||||
|
@ -524,7 +524,7 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
switch (RISCVTargetLowering::getLMUL(Src1VT)) {
|
switch (RISCVTargetLowering::getLMUL(Src1VT)) {
|
||||||
default:
|
default:
|
||||||
llvm_unreachable("Unexpected LMUL!");
|
llvm_unreachable("Unexpected LMUL!");
|
||||||
case RISCVVLMUL::LMUL_F8:
|
case RISCVII::VLMUL::LMUL_F8:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF8 : RISCV::PseudoVMSLT_VX_MF8;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF8 : RISCV::PseudoVMSLT_VX_MF8;
|
||||||
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF8_MASK
|
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF8_MASK
|
||||||
|
@ -532,7 +532,7 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
VMXOROpcode = RISCV::PseudoVMXOR_MM_MF8;
|
VMXOROpcode = RISCV::PseudoVMXOR_MM_MF8;
|
||||||
VMANDNOTOpcode = RISCV::PseudoVMANDNOT_MM_MF8;
|
VMANDNOTOpcode = RISCV::PseudoVMANDNOT_MM_MF8;
|
||||||
break;
|
break;
|
||||||
case RISCVVLMUL::LMUL_F4:
|
case RISCVII::VLMUL::LMUL_F4:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF4 : RISCV::PseudoVMSLT_VX_MF4;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF4 : RISCV::PseudoVMSLT_VX_MF4;
|
||||||
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF4_MASK
|
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF4_MASK
|
||||||
|
@ -540,7 +540,7 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
VMXOROpcode = RISCV::PseudoVMXOR_MM_MF4;
|
VMXOROpcode = RISCV::PseudoVMXOR_MM_MF4;
|
||||||
VMANDNOTOpcode = RISCV::PseudoVMANDNOT_MM_MF4;
|
VMANDNOTOpcode = RISCV::PseudoVMANDNOT_MM_MF4;
|
||||||
break;
|
break;
|
||||||
case RISCVVLMUL::LMUL_F2:
|
case RISCVII::VLMUL::LMUL_F2:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF2 : RISCV::PseudoVMSLT_VX_MF2;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF2 : RISCV::PseudoVMSLT_VX_MF2;
|
||||||
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF2_MASK
|
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_MF2_MASK
|
||||||
|
@ -548,7 +548,7 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
VMXOROpcode = RISCV::PseudoVMXOR_MM_MF2;
|
VMXOROpcode = RISCV::PseudoVMXOR_MM_MF2;
|
||||||
VMANDNOTOpcode = RISCV::PseudoVMANDNOT_MM_MF2;
|
VMANDNOTOpcode = RISCV::PseudoVMANDNOT_MM_MF2;
|
||||||
break;
|
break;
|
||||||
case RISCVVLMUL::LMUL_1:
|
case RISCVII::VLMUL::LMUL_1:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M1 : RISCV::PseudoVMSLT_VX_M1;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M1 : RISCV::PseudoVMSLT_VX_M1;
|
||||||
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_M1_MASK
|
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_M1_MASK
|
||||||
|
@ -556,7 +556,7 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
VMXOROpcode = RISCV::PseudoVMXOR_MM_M1;
|
VMXOROpcode = RISCV::PseudoVMXOR_MM_M1;
|
||||||
VMANDNOTOpcode = RISCV::PseudoVMANDNOT_MM_M1;
|
VMANDNOTOpcode = RISCV::PseudoVMANDNOT_MM_M1;
|
||||||
break;
|
break;
|
||||||
case RISCVVLMUL::LMUL_2:
|
case RISCVII::VLMUL::LMUL_2:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M2 : RISCV::PseudoVMSLT_VX_M2;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M2 : RISCV::PseudoVMSLT_VX_M2;
|
||||||
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_M2_MASK
|
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_M2_MASK
|
||||||
|
@ -564,7 +564,7 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
VMXOROpcode = RISCV::PseudoVMXOR_MM_M2;
|
VMXOROpcode = RISCV::PseudoVMXOR_MM_M2;
|
||||||
VMANDNOTOpcode = RISCV::PseudoVMANDNOT_MM_M2;
|
VMANDNOTOpcode = RISCV::PseudoVMANDNOT_MM_M2;
|
||||||
break;
|
break;
|
||||||
case RISCVVLMUL::LMUL_4:
|
case RISCVII::VLMUL::LMUL_4:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M4 : RISCV::PseudoVMSLT_VX_M4;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M4 : RISCV::PseudoVMSLT_VX_M4;
|
||||||
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_M4_MASK
|
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_M4_MASK
|
||||||
|
@ -572,7 +572,7 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
VMXOROpcode = RISCV::PseudoVMXOR_MM_M4;
|
VMXOROpcode = RISCV::PseudoVMXOR_MM_M4;
|
||||||
VMANDNOTOpcode = RISCV::PseudoVMANDNOT_MM_M4;
|
VMANDNOTOpcode = RISCV::PseudoVMANDNOT_MM_M4;
|
||||||
break;
|
break;
|
||||||
case RISCVVLMUL::LMUL_8:
|
case RISCVII::VLMUL::LMUL_8:
|
||||||
VMSLTOpcode =
|
VMSLTOpcode =
|
||||||
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M8 : RISCV::PseudoVMSLT_VX_M8;
|
IsUnsigned ? RISCV::PseudoVMSLTU_VX_M8 : RISCV::PseudoVMSLT_VX_M8;
|
||||||
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_M8_MASK
|
VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_M8_MASK
|
||||||
|
@ -630,9 +630,9 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
assert(Node->getNumOperands() == Offset + 2 &&
|
assert(Node->getNumOperands() == Offset + 2 &&
|
||||||
"Unexpected number of operands");
|
"Unexpected number of operands");
|
||||||
|
|
||||||
RISCVVSEW VSEW =
|
RISCVII::VSEW VSEW =
|
||||||
static_cast<RISCVVSEW>(Node->getConstantOperandVal(Offset) & 0x7);
|
static_cast<RISCVII::VSEW>(Node->getConstantOperandVal(Offset) & 0x7);
|
||||||
RISCVVLMUL VLMul = static_cast<RISCVVLMUL>(
|
RISCVII::VLMUL VLMul = static_cast<RISCVII::VLMUL>(
|
||||||
Node->getConstantOperandVal(Offset + 1) & 0x7);
|
Node->getConstantOperandVal(Offset + 1) & 0x7);
|
||||||
|
|
||||||
unsigned VTypeI = RISCVVType::encodeVTYPE(
|
unsigned VTypeI = RISCVVType::encodeVTYPE(
|
||||||
|
@ -785,8 +785,8 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
assert(VT.getVectorElementCount() == IndexVT.getVectorElementCount() &&
|
assert(VT.getVectorElementCount() == IndexVT.getVectorElementCount() &&
|
||||||
"Element count mismatch");
|
"Element count mismatch");
|
||||||
|
|
||||||
RISCVVLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
RISCVII::VLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
||||||
RISCVVLMUL IndexLMUL = RISCVTargetLowering::getLMUL(IndexVT);
|
RISCVII::VLMUL IndexLMUL = RISCVTargetLowering::getLMUL(IndexVT);
|
||||||
unsigned IndexScalarSize = IndexVT.getScalarSizeInBits();
|
unsigned IndexScalarSize = IndexVT.getScalarSizeInBits();
|
||||||
const RISCV::VLX_VSXPseudo *P = RISCV::getVLXPseudo(
|
const RISCV::VLX_VSXPseudo *P = RISCV::getVLXPseudo(
|
||||||
IsMasked, IsOrdered, IndexScalarSize, static_cast<unsigned>(LMUL),
|
IsMasked, IsOrdered, IndexScalarSize, static_cast<unsigned>(LMUL),
|
||||||
|
@ -823,7 +823,7 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
addVectorLoadStoreOperands(Node, SEW, DL, CurOp, IsMasked, IsStrided,
|
addVectorLoadStoreOperands(Node, SEW, DL, CurOp, IsMasked, IsStrided,
|
||||||
Operands);
|
Operands);
|
||||||
|
|
||||||
RISCVVLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
RISCVII::VLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
||||||
const RISCV::VLEPseudo *P =
|
const RISCV::VLEPseudo *P =
|
||||||
RISCV::getVLEPseudo(IsMasked, IsStrided, /*FF*/ false, ScalarSize,
|
RISCV::getVLEPseudo(IsMasked, IsStrided, /*FF*/ false, ScalarSize,
|
||||||
static_cast<unsigned>(LMUL));
|
static_cast<unsigned>(LMUL));
|
||||||
|
@ -851,7 +851,7 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
addVectorLoadStoreOperands(Node, ScalarSize, DL, CurOp, IsMasked,
|
addVectorLoadStoreOperands(Node, ScalarSize, DL, CurOp, IsMasked,
|
||||||
/*IsStridedOrIndexed*/ false, Operands);
|
/*IsStridedOrIndexed*/ false, Operands);
|
||||||
|
|
||||||
RISCVVLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
RISCVII::VLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
||||||
const RISCV::VLEPseudo *P =
|
const RISCV::VLEPseudo *P =
|
||||||
RISCV::getVLEPseudo(IsMasked, /*Strided*/ false, /*FF*/ true,
|
RISCV::getVLEPseudo(IsMasked, /*Strided*/ false, /*FF*/ true,
|
||||||
ScalarSize, static_cast<unsigned>(LMUL));
|
ScalarSize, static_cast<unsigned>(LMUL));
|
||||||
|
@ -976,8 +976,8 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
assert(VT.getVectorElementCount() == IndexVT.getVectorElementCount() &&
|
assert(VT.getVectorElementCount() == IndexVT.getVectorElementCount() &&
|
||||||
"Element count mismatch");
|
"Element count mismatch");
|
||||||
|
|
||||||
RISCVVLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
RISCVII::VLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
||||||
RISCVVLMUL IndexLMUL = RISCVTargetLowering::getLMUL(IndexVT);
|
RISCVII::VLMUL IndexLMUL = RISCVTargetLowering::getLMUL(IndexVT);
|
||||||
unsigned IndexScalarSize = IndexVT.getScalarSizeInBits();
|
unsigned IndexScalarSize = IndexVT.getScalarSizeInBits();
|
||||||
const RISCV::VLX_VSXPseudo *P = RISCV::getVSXPseudo(
|
const RISCV::VLX_VSXPseudo *P = RISCV::getVSXPseudo(
|
||||||
IsMasked, IsOrdered, IndexScalarSize, static_cast<unsigned>(LMUL),
|
IsMasked, IsOrdered, IndexScalarSize, static_cast<unsigned>(LMUL),
|
||||||
|
@ -1013,7 +1013,7 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
addVectorLoadStoreOperands(Node, SEW, DL, CurOp, IsMasked, IsStrided,
|
addVectorLoadStoreOperands(Node, SEW, DL, CurOp, IsMasked, IsStrided,
|
||||||
Operands);
|
Operands);
|
||||||
|
|
||||||
RISCVVLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
RISCVII::VLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
||||||
const RISCV::VSEPseudo *P = RISCV::getVSEPseudo(
|
const RISCV::VSEPseudo *P = RISCV::getVSEPseudo(
|
||||||
IsMasked, IsStrided, ScalarSize, static_cast<unsigned>(LMUL));
|
IsMasked, IsStrided, ScalarSize, static_cast<unsigned>(LMUL));
|
||||||
MachineSDNode *Store =
|
MachineSDNode *Store =
|
||||||
|
@ -1066,10 +1066,10 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
if (Idx != 0)
|
if (Idx != 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
RISCVVLMUL SubVecLMUL = RISCVTargetLowering::getLMUL(SubVecContainerVT);
|
RISCVII::VLMUL SubVecLMUL = RISCVTargetLowering::getLMUL(SubVecContainerVT);
|
||||||
bool IsSubVecPartReg = SubVecLMUL == RISCVVLMUL::LMUL_F2 ||
|
bool IsSubVecPartReg = SubVecLMUL == RISCVII::VLMUL::LMUL_F2 ||
|
||||||
SubVecLMUL == RISCVVLMUL::LMUL_F4 ||
|
SubVecLMUL == RISCVII::VLMUL::LMUL_F4 ||
|
||||||
SubVecLMUL == RISCVVLMUL::LMUL_F8;
|
SubVecLMUL == RISCVII::VLMUL::LMUL_F8;
|
||||||
(void)IsSubVecPartReg; // Silence unused variable warning without asserts.
|
(void)IsSubVecPartReg; // Silence unused variable warning without asserts.
|
||||||
assert((!IsSubVecPartReg || V.isUndef()) &&
|
assert((!IsSubVecPartReg || V.isUndef()) &&
|
||||||
"Expecting lowering to have created legal INSERT_SUBVECTORs when "
|
"Expecting lowering to have created legal INSERT_SUBVECTORs when "
|
||||||
|
@ -1162,7 +1162,7 @@ void RISCVDAGToDAGISel::Select(SDNode *Node) {
|
||||||
CurDAG->getRegister(RISCV::X0, XLenVT), VL, SEW,
|
CurDAG->getRegister(RISCV::X0, XLenVT), VL, SEW,
|
||||||
Ld->getChain()};
|
Ld->getChain()};
|
||||||
|
|
||||||
RISCVVLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
RISCVII::VLMUL LMUL = RISCVTargetLowering::getLMUL(VT);
|
||||||
const RISCV::VLEPseudo *P = RISCV::getVLEPseudo(
|
const RISCV::VLEPseudo *P = RISCV::getVLEPseudo(
|
||||||
/*IsMasked*/ false, /*IsStrided*/ true, /*FF*/ false, ScalarSize,
|
/*IsMasked*/ false, /*IsStrided*/ true, /*FF*/ false, ScalarSize,
|
||||||
static_cast<unsigned>(LMUL));
|
static_cast<unsigned>(LMUL));
|
||||||
|
|
|
@ -1033,7 +1033,7 @@ static unsigned getBranchOpcodeForIntCondCode(ISD::CondCode CC) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
RISCVVLMUL RISCVTargetLowering::getLMUL(MVT VT) {
|
RISCVII::VLMUL RISCVTargetLowering::getLMUL(MVT VT) {
|
||||||
assert(VT.isScalableVector() && "Expecting a scalable vector type");
|
assert(VT.isScalableVector() && "Expecting a scalable vector type");
|
||||||
unsigned KnownSize = VT.getSizeInBits().getKnownMinValue();
|
unsigned KnownSize = VT.getSizeInBits().getKnownMinValue();
|
||||||
if (VT.getVectorElementType() == MVT::i1)
|
if (VT.getVectorElementType() == MVT::i1)
|
||||||
|
@ -1043,54 +1043,56 @@ RISCVVLMUL RISCVTargetLowering::getLMUL(MVT VT) {
|
||||||
default:
|
default:
|
||||||
llvm_unreachable("Invalid LMUL.");
|
llvm_unreachable("Invalid LMUL.");
|
||||||
case 8:
|
case 8:
|
||||||
return RISCVVLMUL::LMUL_F8;
|
return RISCVII::VLMUL::LMUL_F8;
|
||||||
case 16:
|
case 16:
|
||||||
return RISCVVLMUL::LMUL_F4;
|
return RISCVII::VLMUL::LMUL_F4;
|
||||||
case 32:
|
case 32:
|
||||||
return RISCVVLMUL::LMUL_F2;
|
return RISCVII::VLMUL::LMUL_F2;
|
||||||
case 64:
|
case 64:
|
||||||
return RISCVVLMUL::LMUL_1;
|
return RISCVII::VLMUL::LMUL_1;
|
||||||
case 128:
|
case 128:
|
||||||
return RISCVVLMUL::LMUL_2;
|
return RISCVII::VLMUL::LMUL_2;
|
||||||
case 256:
|
case 256:
|
||||||
return RISCVVLMUL::LMUL_4;
|
return RISCVII::VLMUL::LMUL_4;
|
||||||
case 512:
|
case 512:
|
||||||
return RISCVVLMUL::LMUL_8;
|
return RISCVII::VLMUL::LMUL_8;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned RISCVTargetLowering::getRegClassIDForLMUL(RISCVVLMUL LMul) {
|
unsigned RISCVTargetLowering::getRegClassIDForLMUL(RISCVII::VLMUL LMul) {
|
||||||
switch (LMul) {
|
switch (LMul) {
|
||||||
default:
|
default:
|
||||||
llvm_unreachable("Invalid LMUL.");
|
llvm_unreachable("Invalid LMUL.");
|
||||||
case RISCVVLMUL::LMUL_F8:
|
case RISCVII::VLMUL::LMUL_F8:
|
||||||
case RISCVVLMUL::LMUL_F4:
|
case RISCVII::VLMUL::LMUL_F4:
|
||||||
case RISCVVLMUL::LMUL_F2:
|
case RISCVII::VLMUL::LMUL_F2:
|
||||||
case RISCVVLMUL::LMUL_1:
|
case RISCVII::VLMUL::LMUL_1:
|
||||||
return RISCV::VRRegClassID;
|
return RISCV::VRRegClassID;
|
||||||
case RISCVVLMUL::LMUL_2:
|
case RISCVII::VLMUL::LMUL_2:
|
||||||
return RISCV::VRM2RegClassID;
|
return RISCV::VRM2RegClassID;
|
||||||
case RISCVVLMUL::LMUL_4:
|
case RISCVII::VLMUL::LMUL_4:
|
||||||
return RISCV::VRM4RegClassID;
|
return RISCV::VRM4RegClassID;
|
||||||
case RISCVVLMUL::LMUL_8:
|
case RISCVII::VLMUL::LMUL_8:
|
||||||
return RISCV::VRM8RegClassID;
|
return RISCV::VRM8RegClassID;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned RISCVTargetLowering::getSubregIndexByMVT(MVT VT, unsigned Index) {
|
unsigned RISCVTargetLowering::getSubregIndexByMVT(MVT VT, unsigned Index) {
|
||||||
RISCVVLMUL LMUL = getLMUL(VT);
|
RISCVII::VLMUL LMUL = getLMUL(VT);
|
||||||
if (LMUL == RISCVVLMUL::LMUL_F8 || LMUL == RISCVVLMUL::LMUL_F4 ||
|
if (LMUL == RISCVII::VLMUL::LMUL_F8 ||
|
||||||
LMUL == RISCVVLMUL::LMUL_F2 || LMUL == RISCVVLMUL::LMUL_1) {
|
LMUL == RISCVII::VLMUL::LMUL_F4 ||
|
||||||
|
LMUL == RISCVII::VLMUL::LMUL_F2 ||
|
||||||
|
LMUL == RISCVII::VLMUL::LMUL_1) {
|
||||||
static_assert(RISCV::sub_vrm1_7 == RISCV::sub_vrm1_0 + 7,
|
static_assert(RISCV::sub_vrm1_7 == RISCV::sub_vrm1_0 + 7,
|
||||||
"Unexpected subreg numbering");
|
"Unexpected subreg numbering");
|
||||||
return RISCV::sub_vrm1_0 + Index;
|
return RISCV::sub_vrm1_0 + Index;
|
||||||
}
|
}
|
||||||
if (LMUL == RISCVVLMUL::LMUL_2) {
|
if (LMUL == RISCVII::VLMUL::LMUL_2) {
|
||||||
static_assert(RISCV::sub_vrm2_3 == RISCV::sub_vrm2_0 + 3,
|
static_assert(RISCV::sub_vrm2_3 == RISCV::sub_vrm2_0 + 3,
|
||||||
"Unexpected subreg numbering");
|
"Unexpected subreg numbering");
|
||||||
return RISCV::sub_vrm2_0 + Index;
|
return RISCV::sub_vrm2_0 + Index;
|
||||||
}
|
}
|
||||||
if (LMUL == RISCVVLMUL::LMUL_4) {
|
if (LMUL == RISCVII::VLMUL::LMUL_4) {
|
||||||
static_assert(RISCV::sub_vrm4_1 == RISCV::sub_vrm4_0 + 1,
|
static_assert(RISCV::sub_vrm4_1 == RISCV::sub_vrm4_0 + 1,
|
||||||
"Unexpected subreg numbering");
|
"Unexpected subreg numbering");
|
||||||
return RISCV::sub_vrm4_0 + Index;
|
return RISCV::sub_vrm4_0 + Index;
|
||||||
|
@ -3721,10 +3723,10 @@ SDValue RISCVTargetLowering::lowerINSERT_SUBVECTOR(SDValue Op,
|
||||||
RISCVTargetLowering::decomposeSubvectorInsertExtractToSubRegs(
|
RISCVTargetLowering::decomposeSubvectorInsertExtractToSubRegs(
|
||||||
VecVT, SubVecVT, OrigIdx, TRI);
|
VecVT, SubVecVT, OrigIdx, TRI);
|
||||||
|
|
||||||
RISCVVLMUL SubVecLMUL = RISCVTargetLowering::getLMUL(SubVecVT);
|
RISCVII::VLMUL SubVecLMUL = RISCVTargetLowering::getLMUL(SubVecVT);
|
||||||
bool IsSubVecPartReg = SubVecLMUL == RISCVVLMUL::LMUL_F2 ||
|
bool IsSubVecPartReg = SubVecLMUL == RISCVII::VLMUL::LMUL_F2 ||
|
||||||
SubVecLMUL == RISCVVLMUL::LMUL_F4 ||
|
SubVecLMUL == RISCVII::VLMUL::LMUL_F4 ||
|
||||||
SubVecLMUL == RISCVVLMUL::LMUL_F8;
|
SubVecLMUL == RISCVII::VLMUL::LMUL_F8;
|
||||||
|
|
||||||
// 1. If the Idx has been completely eliminated and this subvector's size is
|
// 1. If the Idx has been completely eliminated and this subvector's size is
|
||||||
// a vector register or a multiple thereof, or the surrounding elements are
|
// a vector register or a multiple thereof, or the surrounding elements are
|
||||||
|
@ -6447,14 +6449,15 @@ static MachineInstr *elideCopies(MachineInstr *MI,
|
||||||
|
|
||||||
static MachineBasicBlock *addVSetVL(MachineInstr &MI, MachineBasicBlock *BB,
|
static MachineBasicBlock *addVSetVL(MachineInstr &MI, MachineBasicBlock *BB,
|
||||||
int VLIndex, unsigned SEWIndex,
|
int VLIndex, unsigned SEWIndex,
|
||||||
RISCVVLMUL VLMul, bool ForceTailAgnostic) {
|
RISCVII::VLMUL VLMul,
|
||||||
|
bool ForceTailAgnostic) {
|
||||||
MachineFunction &MF = *BB->getParent();
|
MachineFunction &MF = *BB->getParent();
|
||||||
DebugLoc DL = MI.getDebugLoc();
|
DebugLoc DL = MI.getDebugLoc();
|
||||||
const TargetInstrInfo &TII = *MF.getSubtarget().getInstrInfo();
|
const TargetInstrInfo &TII = *MF.getSubtarget().getInstrInfo();
|
||||||
|
|
||||||
unsigned Log2SEW = MI.getOperand(SEWIndex).getImm();
|
unsigned Log2SEW = MI.getOperand(SEWIndex).getImm();
|
||||||
assert(RISCVVType::isValidSEW(1 << Log2SEW) && "Unexpected SEW");
|
assert(RISCVVType::isValidSEW(1 << Log2SEW) && "Unexpected SEW");
|
||||||
RISCVVSEW ElementWidth = static_cast<RISCVVSEW>(Log2SEW - 3);
|
RISCVII::VSEW ElementWidth = static_cast<RISCVII::VSEW>(Log2SEW - 3);
|
||||||
|
|
||||||
MachineRegisterInfo &MRI = MF.getRegInfo();
|
MachineRegisterInfo &MRI = MF.getRegInfo();
|
||||||
|
|
||||||
|
@ -6522,14 +6525,13 @@ RISCVTargetLowering::EmitInstrWithCustomInserter(MachineInstr &MI,
|
||||||
MachineBasicBlock *BB) const {
|
MachineBasicBlock *BB) const {
|
||||||
uint64_t TSFlags = MI.getDesc().TSFlags;
|
uint64_t TSFlags = MI.getDesc().TSFlags;
|
||||||
|
|
||||||
if (TSFlags & RISCVII::HasSEWOpMask) {
|
if (RISCVII::hasSEWOp(TSFlags)) {
|
||||||
unsigned NumOperands = MI.getNumExplicitOperands();
|
unsigned NumOperands = MI.getNumExplicitOperands();
|
||||||
int VLIndex = (TSFlags & RISCVII::HasVLOpMask) ? NumOperands - 2 : -1;
|
int VLIndex = RISCVII::hasVLOp(TSFlags) ? NumOperands - 2 : -1;
|
||||||
unsigned SEWIndex = NumOperands - 1;
|
unsigned SEWIndex = NumOperands - 1;
|
||||||
bool ForceTailAgnostic = TSFlags & RISCVII::ForceTailAgnosticMask;
|
bool ForceTailAgnostic = RISCVII::doesForceTailAgnostic(TSFlags);
|
||||||
|
|
||||||
RISCVVLMUL VLMul = static_cast<RISCVVLMUL>((TSFlags & RISCVII::VLMulMask) >>
|
RISCVII::VLMUL VLMul = RISCVII::getLMul(TSFlags);
|
||||||
RISCVII::VLMulShift);
|
|
||||||
return addVSetVL(MI, BB, VLIndex, SEWIndex, VLMul, ForceTailAgnostic);
|
return addVSetVL(MI, BB, VLIndex, SEWIndex, VLMul, ForceTailAgnostic);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -468,8 +468,8 @@ public:
|
||||||
MVT PartVT, EVT ValueVT,
|
MVT PartVT, EVT ValueVT,
|
||||||
Optional<CallingConv::ID> CC) const override;
|
Optional<CallingConv::ID> CC) const override;
|
||||||
|
|
||||||
static RISCVVLMUL getLMUL(MVT VT);
|
static RISCVII::VLMUL getLMUL(MVT VT);
|
||||||
static unsigned getRegClassIDForLMUL(RISCVVLMUL LMul);
|
static unsigned getRegClassIDForLMUL(RISCVII::VLMUL LMul);
|
||||||
static unsigned getSubregIndexByMVT(MVT VT, unsigned Index);
|
static unsigned getSubregIndexByMVT(MVT VT, unsigned Index);
|
||||||
static unsigned getRegClassIDForVecVT(MVT VT);
|
static unsigned getRegClassIDForVecVT(MVT VT);
|
||||||
static std::pair<unsigned, unsigned>
|
static std::pair<unsigned, unsigned>
|
||||||
|
|
|
@ -155,13 +155,13 @@ static bool lowerRISCVVMachineInstrToMCInst(const MachineInstr *MI,
|
||||||
assert(OpNo >= 0 && "Operand number doesn't fit in an 'int' type");
|
assert(OpNo >= 0 && "Operand number doesn't fit in an 'int' type");
|
||||||
|
|
||||||
// Skip VL and SEW operands which are the last two operands if present.
|
// Skip VL and SEW operands which are the last two operands if present.
|
||||||
if ((TSFlags & RISCVII::HasVLOpMask) && OpNo == (NumOps - 2))
|
if (RISCVII::hasVLOp(TSFlags) && OpNo == (NumOps - 2))
|
||||||
continue;
|
continue;
|
||||||
if ((TSFlags & RISCVII::HasSEWOpMask) && OpNo == (NumOps - 1))
|
if (RISCVII::hasSEWOp(TSFlags) && OpNo == (NumOps - 1))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
// Skip merge op. It should be the first operand after the result.
|
// Skip merge op. It should be the first operand after the result.
|
||||||
if ((TSFlags & RISCVII::HasMergeOpMask) && OpNo == 1) {
|
if (RISCVII::hasMergeOp(TSFlags) && OpNo == 1) {
|
||||||
assert(MI->getNumExplicitDefs() == 1);
|
assert(MI->getNumExplicitDefs() == 1);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -198,7 +198,7 @@ static bool lowerRISCVVMachineInstrToMCInst(const MachineInstr *MI,
|
||||||
|
|
||||||
// Unmasked pseudo instructions need to append dummy mask operand to
|
// Unmasked pseudo instructions need to append dummy mask operand to
|
||||||
// V instructions. All V instructions are modeled as the masked version.
|
// V instructions. All V instructions are modeled as the masked version.
|
||||||
if (TSFlags & RISCVII::HasDummyMaskOpMask)
|
if (RISCVII::hasDummyMaskOp(TSFlags))
|
||||||
OutMI.addOperand(MCOperand::createReg(RISCV::NoRegister));
|
OutMI.addOperand(MCOperand::createReg(RISCV::NoRegister));
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
Loading…
Reference in New Issue