summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Analysis/CodeMetrics.cpp
diff options
context:
space:
mode:
authorSerguei Katkov <serguei.katkov@azul.com>2017-05-18 06:11:56 +0000
committerSerguei Katkov <serguei.katkov@azul.com>2017-05-18 06:11:56 +0000
commitba831f78fd9f6f9d9d96cba699bc3e48b2b26630 (patch)
tree7f45d4a9084668a336f8ef428bbcc298bc6a6de7 /llvm/lib/Analysis/CodeMetrics.cpp
parentb10bff1183b8fcfe1a6625e353f9ebdef904ae7c (diff)
downloadbcm5719-llvm-ba831f78fd9f6f9d9d96cba699bc3e48b2b26630.tar.gz
bcm5719-llvm-ba831f78fd9f6f9d9d96cba699bc3e48b2b26630.zip
[BPI] Reduce the probability of unreachable edge to minimal value greater than 0
The probability of edge coming to unreachable block should be as low as possible. The change reduces the probability to minimal value greater than zero. The bug https://bugs.llvm.org/show_bug.cgi?id=32214 show the example when the probability of edge coming to unreachable block is greater than for edge coming to out of the loop and it causes incorrect loop rotation. Please note that with this change the behavior of unreachable heuristic is a bit different than others. Specifically, before this change the sum of probabilities coming to unreachable blocks have the same weight for all branches (it was just split over all edges of this block coming to unreachable blocks). With this change it might be slightly different but not to much due to probability of taken branch to unreachable block is really small. Reviewers: chandlerc, sanjoy, vsk, congh, junbuml, davidxl, dexonsmith Reviewed By: chandlerc, dexonsmith Subscribers: reames, llvm-commits Differential Revision: https://reviews.llvm.org/D30633 llvm-svn: 303327
Diffstat (limited to 'llvm/lib/Analysis/CodeMetrics.cpp')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud