summaryrefslogtreecommitdiffstats
path: root/llvm/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
commit606a50a9f81d5c55fee3eb6d36934f9ac0989abf (patch)
tree6662f96214f8ed14c0bf7a46861195411dd33e36 /llvm/lib/Analysis/BranchProbabilityInfo.cpp
parent8a8d6466ff60c1285dba86c4a125b556f7256eb2 (diff)
downloadbcm5719-llvm-606a50a9f81d5c55fee3eb6d36934f9ac0989abf.tar.gz
bcm5719-llvm-606a50a9f81d5c55fee3eb6d36934f9ac0989abf.zip
Extend the floating point heuristic to consider NaN checks unlikely.
llvm-svn: 142687
Diffstat (limited to 'llvm/lib/Analysis/BranchProbabilityInfo.cpp')
-rw-r--r--llvm/lib/Analysis/BranchProbabilityInfo.cpp21
1 files changed, 17 insertions, 4 deletions
diff --git a/llvm/lib/Analysis/BranchProbabilityInfo.cpp b/llvm/lib/Analysis/BranchProbabilityInfo.cpp
index 6e8d7e0115d..fc69da9e672 100644
--- a/llvm/lib/Analysis/BranchProbabilityInfo.cpp
+++ b/llvm/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);
OpenPOWER on IntegriCloud