|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| | just ask ScalarEvolution for it on demand. This helps IVUsers be more robust
in the case of expressions changing underneath it. This fixes PR6862.
llvm-svn: 101819 | 
| | 
| 
| 
| 
| 
| | intentionally ignored.
llvm-svn: 100984 | 
| | 
| 
| 
| | llvm-svn: 100983 | 
| | 
| 
| 
| | llvm-svn: 100981 | 
| | 
| 
| 
| 
| 
| | be sent to LSR, which it isn't prepared to handle.
llvm-svn: 100839 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | explicitly split into stride-and-offset pairs. Also, add the
ability to track multiple post-increment loops on the same expression.
This refines the concept of "normalizing" SCEV expressions used for
to post-increment uses, and introduces a dedicated utility routine for
normalizing and denormalizing expressions.
This fixes the expansion of expressions which are post-increment users
of more than one loop at a time. More broadly, this takes LSR another
step closer to being able to reason about more than one loop at a time.
llvm-svn: 100699 | 
| | 
| 
| 
| | llvm-svn: 100515 | 
| | 
| 
| 
| | llvm-svn: 97453 | 
| | 
| 
| 
| | llvm-svn: 96780 | 
| | 
| 
| 
| 
| 
| | to override anything from the parent class.
llvm-svn: 96150 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | bug fixes, and with improved heuristics for analyzing foreign-loop
addrecs.
This change also flattens IVUsers, eliminating the stride-oriented
groupings, which makes it easier to work with.
llvm-svn: 95975 | 
| | 
| 
| 
| 
| 
| | The "uses=" comments are just clutter in this context.
llvm-svn: 95799 | 
| | 
| 
| 
| | llvm-svn: 95022 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This new version is much more aggressive about doing "full" reduction in
cases where it reduces register pressure, and also more aggressive about
rewriting induction variables to count down (or up) to zero when doing so
reduces register pressure.
It currently uses fairly simplistic algorithms for finding reuse
opportunities, but it introduces a new framework allows it to combine
multiple strategies at once to form hybrid solutions, instead of doing
all full-reduction or all base+index.
llvm-svn: 94061 | 
| | 
| 
| 
| 
| 
| 
| 
| | form of an expression. This is the expression without the
post-increment adjustment made, which is useful in determining
which registers will be used by the expansion.
llvm-svn: 93921 | 
| | 
| 
| 
| 
| 
| | so that unnamed blocks are handled.
llvm-svn: 93059 | 
| | 
| 
| 
| 
| 
| | s/errs/dbgs/g except for certain special cases.
llvm-svn: 92037 | 
| | 
| 
| 
| 
| 
| 
| 
| | contains another loop, or an instruction. The loop form is
substantially more efficient on large loops than the typical
code it replaces.
llvm-svn: 91654 | 
| | 
| 
| 
| 
| 
| 
| 
| | of 91296 that caused trouble -- the Processed list needs to be
preserved for the livetime of the pass, as AddUsersIfInteresting
is called from other passes.
llvm-svn: 91641 | 
| | 
| 
| 
| 
| 
| | introduced a non-deterministic behavior in the optimizer somewhere.
llvm-svn: 91598 | 
| | 
| 
| 
| 
| 
| | IVUses list in releaseMemory().
llvm-svn: 91296 | 
| | 
| 
| 
| 
| 
| | condition was inverted when the code was converted to contains().
llvm-svn: 91295 | 
| | 
| 
| 
| 
| 
| | former was just exposing a LoopInfoBase implementation detail.
llvm-svn: 91286 | 
| | 
| 
| 
| | llvm-svn: 89713 | 
| | 
| 
| 
| 
| 
| 
| | for uses inside the loop. This works better with LSR. Disabled behind
-simplify-iv-users while benchmarking.
llvm-svn: 89299 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | cannot be folded into target cmp instruction.
- Avoid a phase ordering issue where early cmp optimization would prevent the
  later count-to-zero optimization.
- Add missing checks which could cause LSR to reuse stride that does not have
  users.
- Fix a bug in count-to-zero optimization code which failed to find the pre-inc
  iv's phi node.
- Remove, tighten, loosen some incorrect checks disable valid transformations.
- Quite a bit of code clean up.
llvm-svn: 86969 | 
| | 
| 
| 
| | llvm-svn: 86161 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | test whether it properly dominates the loop header. This is equivalent
when the loop has a preheader, and has the advantage of working when
the loop doesn't have a preheader. Since IVUsers doesn't Require
LoopSimplify, the loop isn't guaranteed to have a preheader.
llvm-svn: 82899 | 
| | 
| 
| 
| | llvm-svn: 82897 | 
| | 
| 
| 
| | llvm-svn: 79882 | 
| | 
| 
| 
| | llvm-svn: 79832 | 
| | 
| 
| 
| 
| 
| | This required converting a bunch of stuff off DOUT and other cleanups.
llvm-svn: 79819 | 
| | 
| 
| 
| | llvm-svn: 79244 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Some clients which used DOUT have moved to DEBUG. We are deprecating the
   "magic" DOUT behavior which avoided calling printing functions when the
   statement was disabled. In addition to being unnecessary magic, it had the
   downside of leaving code in -Asserts builds, and of hiding potentially
   unnecessary computations.
llvm-svn: 77019 | 
| | 
| 
| 
| | llvm-svn: 75568 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | using the Curiously Recurring Template Pattern with LoopBase.
This will help further refactoring, and future functionality for
Loop. Also, Headers can now foward-declare Loop, instead of pulling
in LoopInfo.h or doing tricks.
llvm-svn: 75519 | 
| | 
| 
| 
| | llvm-svn: 74918 | 
| | 
| 
| 
| | llvm-svn: 73906 | 
| | 
| 
| 
| 
| 
| 
| 
| | expression in IVUsers, because in the case of a use of a non-linear
addrec outside of a loop, this causes the addrec to be evaluated as
a linear addrec.
llvm-svn: 73774 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | casted induction variables in cases where the cast
isn't foldable. It ended up being a pessimization in
many cases. This could be fixed, but it would require
a bunch of complicated code in IVUsers' clients. The
advantages of this approach aren't visible enough to
justify it at this time.
llvm-svn: 73706 | 
| | 
| 
| 
| | llvm-svn: 73401 | 
| | 
| 
| 
| 
| 
| 
| 
| | IVUsers.cpp: In member function ‘bool llvm::IVUsers::AddUsersIfInteresting(llvm::Instruction*)’:
 IVUsers.cpp:221: warning: ‘isSigned’ may be used uninitialized in this function
with gcc-4.3.
llvm-svn: 71654 | 
|  | and generalize it so that it can be used by IndVarSimplify. Implement the
base IndVarSimplify transformation code using IVUsers. This removes
TestOrigIVForWrap and associated code, as ScalarEvolution now has enough
builtin overflow detection and folding logic to handle all the same cases,
and more. Run "opt -iv-users -analyze -disable-output" on your favorite
loop for an example of what IVUsers does.
This lets IndVarSimplify eliminate IV casts and compute trip counts in
more cases. Also, this happens to finally fix the remaining testcases
in PR1301.
Now that IndVarSimplify is being more aggressive, it occasionally runs
into the problem where ScalarEvolutionExpander's code for avoiding
duplicate expansions makes it difficult to ensure that all expanded
instructions dominate all the instructions that will use them. As a
temporary measure, IndVarSimplify now uses a FixUsesBeforeDefs function
to fix up instructions inserted by SCEVExpander. Fortunately, this code
is contained, and can be easily removed once a more comprehensive
solution is available.
llvm-svn: 71535 |