[llvm] [RISCV][CostModel] Updates reduction and shuffle cost (PR #77342)
Craig Topper via llvm-commits
llvm-commits at lists.llvm.org
Wed Jan 10 20:59:45 PST 2024
================
@@ -1392,20 +1426,58 @@ RISCVTTIImpl::getArithmeticReductionCost(unsigned Opcode, VectorType *Ty,
return BaseT::getArithmeticReductionCost(Opcode, Ty, FMF, CostKind);
std::pair<InstructionCost, MVT> LT = getTypeLegalizationCost(Ty);
- if (Ty->getElementType()->isIntegerTy(1))
+ SmallVector<unsigned, 3> Opcodes;
+ Type *ElementTy = Ty->getElementType();
+ if (ElementTy->isIntegerTy(1)) {
// vcpop sequences, see vreduction-mask.ll
- return (LT.first - 1) + (ISD == ISD::AND ? 3 : 2);
+ if (ISD == ISD::AND) {
+ Opcodes = {RISCV::VMNAND_MM, RISCV::VCPOP_M};
+ return (LT.first - 1) +
+ getRISCVInstructionCost(Opcodes, LT.second, CostKind) +
+ getCmpSelInstrCost(Instruction::Select, ElementTy, ElementTy,
----------------
topperc wrote:
Shouldn't this be Instruction::ICmp?
https://github.com/llvm/llvm-project/pull/77342
More information about the llvm-commits
mailing list