DFG: support hashing of graphs circular through variables

No functional change
This commit is contained in:
Geza Lore 2022-09-27 13:50:37 +01:00
parent 17976d7401
commit 09e352ef66

View File

@ -468,8 +468,12 @@ V3Hash DfgVertex::hash(HashCache& cache) const {
V3Hash& result = pair.first->second; V3Hash& result = pair.first->second;
if (pair.second) { if (pair.second) {
result += selfHash(); result += selfHash();
// Variables are defined by themselves, so there is no need to hash the sources. This
// enables sound hashing of graphs circular only through variables, which we rely on.
if (!is<DfgVar>()) {
forEachSource([&result, &cache](const DfgVertex& src) { result += src.hash(cache); }); forEachSource([&result, &cache](const DfgVertex& src) { result += src.hash(cache); });
} }
}
return result; return result;
} }
@ -503,9 +507,8 @@ void DfgVar::accept(DfgVisitor& visitor) { visitor.visit(this); }
bool DfgVar::selfEquals(const DfgVertex& that) const { bool DfgVar::selfEquals(const DfgVertex& that) const {
if (const DfgVar* otherp = that.cast<DfgVar>()) { if (const DfgVar* otherp = that.cast<DfgVar>()) {
UASSERT_OBJ(varp() != otherp->varp() || this == otherp, this, UASSERT_OBJ(varp() != otherp->varp(), this,
"There should only be one DfgVar for a given AstVar"); "There should only be one DfgVar for a given AstVar");
return this == otherp;
} }
return false; return false;
} }