diff options
author | Sanjoy Das <sanjoy@playingwithpointers.com> | 2017-05-22 06:46:04 +0000 |
---|---|---|
committer | Sanjoy Das <sanjoy@playingwithpointers.com> | 2017-05-22 06:46:04 +0000 |
commit | 036dda25a5b125c88e9d2fd8d63b8120842eeb51 (patch) | |
tree | f5bff62a2f27990be5bc2ae803f6405100785feb /llvm/test/Examples/Kaleidoscope | |
parent | fdddf671d8701bf4c41e0fcf9b1ba8fe8c2668b5 (diff) | |
download | bcm5719-llvm-036dda25a5b125c88e9d2fd8d63b8120842eeb51.tar.gz bcm5719-llvm-036dda25a5b125c88e9d2fd8d63b8120842eeb51.zip |
[SCEV] Clarify behavior around max backedge taken count
This is a re-application of a r303497 that was reverted in r303498.
I thought it had broken a bot when it had not (the breakage did not
go away with the revert).
This change makes the split between the "exact" backedge taken count
and the "maximum" backedge taken count a bit more obvious. Both of
these are upper bounds on the number of times the loop header
executes (since SCEV does not account for most kinds of abnormal
control flow), but the latter is guaranteed to be a constant.
There were a few places where the max backedge taken count *was* a
non-constant; I've changed those to compute constants instead.
At this point, I'm not sure if the constant max backedge count can be
computed by calling `getUnsignedRange(Exact).getUnsignedMax()` without
losing precision. If it can, we can simplify even further by making
`getMaxBackedgeTakenCount` a thin wrapper around
`getBackedgeTakenCount` and `getUnsignedRange`.
llvm-svn: 303531
Diffstat (limited to 'llvm/test/Examples/Kaleidoscope')
0 files changed, 0 insertions, 0 deletions