[PATCH] D100566: [SCEV] Add a ah-hoc pattern on isImpliedCondBalancedTypes
Nikita Popov via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Apr 15 13:01:34 PDT 2021
nikic requested changes to this revision.
nikic added inline comments.
This revision now requires changes to proceed.
================
Comment at: llvm/lib/Analysis/ScalarEvolution.cpp:10468
+ // FoundRHS is AddRec's start value if and only if "AddRec == FoundRHS" is
+ // true. It means we can use "FoundRHS >= AddRec's start value".
+ if (FoundPred == ICmpInst::ICMP_EQ) {
----------------
I find it really hard to understand this is doing based on the description. I believe the claim is that
`A: Start s<= FoundRHS --> LHS s< RHS`
implies
`B: <Start,+,Step> == FoundRHS --> LHS s< RHS`.
A sufficient condition for that to hold would be that `<Start,+,Step> == FoundRHS` implies `Start s<= FoundRHS`. I assume that was your line of reasoning.
However, this is clearly not true without further legality checks. You need to at least require that the addrec is nsw, and that the step is non-negative.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D100566/new/
https://reviews.llvm.org/D100566
More information about the llvm-commits
mailing list