summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2008-12-17 05:42:08 +0000
committerChris Lattner <sabre@nondot.org>2008-12-17 05:42:08 +0000
commit0cdf52310a1efdfc8e33a19dbd4b5da565acafc5 (patch)
treecde2e18e9f548b3d25e0f3fe9d84029397e84ef7
parent222ef4c489ae791e922a95149595a33dc33a5591 (diff)
downloadbcm5719-llvm-0cdf52310a1efdfc8e33a19dbd4b5da565acafc5.tar.gz
bcm5719-llvm-0cdf52310a1efdfc8e33a19dbd4b5da565acafc5.zip
insert some sequence points and preincrement an iterator to avoid
iterator invalidation problems. llvm-svn: 61124
-rw-r--r--llvm/lib/Transforms/IPO/GlobalOpt.cpp15
1 files changed, 8 insertions, 7 deletions
diff --git a/llvm/lib/Transforms/IPO/GlobalOpt.cpp b/llvm/lib/Transforms/IPO/GlobalOpt.cpp
index f39a0dc6379..55fd267395a 100644
--- a/llvm/lib/Transforms/IPO/GlobalOpt.cpp
+++ b/llvm/lib/Transforms/IPO/GlobalOpt.cpp
@@ -1205,10 +1205,10 @@ static void RewriteHeapSROALoadUser(Instruction *LoadUser,
// If this is the first time we've seen this PHI, recursively process all
// users.
- for (Value::use_iterator UI = PN->use_begin(), E = PN->use_end(); UI != E;
- ++UI)
- RewriteHeapSROALoadUser(cast<Instruction>(*UI), InsertedScalarizedValues,
- PHIsToRewrite);
+ for (Value::use_iterator UI = PN->use_begin(), E = PN->use_end(); UI != E; ) {
+ Instruction *User = cast<Instruction>(*UI++);
+ RewriteHeapSROALoadUser(User, InsertedScalarizedValues, PHIsToRewrite);
+ }
}
/// RewriteUsesOfLoadForHeapSRoA - We are performing Heap SRoA on a global. Ptr
@@ -1219,9 +1219,10 @@ static void RewriteUsesOfLoadForHeapSRoA(LoadInst *Load,
DenseMap<Value*, std::vector<Value*> > &InsertedScalarizedValues,
std::vector<std::pair<PHINode*, unsigned> > &PHIsToRewrite) {
for (Value::use_iterator UI = Load->use_begin(), E = Load->use_end();
- UI != E; )
- RewriteHeapSROALoadUser(cast<Instruction>(*UI++), InsertedScalarizedValues,
- PHIsToRewrite);
+ UI != E; ) {
+ Instruction *User = cast<Instruction>(*UI++);
+ RewriteHeapSROALoadUser(User, InsertedScalarizedValues, PHIsToRewrite);
+ }
if (Load->use_empty()) {
Load->eraseFromParent();
OpenPOWER on IntegriCloud