================ @@ -317,38 +323,60 @@ ABIArgInfo RISCVABIInfo::coerceAndExpandFPCCEligibleStruct( // Fixed-length RVV vectors are represented as scalable vectors in function // args/return and must be coerced from fixed vectors. -ABIArgInfo RISCVABIInfo::coerceVLSVector(QualType Ty) const { +ABIArgInfo RISCVABIInfo::coerceVLSVector(QualType Ty, + unsigned ArgABIVLen) const { assert(Ty->isVectorType() && "expected vector type!"); const auto *VT = Ty->castAs<VectorType>(); assert(VT->getElementType()->isBuiltinType() && "expected builtin type!"); - auto VScale = - getContext().getTargetInfo().getVScaleRange(getContext().getLangOpts()); - unsigned NumElts = VT->getNumElements(); - llvm::Type *EltType; - if (VT->getVectorKind() == VectorKind::RVVFixedLengthMask) { - NumElts *= 8; - EltType = llvm::Type::getInt1Ty(getVMContext()); + llvm::ScalableVectorType *ResType; + llvm::Type *EltType = CGT.ConvertType(VT->getElementType()); + + if (ArgABIVLen == 0) { + // RVV fixed-length vector + auto VScale = + getContext().getTargetInfo().getVScaleRange(getContext().getLangOpts()); + + if (VT->getVectorKind() == VectorKind::RVVFixedLengthMask) { + NumElts *= 8; + EltType = llvm::Type::getInt1Ty(getVMContext()); + } + + // The MinNumElts is simplified from equation: + // NumElts / VScale = + // (EltSize * NumElts / (VScale * RVVBitsPerBlock)) + // * (RVVBitsPerBlock / EltSize) + ResType = llvm::ScalableVectorType::get(EltType, NumElts / VScale->first); } else { - assert(VT->getVectorKind() == VectorKind::RVVFixedLengthData && - "Unexpected vector kind"); - EltType = CGT.ConvertType(VT->getElementType()); + // If the corresponding extension is not supported, just make it an i32 + // vector. + const TargetInfo &TI = getContext().getTargetInfo(); ---------------- 4vtomat wrote:
I think unless we pass `FunctionDecl` to `arrangeLLVMFunctionInfo` in `CodeGenTypes`, we are not able to know what's the function we are working on during `computeInfo`. https://github.com/llvm/llvm-project/pull/100346 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits