aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDuncan Sands <baldrick@free.fr>2012-02-05 19:43:37 +0000
committerDuncan Sands <baldrick@free.fr>2012-02-05 19:43:37 +0000
commitc4fd448712a70a414bcf05d74f77416407ae42c2 (patch)
tree3cd8fb02697b51a9b5b0a8b876acdf3d22c4beec
parent23f612113a0532dda1ebf7156283b8cf9a4c0ed5 (diff)
Neaten up this method. Check that if there is only one
predecessor then it's Src. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@149843 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Transforms/Scalar/GVN.cpp6
1 files changed, 3 insertions, 3 deletions
diff --git a/lib/Transforms/Scalar/GVN.cpp b/lib/Transforms/Scalar/GVN.cpp
index f6d6b90b99..654125342a 100644
--- a/lib/Transforms/Scalar/GVN.cpp
+++ b/lib/Transforms/Scalar/GVN.cpp
@@ -1999,10 +1999,10 @@ static bool isOnlyReachableViaThisEdge(BasicBlock *Src, BasicBlock *Dst,
// only reachable from Src, in practice it is pointless since at the time
// GVN runs all such loops have preheaders, which means that Dst will have
// been changed to have only one predecessor, namely Src.
- pred_iterator PI = pred_begin(Dst), PE = pred_end(Dst);
- assert(PI != PE && "No edge between these basic blocks!");
+ BasicBlock *Pred = Dst->getSinglePredecessor();
+ assert((!Pred || Pred == Src) && "No edge between these basic blocks!");
(void)Src;
- return PE == ++PI;
+ return Pred != 0;
}
/// processInstruction - When calculating availability, handle an instruction