diff --git a/llvm/include/llvm/CodeGen/BasicTTIImpl.h b/llvm/include/llvm/CodeGen/BasicTTIImpl.h --- a/llvm/include/llvm/CodeGen/BasicTTIImpl.h +++ b/llvm/include/llvm/CodeGen/BasicTTIImpl.h @@ -82,16 +82,17 @@ /// Estimate a cost of Broadcast as an extract and sequence of insert /// operations. unsigned getBroadcastShuffleOverhead(Type *Ty) { - assert(Ty->isVectorTy() && "Can only shuffle vectors"); + auto *VTy = dyn_cast(Ty); + assert(VTy && "Can only shuffle vectors"); unsigned Cost = 0; // Broadcast cost is equal to the cost of extracting the zero'th element // plus the cost of inserting it into every element of the result vector. Cost += static_cast(this)->getVectorInstrCost( - Instruction::ExtractElement, Ty, 0); + Instruction::ExtractElement, VTy, 0); - for (int i = 0, e = Ty->getVectorNumElements(); i < e; ++i) { + for (int i = 0, e = VTy->getNumElements(); i < e; ++i) { Cost += static_cast(this)->getVectorInstrCost( - Instruction::InsertElement, Ty, i); + Instruction::InsertElement, VTy, i); } return Cost; } @@ -99,7 +100,8 @@ /// Estimate a cost of shuffle as a sequence of extract and insert /// operations. unsigned getPermuteShuffleOverhead(Type *Ty) { - assert(Ty->isVectorTy() && "Can only shuffle vectors"); + auto *VTy = dyn_cast(Ty); + assert(VTy && "Can only shuffle vectors"); unsigned Cost = 0; // Shuffle cost is equal to the cost of extracting element from its argument // plus the cost of inserting them onto the result vector. @@ -108,11 +110,11 @@ // index 0 of first vector, index 1 of second vector,index 2 of first // vector and finally index 3 of second vector and insert them at index // <0,1,2,3> of result vector. - for (int i = 0, e = Ty->getVectorNumElements(); i < e; ++i) { - Cost += static_cast(this) - ->getVectorInstrCost(Instruction::InsertElement, Ty, i); - Cost += static_cast(this) - ->getVectorInstrCost(Instruction::ExtractElement, Ty, i); + for (int i = 0, e = VTy->getNumElements(); i < e; ++i) { + Cost += static_cast(this)->getVectorInstrCost( + Instruction::InsertElement, VTy, i); + Cost += static_cast(this)->getVectorInstrCost( + Instruction::ExtractElement, VTy, i); } return Cost; } @@ -122,8 +124,10 @@ unsigned getExtractSubvectorOverhead(Type *Ty, int Index, Type *SubTy) { assert(Ty && Ty->isVectorTy() && SubTy && SubTy->isVectorTy() && "Can only extract subvectors from vectors"); - int NumSubElts = SubTy->getVectorNumElements(); - assert((Index + NumSubElts) <= (int)Ty->getVectorNumElements() && + auto *VTy = cast(Ty); + auto *SubVTy = cast(SubTy); + int NumSubElts = SubVTy->getNumElements(); + assert((Index + NumSubElts) <= (int)VTy->getNumElements() && "SK_ExtractSubvector index out of range"); unsigned Cost = 0; @@ -132,9 +136,9 @@ // type. for (int i = 0; i != NumSubElts; ++i) { Cost += static_cast(this)->getVectorInstrCost( - Instruction::ExtractElement, Ty, i + Index); + Instruction::ExtractElement, VTy, i + Index); Cost += static_cast(this)->getVectorInstrCost( - Instruction::InsertElement, SubTy, i); + Instruction::InsertElement, SubVTy, i); } return Cost; } @@ -144,8 +148,10 @@ unsigned getInsertSubvectorOverhead(Type *Ty, int Index, Type *SubTy) { assert(Ty && Ty->isVectorTy() && SubTy && SubTy->isVectorTy() && "Can only insert subvectors into vectors"); - int NumSubElts = SubTy->getVectorNumElements(); - assert((Index + NumSubElts) <= (int)Ty->getVectorNumElements() && + auto *VTy = cast(Ty); + auto *SubVTy = cast(SubTy); + int NumSubElts = SubVTy->getNumElements(); + assert((Index + NumSubElts) <= (int)VTy->getNumElements() && "SK_InsertSubvector index out of range"); unsigned Cost = 0; @@ -154,9 +160,9 @@ // type. for (int i = 0; i != NumSubElts; ++i) { Cost += static_cast(this)->getVectorInstrCost( - Instruction::ExtractElement, SubTy, i); + Instruction::ExtractElement, SubVTy, i); Cost += static_cast(this)->getVectorInstrCost( - Instruction::InsertElement, Ty, i + Index); + Instruction::InsertElement, VTy, i + Index); } return Cost; } @@ -577,16 +583,17 @@ /// Estimate the overhead of scalarizing an instruction. Insert and Extract /// are set if the result needs to be inserted and/or extracted from vectors. unsigned getScalarizationOverhead(Type *Ty, bool Insert, bool Extract) { - assert(Ty->isVectorTy() && "Can only scalarize vectors"); + auto *VTy = dyn_cast(Ty); + assert(VTy && "Can only scalarize vectors"); unsigned Cost = 0; - for (int i = 0, e = Ty->getVectorNumElements(); i < e; ++i) { + for (int i = 0, e = VTy->getNumElements(); i < e; ++i) { if (Insert) - Cost += static_cast(this) - ->getVectorInstrCost(Instruction::InsertElement, Ty, i); + Cost += static_cast(this)->getVectorInstrCost( + Instruction::InsertElement, VTy, i); if (Extract) - Cost += static_cast(this) - ->getVectorInstrCost(Instruction::ExtractElement, Ty, i); + Cost += static_cast(this)->getVectorInstrCost( + Instruction::ExtractElement, VTy, i); } return Cost; @@ -605,7 +612,7 @@ if (A->getType()->isVectorTy()) { VecTy = A->getType(); // If A is a vector operand, VF should be 1 or correspond to A. - assert((VF == 1 || VF == VecTy->getVectorNumElements()) && + assert((VF == 1 || VF == cast(VecTy)->getNumElements()) && "Vector argument does not match VF"); } else @@ -619,18 +626,17 @@ } unsigned getScalarizationOverhead(Type *VecTy, ArrayRef Args) { - assert(VecTy->isVectorTy()); + auto *VecVTy = cast(VecTy); unsigned Cost = 0; - Cost += getScalarizationOverhead(VecTy, true, false); + Cost += getScalarizationOverhead(VecVTy, true, false); if (!Args.empty()) - Cost += getOperandsScalarizationOverhead(Args, - VecTy->getVectorNumElements()); + Cost += getOperandsScalarizationOverhead(Args, VecVTy->getNumElements()); else // When no information on arguments is provided, we add the cost // associated with one argument as a heuristic. - Cost += getScalarizationOverhead(VecTy, false, true); + Cost += getScalarizationOverhead(VecVTy, false, true); return Cost; } @@ -672,13 +678,13 @@ // Else, assume that we need to scalarize this op. // TODO: If one of the types get legalized by splitting, handle this // similarly to what getCastInstrCost() does. - if (Ty->isVectorTy()) { - unsigned Num = Ty->getVectorNumElements(); - unsigned Cost = static_cast(this) - ->getArithmeticInstrCost(Opcode, Ty->getScalarType()); + if (auto VTy = dyn_cast(Ty)) { + unsigned Num = VTy->getNumElements(); + unsigned Cost = static_cast(this)->getArithmeticInstrCost( + Opcode, VTy->getScalarType()); // Return the cost of multiple scalar invocation plus the cost of // inserting and extracting the values. - return getScalarizationOverhead(Ty, Args) + Num * Cost; + return getScalarizationOverhead(VTy, Args) + Num * Cost; } // We don't know anything about this scalar instruction. @@ -773,6 +779,8 @@ // Check vector-to-vector casts. if (Dst->isVectorTy() && Src->isVectorTy()) { + auto *SrcVTy = cast(Src); + auto *DstVTy = cast(Dst); // If the cast is between same-sized registers, then the check is simple. if (SrcLT.first == DstLT.first && SrcLT.second.getSizeInBits() == DstLT.second.getSizeInBits()) { @@ -800,11 +808,11 @@ TargetLowering::TypeSplitVector || TLI->getTypeAction(Dst->getContext(), TLI->getValueType(DL, Dst)) == TargetLowering::TypeSplitVector) && - Src->getVectorNumElements() > 1 && Dst->getVectorNumElements() > 1) { - Type *SplitDst = VectorType::get(Dst->getVectorElementType(), - Dst->getVectorNumElements() / 2); - Type *SplitSrc = VectorType::get(Src->getVectorElementType(), - Src->getVectorNumElements() / 2); + SrcVTy->getNumElements() > 1 && DstVTy->getNumElements() > 1) { + Type *SplitDst = VectorType::get(DstVTy->getElementType(), + DstVTy->getNumElements() / 2); + Type *SplitSrc = VectorType::get(SrcVTy->getElementType(), + SrcVTy->getNumElements() / 2); T *TTI = static_cast(this); return TTI->getVectorSplitCost() + (2 * TTI->getCastInstrCost(Opcode, SplitDst, SplitSrc, I)); @@ -812,7 +820,7 @@ // In other cases where the source or destination are illegal, assume // the operation will get scalarized. - unsigned Num = Dst->getVectorNumElements(); + unsigned Num = DstVTy->getNumElements(); unsigned Cost = static_cast(this)->getCastInstrCost( Opcode, Dst->getScalarType(), Src->getScalarType(), I); @@ -872,16 +880,16 @@ // Otherwise, assume that the cast is scalarized. // TODO: If one of the types get legalized by splitting, handle this // similarly to what getCastInstrCost() does. - if (ValTy->isVectorTy()) { - unsigned Num = ValTy->getVectorNumElements(); + if (auto *ValVTy = dyn_cast(ValTy)) { + unsigned Num = ValVTy->getNumElements(); if (CondTy) CondTy = CondTy->getScalarType(); unsigned Cost = static_cast(this)->getCmpSelInstrCost( - Opcode, ValTy->getScalarType(), CondTy, I); + Opcode, ValVTy->getScalarType(), CondTy, I); // Return the cost of multiple scalar invocation plus the cost of // inserting and extracting the values. - return getScalarizationOverhead(ValTy, true, false) + Num * Cost; + return getScalarizationOverhead(ValVTy, true, false) + Num * Cost; } // Unknown scalar opcode. @@ -1087,7 +1095,8 @@ ArrayRef Args, FastMathFlags FMF, unsigned VF = 1, const Instruction *I = nullptr) { - unsigned RetVF = (RetTy->isVectorTy() ? RetTy->getVectorNumElements() : 1); + unsigned RetVF = + (RetTy->isVectorTy() ? cast(RetTy)->getNumElements() : 1); assert((RetVF == 1 || VF == 1) && "VF > 1 and RetVF is a vector type"); auto *ConcreteTTI = static_cast(this); @@ -1210,7 +1219,8 @@ if (RetTy->isVectorTy()) { if (ScalarizationCostPassed == std::numeric_limits::max()) ScalarizationCost = getScalarizationOverhead(RetTy, true, false); - ScalarCalls = std::max(ScalarCalls, RetTy->getVectorNumElements()); + ScalarCalls = std::max( + ScalarCalls, (unsigned)cast(RetTy)->getNumElements()); ScalarRetTy = RetTy->getScalarType(); } SmallVector ScalarTys; @@ -1219,7 +1229,8 @@ if (Ty->isVectorTy()) { if (ScalarizationCostPassed == std::numeric_limits::max()) ScalarizationCost += getScalarizationOverhead(Ty, false, true); - ScalarCalls = std::max(ScalarCalls, Ty->getVectorNumElements()); + ScalarCalls = std::max( + ScalarCalls, (unsigned)cast(Ty)->getNumElements()); Ty = Ty->getScalarType(); } ScalarTys.push_back(Ty); @@ -1551,7 +1562,7 @@ ((ScalarizationCostPassed != std::numeric_limits::max()) ? ScalarizationCostPassed : getScalarizationOverhead(RetTy, true, false)); - unsigned ScalarCalls = RetTy->getVectorNumElements(); + unsigned ScalarCalls = cast(RetTy)->getNumElements(); SmallVector ScalarTys; for (unsigned i = 0, ie = Tys.size(); i != ie; ++i) { Type *Ty = Tys[i]; @@ -1565,7 +1576,9 @@ if (Tys[i]->isVectorTy()) { if (ScalarizationCostPassed == std::numeric_limits::max()) ScalarizationCost += getScalarizationOverhead(Tys[i], false, true); - ScalarCalls = std::max(ScalarCalls, Tys[i]->getVectorNumElements()); + ScalarCalls = + std::max(ScalarCalls, + (unsigned)cast(Tys[i])->getNumElements()); } } @@ -1639,8 +1652,8 @@ unsigned getArithmeticReductionCost(unsigned Opcode, Type *Ty, bool IsPairwise) { assert(Ty->isVectorTy() && "Expect a vector type"); - Type *ScalarTy = Ty->getVectorElementType(); - unsigned NumVecElts = Ty->getVectorNumElements(); + Type *ScalarTy = cast(Ty)->getElementType(); + unsigned NumVecElts = cast(Ty)->getNumElements(); unsigned NumReduxLevels = Log2_32(NumVecElts); unsigned ArithCost = 0; unsigned ShuffleCost = 0; @@ -1689,9 +1702,9 @@ unsigned getMinMaxReductionCost(Type *Ty, Type *CondTy, bool IsPairwise, bool) { assert(Ty->isVectorTy() && "Expect a vector type"); - Type *ScalarTy = Ty->getVectorElementType(); - Type *ScalarCondTy = CondTy->getVectorElementType(); - unsigned NumVecElts = Ty->getVectorNumElements(); + Type *ScalarTy = cast(Ty)->getElementType(); + Type *ScalarCondTy = cast(CondTy)->getElementType(); + unsigned NumVecElts = cast(Ty)->getNumElements(); unsigned NumReduxLevels = Log2_32(NumVecElts); unsigned CmpOpcode; if (Ty->isFPOrFPVectorTy()) { diff --git a/llvm/lib/CodeGen/CodeGenPrepare.cpp b/llvm/lib/CodeGen/CodeGenPrepare.cpp --- a/llvm/lib/CodeGen/CodeGenPrepare.cpp +++ b/llvm/lib/CodeGen/CodeGenPrepare.cpp @@ -6577,7 +6577,7 @@ UseSplat = true; } - ElementCount EC = getTransitionType()->getVectorElementCount(); + ElementCount EC = cast(getTransitionType())->getElementCount(); if (UseSplat) return ConstantVector::getSplat(EC, Val); @@ -6840,7 +6840,7 @@ // whereas scalable vectors would have to be shifted by // <2log(vscale) + number of bits> in order to store the // low/high parts. Bailing out for now. - if (StoreType->isVectorTy() && StoreType->getVectorIsScalable()) + if (StoreType->isVectorTy() && cast(StoreType)->isScalable()) return false; if (!DL.typeSizeEqualsStoreSize(StoreType) || diff --git a/llvm/lib/CodeGen/ExpandReductions.cpp b/llvm/lib/CodeGen/ExpandReductions.cpp --- a/llvm/lib/CodeGen/ExpandReductions.cpp +++ b/llvm/lib/CodeGen/ExpandReductions.cpp @@ -125,7 +125,7 @@ if (!FMF.allowReassoc()) Rdx = getOrderedReduction(Builder, Acc, Vec, getOpcode(ID), MRK); else { - if (!isPowerOf2_32(Vec->getType()->getVectorNumElements())) + if (!isPowerOf2_32(cast(Vec->getType())->getNumElements())) continue; Rdx = getShuffleReduction(Builder, Vec, getOpcode(ID), MRK); @@ -146,7 +146,7 @@ case Intrinsic::experimental_vector_reduce_fmax: case Intrinsic::experimental_vector_reduce_fmin: { Value *Vec = II->getArgOperand(0); - if (!isPowerOf2_32(Vec->getType()->getVectorNumElements())) + if (!isPowerOf2_32(cast(Vec->getType())->getNumElements())) continue; Rdx = getShuffleReduction(Builder, Vec, getOpcode(ID), MRK); diff --git a/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp b/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp --- a/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp +++ b/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp @@ -1913,7 +1913,7 @@ MachineIRBuilder &MIRBuilder) { // If it is a <1 x Ty> vector, use the scalar as it is // not a legal vector type in LLT. - if (U.getType()->getVectorNumElements() == 1) { + if (cast(U.getType())->getNumElements() == 1) { Register Elt = getOrCreateVReg(*U.getOperand(1)); auto &Regs = *VMap.getVRegs(U); if (Regs.empty()) { @@ -1937,7 +1937,7 @@ MachineIRBuilder &MIRBuilder) { // If it is a <1 x Ty> vector, use the scalar as it is // not a legal vector type in LLT. - if (U.getOperand(0)->getType()->getVectorNumElements() == 1) { + if (cast(U.getOperand(0)->getType())->getNumElements() == 1) { Register Elt = getOrCreateVReg(*U.getOperand(0)); auto &Regs = *VMap.getVRegs(U); if (Regs.empty()) { diff --git a/llvm/lib/CodeGen/InterleavedAccessPass.cpp b/llvm/lib/CodeGen/InterleavedAccessPass.cpp --- a/llvm/lib/CodeGen/InterleavedAccessPass.cpp +++ b/llvm/lib/CodeGen/InterleavedAccessPass.cpp @@ -308,7 +308,7 @@ unsigned Factor, Index; - unsigned NumLoadElements = LI->getType()->getVectorNumElements(); + unsigned NumLoadElements = cast(LI->getType())->getNumElements(); // Check if the first shufflevector is DE-interleave shuffle. if (!isDeInterleaveMask(Shuffles[0]->getShuffleMask(), Factor, Index, MaxFactor, NumLoadElements)) @@ -426,7 +426,8 @@ // Check if the shufflevector is RE-interleave shuffle. unsigned Factor; - unsigned OpNumElts = SVI->getOperand(0)->getType()->getVectorNumElements(); + unsigned OpNumElts = + cast(SVI->getOperand(0)->getType())->getNumElements(); if (!isReInterleaveMask(SVI->getShuffleMask(), Factor, MaxFactor, OpNumElts)) return false; diff --git a/llvm/lib/CodeGen/ScalarizeMaskedMemIntrin.cpp b/llvm/lib/CodeGen/ScalarizeMaskedMemIntrin.cpp --- a/llvm/lib/CodeGen/ScalarizeMaskedMemIntrin.cpp +++ b/llvm/lib/CodeGen/ScalarizeMaskedMemIntrin.cpp @@ -82,7 +82,7 @@ if (!C) return false; - unsigned NumElts = Mask->getType()->getVectorNumElements(); + unsigned NumElts = cast(Mask->getType())->getNumElements(); for (unsigned i = 0; i != NumElts; ++i) { Constant *CElt = C->getAggregateElement(i); if (!CElt || !isa(CElt)) @@ -521,9 +521,10 @@ assert(isa(Src->getType()) && "Unexpected data type in masked scatter intrinsic"); - assert(isa(Ptrs->getType()) && - isa(Ptrs->getType()->getVectorElementType()) && - "Vector of pointers is expected in masked scatter intrinsic"); + assert( + isa(Ptrs->getType()) && + isa(cast(Ptrs->getType())->getElementType()) && + "Vector of pointers is expected in masked scatter intrinsic"); IRBuilder<> Builder(CI->getContext()); Instruction *InsertPt = CI; @@ -532,7 +533,7 @@ Builder.SetCurrentDebugLocation(CI->getDebugLoc()); MaybeAlign AlignVal(cast(Alignment)->getZExtValue()); - unsigned VectorWidth = Src->getType()->getVectorNumElements(); + unsigned VectorWidth = cast(Src->getType())->getNumElements(); // Shorten the way if the mask is a vector of constants. if (isConstantIntVector(Mask)) { @@ -725,7 +726,7 @@ Builder.SetInsertPoint(InsertPt); Builder.SetCurrentDebugLocation(CI->getDebugLoc()); - Type *EltTy = VecType->getVectorElementType(); + Type *EltTy = VecType->getElementType(); unsigned VectorWidth = VecType->getNumElements(); diff --git a/llvm/lib/CodeGen/SelectionDAG/FunctionLoweringInfo.cpp b/llvm/lib/CodeGen/SelectionDAG/FunctionLoweringInfo.cpp --- a/llvm/lib/CodeGen/SelectionDAG/FunctionLoweringInfo.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/FunctionLoweringInfo.cpp @@ -161,7 +161,7 @@ // Scalable vectors may need a special StackID to distinguish // them from other (fixed size) stack objects. - if (Ty->isVectorTy() && Ty->getVectorIsScalable()) + if (Ty->isVectorTy() && cast(Ty)->isScalable()) MF->getFrameInfo().setStackID(FrameIndex, TFI->getStackIDForScalableVectors()); diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp --- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp @@ -3741,8 +3741,9 @@ // Normalize Vector GEP - all scalar operands should be converted to the // splat vector. bool IsVectorGEP = I.getType()->isVectorTy(); - ElementCount VectorElementCount = IsVectorGEP ? - I.getType()->getVectorElementCount() : ElementCount(0, false); + ElementCount VectorElementCount = + IsVectorGEP ? cast(I.getType())->getElementCount() + : ElementCount(0, false); if (IsVectorGEP && !N.getValueType().isVector()) { LLVMContext &Context = *DAG.getContext(); @@ -4302,7 +4303,7 @@ IndexType = ISD::SIGNED_SCALED; if (STy || !Index.getValueType().isVector()) { - unsigned GEPWidth = GEP->getType()->getVectorNumElements(); + unsigned GEPWidth = cast(GEP->getType())->getNumElements(); EVT VT = EVT::getVectorVT(Context, Index.getValueType(), GEPWidth); Index = DAG.getSplatBuildVector(VT, SDLoc(Index), Index); } diff --git a/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp b/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp --- a/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp +++ b/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp @@ -1681,8 +1681,8 @@ return APIntToHexString(CI->getValue()); } else { unsigned NumElements; - if (isa(Ty)) - NumElements = Ty->getVectorNumElements(); + if (auto *VTy = dyn_cast(Ty)) + NumElements = VTy->getNumElements(); else NumElements = Ty->getArrayNumElements(); std::string HexString;