forked from OSchip/llvm-project
[NFCI][CodeGen, AArch64] Fix inconsistent TargetCostKind types.
The pass uses different cost kinds to estimate "old" and "interleaved" costs: default cost kind for all targets override `getInterleavedMemoryOpCost()` is `TCK_SizeAndLatency`. Although at the moment estimated `TCK_Latency` costs are equal to `TCK_SizeAndLatency`, (so the change is NFC) it may change in future. Reviewed By: RKSimon Differential Revision: https://reviews.llvm.org/D110100
This commit is contained in:
parent
fe16d331d3
commit
1a7b7d7ba2
|
@ -1131,6 +1131,7 @@ bool InterleavedLoadCombineImpl::combine(std::list<VectorInfo> &InterleavedLoad,
|
|||
|
||||
InstructionCost InterleavedCost;
|
||||
InstructionCost InstructionCost = 0;
|
||||
const TTI::TargetCostKind CostKind = TTI::TCK_SizeAndLatency;
|
||||
|
||||
// Get the interleave factor
|
||||
unsigned Factor = InterleavedLoad.size();
|
||||
|
@ -1158,8 +1159,7 @@ bool InterleavedLoadCombineImpl::combine(std::list<VectorInfo> &InterleavedLoad,
|
|||
// be expected. Also sum the cost of the Instructions beeing left dead.
|
||||
for (auto &I : Is) {
|
||||
// Compute the old cost
|
||||
InstructionCost +=
|
||||
TTI.getInstructionCost(I, TargetTransformInfo::TCK_Latency);
|
||||
InstructionCost += TTI.getInstructionCost(I, CostKind);
|
||||
|
||||
// The final SVIs are allowed not to be dead, all uses will be replaced
|
||||
if (SVIs.find(I) != SVIs.end())
|
||||
|
@ -1212,7 +1212,7 @@ bool InterleavedLoadCombineImpl::combine(std::list<VectorInfo> &InterleavedLoad,
|
|||
Indices.push_back(i);
|
||||
InterleavedCost = TTI.getInterleavedMemoryOpCost(
|
||||
Instruction::Load, ILTy, Factor, Indices, InsertionPoint->getAlign(),
|
||||
InsertionPoint->getPointerAddressSpace());
|
||||
InsertionPoint->getPointerAddressSpace(), CostKind);
|
||||
|
||||
if (InterleavedCost >= InstructionCost) {
|
||||
return false;
|
||||
|
|
Loading…
Reference in New Issue