diff --git a/llvm/include/llvm/Analysis/TargetTransformInfo.h b/llvm/include/llvm/Analysis/TargetTransformInfo.h --- a/llvm/include/llvm/Analysis/TargetTransformInfo.h +++ b/llvm/include/llvm/Analysis/TargetTransformInfo.h @@ -1225,8 +1225,9 @@ /// The 'SE' parameter holds pointer for the scalar evolution object which /// is used in order to get the Ptr step value in case of constant stride. /// The 'Ptr' parameter holds SCEV of the access pointer. - int getAddressComputationCost(Type *Ty, ScalarEvolution *SE = nullptr, - const SCEV *Ptr = nullptr) const; + InstructionCost getAddressComputationCost(Type *Ty, + ScalarEvolution *SE = nullptr, + const SCEV *Ptr = nullptr) const; /// \returns The cost, if any, of keeping values of the given types alive /// over a callsite. @@ -1630,8 +1631,8 @@ ArrayRef Tys, TTI::TargetCostKind CostKind) = 0; virtual unsigned getNumberOfParts(Type *Tp) = 0; - virtual int getAddressComputationCost(Type *Ty, ScalarEvolution *SE, - const SCEV *Ptr) = 0; + virtual InstructionCost + getAddressComputationCost(Type *Ty, ScalarEvolution *SE, const SCEV *Ptr) = 0; virtual unsigned getCostOfKeepingLiveOverCall(ArrayRef Tys) = 0; virtual bool getTgtMemIntrinsic(IntrinsicInst *Inst, MemIntrinsicInfo &Info) = 0; @@ -2137,8 +2138,8 @@ unsigned getNumberOfParts(Type *Tp) override { return Impl.getNumberOfParts(Tp); } - int getAddressComputationCost(Type *Ty, ScalarEvolution *SE, - const SCEV *Ptr) override { + InstructionCost getAddressComputationCost(Type *Ty, ScalarEvolution *SE, + const SCEV *Ptr) override { return Impl.getAddressComputationCost(Ty, SE, Ptr); } unsigned getCostOfKeepingLiveOverCall(ArrayRef Tys) override { diff --git a/llvm/include/llvm/Analysis/TargetTransformInfoImpl.h b/llvm/include/llvm/Analysis/TargetTransformInfoImpl.h --- a/llvm/include/llvm/Analysis/TargetTransformInfoImpl.h +++ b/llvm/include/llvm/Analysis/TargetTransformInfoImpl.h @@ -611,8 +611,8 @@ unsigned getNumberOfParts(Type *Tp) const { return 0; } - unsigned getAddressComputationCost(Type *Tp, ScalarEvolution *, - const SCEV *) const { + InstructionCost getAddressComputationCost(Type *Tp, ScalarEvolution *, + const SCEV *) const { return 0; } 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 @@ -1896,8 +1896,8 @@ return LT.first; } - unsigned getAddressComputationCost(Type *Ty, ScalarEvolution *, - const SCEV *) { + InstructionCost getAddressComputationCost(Type *Ty, ScalarEvolution *, + const SCEV *) { return 0; } diff --git a/llvm/lib/Analysis/TargetTransformInfo.cpp b/llvm/lib/Analysis/TargetTransformInfo.cpp --- a/llvm/lib/Analysis/TargetTransformInfo.cpp +++ b/llvm/lib/Analysis/TargetTransformInfo.cpp @@ -877,10 +877,10 @@ return TTIImpl->getNumberOfParts(Tp); } -int TargetTransformInfo::getAddressComputationCost(Type *Tp, - ScalarEvolution *SE, - const SCEV *Ptr) const { - int Cost = TTIImpl->getAddressComputationCost(Tp, SE, Ptr); +InstructionCost +TargetTransformInfo::getAddressComputationCost(Type *Tp, ScalarEvolution *SE, + const SCEV *Ptr) const { + InstructionCost Cost = TTIImpl->getAddressComputationCost(Tp, SE, Ptr); assert(Cost >= 0 && "TTI should not produce negative costs!"); return Cost; } diff --git a/llvm/lib/Target/AArch64/AArch64TargetTransformInfo.h b/llvm/lib/Target/AArch64/AArch64TargetTransformInfo.h --- a/llvm/lib/Target/AArch64/AArch64TargetTransformInfo.h +++ b/llvm/lib/Target/AArch64/AArch64TargetTransformInfo.h @@ -166,7 +166,8 @@ ArrayRef Args = ArrayRef(), const Instruction *CxtI = nullptr); - int getAddressComputationCost(Type *Ty, ScalarEvolution *SE, const SCEV *Ptr); + InstructionCost getAddressComputationCost(Type *Ty, ScalarEvolution *SE, + const SCEV *Ptr); InstructionCost getCmpSelInstrCost(unsigned Opcode, Type *ValTy, Type *CondTy, CmpInst::Predicate VecPred, diff --git a/llvm/lib/Target/AArch64/AArch64TargetTransformInfo.cpp b/llvm/lib/Target/AArch64/AArch64TargetTransformInfo.cpp --- a/llvm/lib/Target/AArch64/AArch64TargetTransformInfo.cpp +++ b/llvm/lib/Target/AArch64/AArch64TargetTransformInfo.cpp @@ -819,8 +819,9 @@ } } -int AArch64TTIImpl::getAddressComputationCost(Type *Ty, ScalarEvolution *SE, - const SCEV *Ptr) { +InstructionCost AArch64TTIImpl::getAddressComputationCost(Type *Ty, + ScalarEvolution *SE, + const SCEV *Ptr) { // Address computations in vectorized code with non-consecutive addresses will // likely result in more instructions compared to scalar code where the // computation can more often be merged into the index mode. The resulting diff --git a/llvm/lib/Target/ARM/ARMTargetTransformInfo.h b/llvm/lib/Target/ARM/ARMTargetTransformInfo.h --- a/llvm/lib/Target/ARM/ARMTargetTransformInfo.h +++ b/llvm/lib/Target/ARM/ARMTargetTransformInfo.h @@ -215,8 +215,8 @@ InstructionCost getVectorInstrCost(unsigned Opcode, Type *Val, unsigned Index); - int getAddressComputationCost(Type *Val, ScalarEvolution *SE, - const SCEV *Ptr); + InstructionCost getAddressComputationCost(Type *Val, ScalarEvolution *SE, + const SCEV *Ptr); InstructionCost getArithmeticInstrCost( unsigned Opcode, Type *Ty, diff --git a/llvm/lib/Target/ARM/ARMTargetTransformInfo.cpp b/llvm/lib/Target/ARM/ARMTargetTransformInfo.cpp --- a/llvm/lib/Target/ARM/ARMTargetTransformInfo.cpp +++ b/llvm/lib/Target/ARM/ARMTargetTransformInfo.cpp @@ -977,8 +977,9 @@ BaseT::getCmpSelInstrCost(Opcode, ValTy, CondTy, VecPred, CostKind, I); } -int ARMTTIImpl::getAddressComputationCost(Type *Ty, ScalarEvolution *SE, - const SCEV *Ptr) { +InstructionCost ARMTTIImpl::getAddressComputationCost(Type *Ty, + ScalarEvolution *SE, + const SCEV *Ptr) { // Address computations in vectorized code with non-consecutive addresses will // likely result in more instructions compared to scalar code where the // computation can more often be merged into the index mode. The resulting diff --git a/llvm/lib/Target/Hexagon/HexagonTargetTransformInfo.h b/llvm/lib/Target/Hexagon/HexagonTargetTransformInfo.h --- a/llvm/lib/Target/Hexagon/HexagonTargetTransformInfo.h +++ b/llvm/lib/Target/Hexagon/HexagonTargetTransformInfo.h @@ -113,8 +113,8 @@ TTI::TargetCostKind CostKind); InstructionCost getIntrinsicInstrCost(const IntrinsicCostAttributes &ICA, TTI::TargetCostKind CostKind); - unsigned getAddressComputationCost(Type *Tp, ScalarEvolution *SE, - const SCEV *S); + InstructionCost getAddressComputationCost(Type *Tp, ScalarEvolution *SE, + const SCEV *S); InstructionCost getMemoryOpCost(unsigned Opcode, Type *Src, MaybeAlign Alignment, unsigned AddressSpace, TTI::TargetCostKind CostKind, diff --git a/llvm/lib/Target/Hexagon/HexagonTargetTransformInfo.cpp b/llvm/lib/Target/Hexagon/HexagonTargetTransformInfo.cpp --- a/llvm/lib/Target/Hexagon/HexagonTargetTransformInfo.cpp +++ b/llvm/lib/Target/Hexagon/HexagonTargetTransformInfo.cpp @@ -150,8 +150,9 @@ return BaseT::getIntrinsicInstrCost(ICA, CostKind); } -unsigned HexagonTTIImpl::getAddressComputationCost(Type *Tp, - ScalarEvolution *SE, const SCEV *S) { +InstructionCost HexagonTTIImpl::getAddressComputationCost(Type *Tp, + ScalarEvolution *SE, + const SCEV *S) { return 0; } diff --git a/llvm/lib/Target/X86/X86TargetTransformInfo.h b/llvm/lib/Target/X86/X86TargetTransformInfo.h --- a/llvm/lib/Target/X86/X86TargetTransformInfo.h +++ b/llvm/lib/Target/X86/X86TargetTransformInfo.h @@ -155,8 +155,8 @@ Align Alignment, TTI::TargetCostKind CostKind, const Instruction *I); - int getAddressComputationCost(Type *PtrTy, ScalarEvolution *SE, - const SCEV *Ptr); + InstructionCost getAddressComputationCost(Type *PtrTy, ScalarEvolution *SE, + const SCEV *Ptr); Optional instCombineIntrinsic(InstCombiner &IC, IntrinsicInst &II) const; diff --git a/llvm/lib/Target/X86/X86TargetTransformInfo.cpp b/llvm/lib/Target/X86/X86TargetTransformInfo.cpp --- a/llvm/lib/Target/X86/X86TargetTransformInfo.cpp +++ b/llvm/lib/Target/X86/X86TargetTransformInfo.cpp @@ -3317,8 +3317,9 @@ return Cost + LT.first; } -int X86TTIImpl::getAddressComputationCost(Type *Ty, ScalarEvolution *SE, - const SCEV *Ptr) { +InstructionCost X86TTIImpl::getAddressComputationCost(Type *Ty, + ScalarEvolution *SE, + const SCEV *Ptr) { // Address computations in vectorized code with non-consecutive addresses will // likely result in more instructions compared to scalar code where the // computation can more often be merged into the index mode. The resulting