summaryrefslogtreecommitdiff
path: root/lib/Analysis/BranchProbabilityInfo.cpp
diff options
context:
space:
mode:
authorBenjamin Kramer <benny.kra@googlemail.com>2011-10-21 21:13:47 +0000
committerBenjamin Kramer <benny.kra@googlemail.com>2011-10-21 21:13:47 +0000
commit675c02b0b9967f286b4d5aa8c3f7d8fc9e7988c4 (patch)
tree83e82d1d8795ca98bc1d74a5dfeb3d92dfd33b48 /lib/Analysis/BranchProbabilityInfo.cpp
parent7102b703bfacd7e8d1b3ef967d0e1b10b56714b7 (diff)
downloadllvm-675c02b0b9967f286b4d5aa8c3f7d8fc9e7988c4.tar.gz
llvm-675c02b0b9967f286b4d5aa8c3f7d8fc9e7988c4.tar.bz2
llvm-675c02b0b9967f286b4d5aa8c3f7d8fc9e7988c4.tar.xz
Extend the floating point heuristic to consider NaN checks unlikely.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@142687 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/BranchProbabilityInfo.cpp')
-rw-r--r--lib/Analysis/BranchProbabilityInfo.cpp21
1 files changed, 17 insertions, 4 deletions
diff --git a/lib/Analysis/BranchProbabilityInfo.cpp b/lib/Analysis/BranchProbabilityInfo.cpp
index 6e8d7e0115..fc69da9e67 100644
--- a/lib/Analysis/BranchProbabilityInfo.cpp
+++ b/lib/Analysis/BranchProbabilityInfo.cpp
@@ -391,15 +391,28 @@ bool BranchProbabilityAnalysis::calcFloatingPointHeuristics(BasicBlock *BB) {
Value *Cond = BI->getCondition();
FCmpInst *FCmp = dyn_cast<FCmpInst>(Cond);
- if (!FCmp || !FCmp->isEquality())
+ if (!FCmp)
return false;
+ bool isProb;
+ if (FCmp->isEquality()) {
+ // f1 == f2 -> Unlikely
+ // f1 != f2 -> Likely
+ isProb = !FCmp->isTrueWhenEqual();
+ } else if (FCmp->getPredicate() == FCmpInst::FCMP_ORD) {
+ // !isnan -> Likely
+ isProb = true;
+ } else if (FCmp->getPredicate() == FCmpInst::FCMP_UNO) {
+ // isnan -> Unlikely
+ isProb = false;
+ } else {
+ return false;
+ }
+
BasicBlock *Taken = BI->getSuccessor(0);
BasicBlock *NonTaken = BI->getSuccessor(1);
- // f1 == f2 -> Unlikely
- // f1 != f2 -> Likely
- if (FCmp->isTrueWhenEqual())
+ if (!isProb)
std::swap(Taken, NonTaken);
BP->setEdgeWeight(BB, Taken, FPH_TAKEN_WEIGHT);