mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-23 02:32:11 +00:00
Fix Analysis/BasicAA/pure-const-dce.ll. This turned out to be a correctness
bug as well as a missed optimization. We weren't properly checking for local dependencies before moving on to non-local ones when doing non-local read-only call CSE. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51082 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
94fb68ba21
commit
c4f406e736
@ -441,6 +441,43 @@ uint32_t ValueTable::lookup_or_add(Value* V) {
|
|||||||
return nextValueNumber++;
|
return nextValueNumber++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Instruction* local_dep = MD->getDependency(C);
|
||||||
|
|
||||||
|
if (local_dep == MemoryDependenceAnalysis::None) {
|
||||||
|
valueNumbering.insert(std::make_pair(V, nextValueNumber));
|
||||||
|
return nextValueNumber++;
|
||||||
|
} else if (local_dep != MemoryDependenceAnalysis::NonLocal) {
|
||||||
|
if (!isa<CallInst>(local_dep)) {
|
||||||
|
valueNumbering.insert(std::make_pair(V, nextValueNumber));
|
||||||
|
return nextValueNumber++;
|
||||||
|
}
|
||||||
|
|
||||||
|
CallInst* local_cdep = cast<CallInst>(local_dep);
|
||||||
|
|
||||||
|
if (local_cdep->getCalledFunction() != C->getCalledFunction() ||
|
||||||
|
local_cdep->getNumOperands() != C->getNumOperands()) {
|
||||||
|
valueNumbering.insert(std::make_pair(V, nextValueNumber));
|
||||||
|
return nextValueNumber++;
|
||||||
|
} else if (!C->getCalledFunction()) {
|
||||||
|
valueNumbering.insert(std::make_pair(V, nextValueNumber));
|
||||||
|
return nextValueNumber++;
|
||||||
|
} else {
|
||||||
|
for (unsigned i = 1; i < C->getNumOperands(); ++i) {
|
||||||
|
uint32_t c_vn = lookup_or_add(C->getOperand(i));
|
||||||
|
uint32_t cd_vn = lookup_or_add(local_cdep->getOperand(i));
|
||||||
|
if (c_vn != cd_vn) {
|
||||||
|
valueNumbering.insert(std::make_pair(V, nextValueNumber));
|
||||||
|
return nextValueNumber++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t v = lookup_or_add(local_cdep);
|
||||||
|
valueNumbering.insert(std::make_pair(V, v));
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
DenseMap<BasicBlock*, Value*> deps;
|
DenseMap<BasicBlock*, Value*> deps;
|
||||||
MD->getNonLocalDependency(C, deps);
|
MD->getNonLocalDependency(C, deps);
|
||||||
CallInst* cdep = 0;
|
CallInst* cdep = 0;
|
||||||
@ -488,7 +525,7 @@ uint32_t ValueTable::lookup_or_add(Value* V) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t v = valueNumbering[cdep];
|
uint32_t v = lookup_or_add(cdep);
|
||||||
valueNumbering.insert(std::make_pair(V, v));
|
valueNumbering.insert(std::make_pair(V, v));
|
||||||
return v;
|
return v;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user