Similar to collecting information from branches guarding a loop, we can
also collect information from assumes dominating the loop header.
Fixes PR47247.
Paths
| Differential D87854
[SCEV] Also use info from assumes in applyLoopGuards. ClosedPublic Authored by fhahn on Sep 17 2020, 12:56 PM.
Details Summary Similar to collecting information from branches guarding a loop, we can Fixes PR47247.
Diff Detail
Event TimelineComment Actions commit message?
Comment Actions
It was not quite ready yet, but now everything should be in place and this patch only contains the important change. I'll update the title/description shortly after updating the diff. fhahn retitled this revision from [SCEV] Use information from assume for BE taken count. to [SCEV] Also use info from assumes in applyLoopGuards..Sep 25 2020, 11:22 AM This revision is now accepted and ready to land.Sep 25 2020, 12:44 PM This revision was landed with ongoing or failed builds.Sep 28 2020, 5:15 AM Closed by commit rG0ad793f321ed: [SCEV] Also use info from assumes in applyLoopGuards. (authored by fhahn). · Explain Why This revision was automatically updated to reflect the committed changes. fhahn marked an inline comment as done.
Revision Contents
Diff 294372 llvm/lib/Analysis/ScalarEvolution.cpp
llvm/test/Analysis/ScalarEvolution/max-backedge-taken-count-guard-info.ll
|
Nit: perform the dyn_cast first, dominance check is probably more costly.