forked from OSchip/llvm-project
[LAA] NFC: Rename [get]MaxSafeRegisterWidth -> [get]MaxSafeVectorWidthInBits
MaxSafeRegisterWidth is a misnomer since it actually returns the maximum safe vector width. Register suggests it relates directly to a physical register where it could be a vector spanning one or more physical registers. Reviewed By: sdesmalen Differential Revision: https://reviews.llvm.org/D91727
This commit is contained in:
parent
ecabb39ca1
commit
1ba4b82f67
|
@ -171,7 +171,8 @@ public:
|
||||||
|
|
||||||
MemoryDepChecker(PredicatedScalarEvolution &PSE, const Loop *L)
|
MemoryDepChecker(PredicatedScalarEvolution &PSE, const Loop *L)
|
||||||
: PSE(PSE), InnermostLoop(L), AccessIdx(0), MaxSafeDepDistBytes(0),
|
: PSE(PSE), InnermostLoop(L), AccessIdx(0), MaxSafeDepDistBytes(0),
|
||||||
MaxSafeRegisterWidth(-1U), FoundNonConstantDistanceDependence(false),
|
MaxSafeVectorWidthInBits(-1U),
|
||||||
|
FoundNonConstantDistanceDependence(false),
|
||||||
Status(VectorizationSafetyStatus::Safe), RecordDependences(true) {}
|
Status(VectorizationSafetyStatus::Safe), RecordDependences(true) {}
|
||||||
|
|
||||||
/// Register the location (instructions are given increasing numbers)
|
/// Register the location (instructions are given increasing numbers)
|
||||||
|
@ -210,7 +211,9 @@ public:
|
||||||
|
|
||||||
/// Return the number of elements that are safe to operate on
|
/// Return the number of elements that are safe to operate on
|
||||||
/// simultaneously, multiplied by the size of the element in bits.
|
/// simultaneously, multiplied by the size of the element in bits.
|
||||||
uint64_t getMaxSafeRegisterWidth() const { return MaxSafeRegisterWidth; }
|
uint64_t getMaxSafeVectorWidthInBits() const {
|
||||||
|
return MaxSafeVectorWidthInBits;
|
||||||
|
}
|
||||||
|
|
||||||
/// In same cases when the dependency check fails we can still
|
/// In same cases when the dependency check fails we can still
|
||||||
/// vectorize the loop with a dynamic array access check.
|
/// vectorize the loop with a dynamic array access check.
|
||||||
|
@ -275,7 +278,7 @@ private:
|
||||||
/// operate on simultaneously, multiplied by the size of the element in bits.
|
/// operate on simultaneously, multiplied by the size of the element in bits.
|
||||||
/// The size of the element is taken from the memory access that is most
|
/// The size of the element is taken from the memory access that is most
|
||||||
/// restrictive.
|
/// restrictive.
|
||||||
uint64_t MaxSafeRegisterWidth;
|
uint64_t MaxSafeVectorWidthInBits;
|
||||||
|
|
||||||
/// If we see a non-constant dependence distance we can still try to
|
/// If we see a non-constant dependence distance we can still try to
|
||||||
/// vectorize this loop with runtime checks.
|
/// vectorize this loop with runtime checks.
|
||||||
|
|
|
@ -311,8 +311,8 @@ public:
|
||||||
|
|
||||||
unsigned getMaxSafeDepDistBytes() { return LAI->getMaxSafeDepDistBytes(); }
|
unsigned getMaxSafeDepDistBytes() { return LAI->getMaxSafeDepDistBytes(); }
|
||||||
|
|
||||||
uint64_t getMaxSafeRegisterWidth() const {
|
uint64_t getMaxSafeVectorWidthInBits() const {
|
||||||
return LAI->getDepChecker().getMaxSafeRegisterWidth();
|
return LAI->getDepChecker().getMaxSafeVectorWidthInBits();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool hasStride(Value *V) { return LAI->hasStride(V); }
|
bool hasStride(Value *V) { return LAI->hasStride(V); }
|
||||||
|
|
|
@ -1654,7 +1654,7 @@ MemoryDepChecker::isDependent(const MemAccessInfo &A, unsigned AIdx,
|
||||||
LLVM_DEBUG(dbgs() << "LAA: Positive distance " << Val.getSExtValue()
|
LLVM_DEBUG(dbgs() << "LAA: Positive distance " << Val.getSExtValue()
|
||||||
<< " with max VF = " << MaxVF << '\n');
|
<< " with max VF = " << MaxVF << '\n');
|
||||||
uint64_t MaxVFInBits = MaxVF * TypeByteSize * 8;
|
uint64_t MaxVFInBits = MaxVF * TypeByteSize * 8;
|
||||||
MaxSafeRegisterWidth = std::min(MaxSafeRegisterWidth, MaxVFInBits);
|
MaxSafeVectorWidthInBits = std::min(MaxSafeVectorWidthInBits, MaxVFInBits);
|
||||||
return Dependence::BackwardVectorizable;
|
return Dependence::BackwardVectorizable;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5369,9 +5369,9 @@ LoopVectorizationCostModel::computeFeasibleMaxVF(unsigned ConstTripCount) {
|
||||||
// It is computed by MaxVF * sizeOf(type) * 8, where type is taken from
|
// It is computed by MaxVF * sizeOf(type) * 8, where type is taken from
|
||||||
// the memory accesses that is most restrictive (involved in the smallest
|
// the memory accesses that is most restrictive (involved in the smallest
|
||||||
// dependence distance).
|
// dependence distance).
|
||||||
unsigned MaxSafeRegisterWidth = Legal->getMaxSafeRegisterWidth();
|
unsigned MaxSafeVectorWidthInBits = Legal->getMaxSafeVectorWidthInBits();
|
||||||
|
|
||||||
WidestRegister = std::min(WidestRegister, MaxSafeRegisterWidth);
|
WidestRegister = std::min(WidestRegister, MaxSafeVectorWidthInBits);
|
||||||
|
|
||||||
// Ensure MaxVF is a power of 2; the dependence distance bound may not be.
|
// Ensure MaxVF is a power of 2; the dependence distance bound may not be.
|
||||||
// Note that both WidestRegister and WidestType may not be a powers of 2.
|
// Note that both WidestRegister and WidestType may not be a powers of 2.
|
||||||
|
|
Loading…
Reference in New Issue