summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms/Scalar/TailDuplication.cpp
diff options
context:
space:
mode:
authorGabor Greif <ggreif@gmail.com>2010-07-12 10:36:48 +0000
committerGabor Greif <ggreif@gmail.com>2010-07-12 10:36:48 +0000
commit2a464d73082bb3b1375a178db9528d5860e57b28 (patch)
tree463a742ad5889073a62ce09c13cbdc74f6dcd924 /llvm/lib/Transforms/Scalar/TailDuplication.cpp
parent41b4a6b36ac77b94e4ee1908d580368e9f09fbfd (diff)
downloadbcm5719-llvm-2a464d73082bb3b1375a178db9528d5860e57b28.tar.gz
bcm5719-llvm-2a464d73082bb3b1375a178db9528d5860e57b28.zip
cache dereferenced iterators
llvm-svn: 108131
Diffstat (limited to 'llvm/lib/Transforms/Scalar/TailDuplication.cpp')
-rw-r--r--llvm/lib/Transforms/Scalar/TailDuplication.cpp9
1 files changed, 5 insertions, 4 deletions
diff --git a/llvm/lib/Transforms/Scalar/TailDuplication.cpp b/llvm/lib/Transforms/Scalar/TailDuplication.cpp
index 2306a77670f..febc872d930 100644
--- a/llvm/lib/Transforms/Scalar/TailDuplication.cpp
+++ b/llvm/lib/Transforms/Scalar/TailDuplication.cpp
@@ -206,13 +206,14 @@ static BasicBlock *FindObviousSharedDomOf(BasicBlock *SrcBlock,
// there is only one other pred, get it, otherwise we can't handle it.
PI = pred_begin(DstBlock); PE = pred_end(DstBlock);
BasicBlock *DstOtherPred = 0;
- if (*PI == SrcBlock) {
+ BasicBlock *P = *PI;
+ if (P == SrcBlock) {
if (++PI == PE) return 0;
- DstOtherPred = *PI;
+ DstOtherPred = P;
if (++PI != PE) return 0;
} else {
- DstOtherPred = *PI;
- if (++PI == PE || *PI != SrcBlock || ++PI != PE) return 0;
+ DstOtherPred = P;
+ if (++PI == PE || P != SrcBlock || ++PI != PE) return 0;
}
// We can handle two situations here: "if then" and "if then else" blocks. An
OpenPOWER on IntegriCloud