summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJakub Staszak <kubastaszak@gmail.com>2012-10-16 19:32:31 +0000
committerJakub Staszak <kubastaszak@gmail.com>2012-10-16 19:32:31 +0000
commitba34fdb0e47c39b9bb770869d343f849ceb6fff3 (patch)
tree9c1d198c146acb22a0391855dcbde6c2564a5faf
parentfef9e3199a6256c957e990f79051b8926f623538 (diff)
downloadbcm5719-llvm-ba34fdb0e47c39b9bb770869d343f849ceb6fff3.tar.gz
bcm5719-llvm-ba34fdb0e47c39b9bb770869d343f849ceb6fff3.zip
Simplify potentially quadratic behavior while erasing elements from std::vector.
llvm-svn: 166045
-rw-r--r--llvm/lib/Transforms/Scalar/DCE.cpp8
1 files changed, 1 insertions, 7 deletions
diff --git a/llvm/lib/Transforms/Scalar/DCE.cpp b/llvm/lib/Transforms/Scalar/DCE.cpp
index 086f0a1a714..8d53443b389 100644
--- a/llvm/lib/Transforms/Scalar/DCE.cpp
+++ b/llvm/lib/Transforms/Scalar/DCE.cpp
@@ -118,13 +118,7 @@ bool DCE::runOnFunction(Function &F) {
I->eraseFromParent();
// Remove the instruction from the worklist if it still exists in it.
- for (std::vector<Instruction*>::iterator WI = WorkList.begin();
- WI != WorkList.end(); ) {
- if (*WI == I)
- WI = WorkList.erase(WI);
- else
- ++WI;
- }
+ WorkList.erase(std::remove(WorkList.begin(), WorkList.end(), I), WorkList.end());
MadeChange = true;
++DCEEliminated;
OpenPOWER on IntegriCloud