[PATCH] D111353: [SCEV] Extend ability to infer flags to more complicates scopes

Philip Reames via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Thu Oct 7 13:38:24 PDT 2021


reames created this revision.
reames added reviewers: nikic, efriedma, lebedev.ri, mkazantsev.
Herald added subscribers: bollu, hiraditya, mcrosier.
reames requested review of this revision.
Herald added a project: LLVM.

At it's heart, this change simply extends the reasoning for proving that B must execute if A does to allow a single-successor or loop preheader chain of blocks.  The majority of the change is in making that reasonable efficient.

To make this efficient, we need to cache the per-block queries for the intermediate nodes in the found path.  (I'd love to do the edge cases too, but the invalidation is trickier.)  This patch does so by taking an existing loop level cache, and essentially splitting it into a per-block cache and then summarizing back to loop level.  In particular, we exactly parallel the construction and invalidation of the new-block cache so that no new invalidation events should be needed.  The new cache should be "as correct" as the original code.

The invalidation actions we need to worry about are adding and removing instructions from a block.  For removal, we might end up in an imprecise state.  For addition, we might end up in a incorrect state.  The existing LoopProperties cache has exactly the same issues, and depends on forgetLoop calls for correctness when we insert new instructions (with interesting properties) into a loop.

Long term, I'm actually hoping to sink the notion of block properties into BasicBlock itself, but starting here with a standalone patch makes a lot of sense.


Repository:
  rG LLVM Github Monorepo

https://reviews.llvm.org/D111353

Files:
  llvm/include/llvm/Analysis/ScalarEvolution.h
  llvm/lib/Analysis/ScalarEvolution.cpp
  llvm/test/Analysis/Delinearization/multidim_ivs_and_integer_offsets_3d.ll
  llvm/test/Analysis/Delinearization/multidim_ivs_and_parameteric_offsets_3d.ll
  llvm/test/Analysis/ScalarEvolution/flags-from-poison.ll
  llvm/test/Analysis/ScalarEvolution/incorrect-exit-count.ll
  llvm/test/Analysis/ScalarEvolution/nsw.ll

-------------- next part --------------
A non-text attachment was scrubbed...
Name: D111353.377991.patch
Type: text/x-patch
Size: 13857 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20211007/e67a814e/attachment.bin>


More information about the llvm-commits mailing list