V1 >> V2 u<= V1 for any V1, V2
This works for lshr and any div's that are changed to lshr's
This fixes issues in clang and rustc:
https://github.com/llvm/llvm-project/issues/62441
https://github.com/rust-lang/rust/issues/110971
Paths
| Differential D151541
[ValueTracking] Implied conditions for lshr ClosedPublic Authored by caojoshua on May 26 2023, 1:20 AM.
Details Summary V1 >> V2 u<= V1 for any V1, V2 This works for lshr and any div's that are changed to lshr's This fixes issues in clang and rustc:
Diff Detail
Event TimelineComment Actions I've confirmed this fixes the clang issue. Not sure how to test for rustc, but it should fix based on what I'm seeing in the IR. This revision is now accepted and ready to land.Jun 6 2023, 9:41 AM This revision was landed with ongoing or failed builds.Jun 6 2023, 9:08 PM Closed by commit rGcb9f1aaddac0: [ValueTracking] Implied conditions for lshr (authored by caojoshua). · Explain Why This revision was automatically updated to reflect the committed changes.
Revision Contents
Diff 525972 llvm/lib/Analysis/ValueTracking.cpp
llvm/test/Transforms/InstSimplify/implies.ll
|