[NewGVN] equals() for loads/stores is the same. Unify.

Differential Revision:  https://reviews.llvm.org/D28116

llvm-svn: 290667
This commit is contained in:
Davide Italiano 2016-12-28 13:37:17 +00:00
parent 99940720c8
commit b111409015
1 changed files with 13 additions and 23 deletions

View File

@ -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