mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-24 22:24:54 +00:00
Allow GVN to eliminate read-only function calls when it can detect that they are redundant.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@44323 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -476,7 +476,8 @@ uint32_t ValueTable::lookup_or_add(Value* V) {
|
||||
|
||||
if (CallInst* C = dyn_cast<CallInst>(V)) {
|
||||
if (C->getCalledFunction() &&
|
||||
AA->doesNotAccessMemory(C->getCalledFunction())) {
|
||||
(AA->doesNotAccessMemory(C->getCalledFunction()) ||
|
||||
AA->onlyReadsMemory(C->getCalledFunction()))) {
|
||||
Expression e = create_expression(C);
|
||||
|
||||
DenseMap<Expression, uint32_t>::iterator EI = expressionNumbering.find(e);
|
||||
@@ -1038,6 +1039,22 @@ bool GVN::processInstruction(Instruction* I,
|
||||
} else if (currAvail.test(num)) {
|
||||
Value* repl = find_leader(currAvail, num);
|
||||
|
||||
if (CallInst* CI = dyn_cast<CallInst>(I)) {
|
||||
AliasAnalysis& AA = getAnalysis<AliasAnalysis>();
|
||||
if (CI->getCalledFunction() &&
|
||||
!AA.doesNotAccessMemory(CI->getCalledFunction())) {
|
||||
MemoryDependenceAnalysis& MD = getAnalysis<MemoryDependenceAnalysis>();
|
||||
if (MD.getDependency(CI) != MD.getDependency(cast<CallInst>(repl))) {
|
||||
// There must be an intervening may-alias store, so nothing from
|
||||
// this point on will be able to be replaced with the preceding call
|
||||
currAvail.erase(repl);
|
||||
currAvail.insert(I);
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
VN.erase(I);
|
||||
I->replaceAllUsesWith(repl);
|
||||
toErase.push_back(I);
|
||||
|
Reference in New Issue
Block a user