[llvm-commits] CVS: llvm/lib/Transforms/Scalar/SCCP.cpp
Chris Lattner
lattner at cs.uiuc.edu
Fri Dec 10 18:54:13 PST 2004
Changes in directory llvm/lib/Transforms/Scalar:
SCCP.cpp updated: 1.114 -> 1.115
---
Log message:
Fix a bug where we could delete dead invoke instructions with uses.
In functions where we fully constant prop the return value, replace all
ret instructions with 'ret undef'.
---
Diffs of the changes: (+26 -0)
Index: llvm/lib/Transforms/Scalar/SCCP.cpp
diff -u llvm/lib/Transforms/Scalar/SCCP.cpp:1.114 llvm/lib/Transforms/Scalar/SCCP.cpp:1.115
--- llvm/lib/Transforms/Scalar/SCCP.cpp:1.114 Fri Dec 10 16:29:08 2004
+++ llvm/lib/Transforms/Scalar/SCCP.cpp Fri Dec 10 20:53:57 2004
@@ -172,6 +172,13 @@
return ValueState;
}
+ /// getTrackedFunctionRetVals - Get the inferred return value map.
+ ///
+ const hash_map<Function*, LatticeVal> &getTrackedFunctionRetVals() {
+ return TrackedFunctionRetVals;
+ }
+
+
private:
// markConstant - Make a value be marked as "constant". If the value
// is not already a constant, add it to the instruction work list so that
@@ -1138,6 +1145,8 @@
if (Succ->begin() != Succ->end() && isa<PHINode>(Succ->begin()))
TI->getSuccessor(i)->removePredecessor(BB);
}
+ if (!TI->use_empty())
+ TI->replaceAllUsesWith(UndefValue::get(TI->getType()));
BB->getInstList().erase(TI);
} else {
@@ -1183,5 +1192,22 @@
F->getBasicBlockList().erase(DeadBB);
}
}
+
+ // If we inferred constant or undef return values for a function, we replaced
+ // all call uses with the inferred value. This means we don't need to bother
+ // actually returning anything from the function. Replace all return
+ // instructions with return undef.
+ const hash_map<Function*, LatticeVal> &RV =Solver.getTrackedFunctionRetVals();
+ for (hash_map<Function*, LatticeVal>::const_iterator I = RV.begin(),
+ E = RV.end(); I != E; ++I)
+ if (!I->second.isOverdefined() &&
+ I->first->getReturnType() != Type::VoidTy) {
+ Function *F = I->first;
+ for (Function::iterator BB = F->begin(), E = F->end(); BB != E; ++BB)
+ if (ReturnInst *RI = dyn_cast<ReturnInst>(BB->getTerminator()))
+ if (!isa<UndefValue>(RI->getOperand(0)))
+ RI->setOperand(0, UndefValue::get(F->getReturnType()));
+ }
+
return MadeChanges;
}
More information about the llvm-commits
mailing list