forked from OSchip/llvm-project
[NewGVN] equals() for loads/stores is the same. Unify.
Differential Revision: https://reviews.llvm.org/D28116 llvm-svn: 290667
This commit is contained in:
parent
99940720c8
commit
b111409015
|
@ -350,36 +350,26 @@ char NewGVN::ID = 0;
|
||||||
// createGVNPass - The public interface to this file.
|
// createGVNPass - The public interface to this file.
|
||||||
FunctionPass *llvm::createNewGVNPass() { return new NewGVN(); }
|
FunctionPass *llvm::createNewGVNPass() { return new NewGVN(); }
|
||||||
|
|
||||||
bool LoadExpression::equals(const Expression &Other) const {
|
template <typename T>
|
||||||
if (!isa<LoadExpression>(Other) && !isa<StoreExpression>(Other))
|
static bool equalsLoadStoreHelper(const T &LHS, const Expression &RHS) {
|
||||||
|
if ((!isa<LoadExpression>(RHS) && !isa<StoreExpression>(RHS)) ||
|
||||||
|
!LHS.BasicExpression::equals(RHS))
|
||||||
return false;
|
return false;
|
||||||
if (!this->BasicExpression::equals(Other))
|
if (const auto *L = dyn_cast<LoadExpression>(&RHS))
|
||||||
return false;
|
if (LHS.getDefiningAccess() != L->getDefiningAccess())
|
||||||
if (const auto *OtherL = dyn_cast<LoadExpression>(&Other)) {
|
|
||||||
if (DefiningAccess != OtherL->getDefiningAccess())
|
|
||||||
return false;
|
return false;
|
||||||
} else if (const auto *OtherS = dyn_cast<StoreExpression>(&Other)) {
|
if (const auto *S = dyn_cast<StoreExpression>(&RHS))
|
||||||
if (DefiningAccess != OtherS->getDefiningAccess())
|
if (LHS.getDefiningAccess() != S->getDefiningAccess())
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool StoreExpression::equals(const Expression &Other) const {
|
bool LoadExpression::equals(const Expression &Other) const {
|
||||||
if (!isa<LoadExpression>(Other) && !isa<StoreExpression>(Other))
|
return equalsLoadStoreHelper(*this, Other);
|
||||||
return false;
|
}
|
||||||
if (!this->BasicExpression::equals(Other))
|
|
||||||
return false;
|
|
||||||
if (const auto *OtherL = dyn_cast<LoadExpression>(&Other)) {
|
|
||||||
if (DefiningAccess != OtherL->getDefiningAccess())
|
|
||||||
return false;
|
|
||||||
} else if (const auto *OtherS = dyn_cast<StoreExpression>(&Other)) {
|
|
||||||
if (DefiningAccess != OtherS->getDefiningAccess())
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
bool StoreExpression::equals(const Expression &Other) const {
|
||||||
|
return equalsLoadStoreHelper(*this, Other);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef NDEBUG
|
#ifndef NDEBUG
|
||||||
|
|
Loading…
Reference in New Issue