|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| | thanks to contexts-on-types.  More to come.
llvm-svn: 77011 | 
| | 
| 
| 
| | llvm-svn: 76702 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| | the [I|F]CmpInst constructors.  Who knew!?
llvm-svn: 75200 | 
| | 
| 
| 
| | llvm-svn: 74918 | 
| | 
| 
| 
| | llvm-svn: 74753 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | trip counts in more cases.
Generalize ScalarEvolution's isLoopGuardedByCond code to recognize
And and Or conditions, splitting the code out into an
isNecessaryCond helper function so that it can evaluate Ands and Ors
recursively, and make SCEVExpander be much more aggressive about
hoisting instructions out of loops.
test/CodeGen/X86/pr3495.ll has an additional instruction now, but
it appears to be due to an arbitrary register allocation difference.
llvm-svn: 74048 | 
| | 
| 
| 
| 
| 
| | preheader is already an instruction.
llvm-svn: 74031 | 
| | 
| 
| 
| | llvm-svn: 73906 | 
| | 
| 
| 
| 
| 
| | terminology that LoopInfo uses.
llvm-svn: 73863 | 
| | 
| 
| 
| | llvm-svn: 73796 | 
| | 
| 
| 
| 
| 
| 
| | hand-crafted testcase which demonstrates the bug that was exposed
in 254.gap.
llvm-svn: 73793 | 
| | 
| 
| 
| 
| 
| | which it isn't prepared to handle.
llvm-svn: 73787 | 
| | 
| 
| 
| | llvm-svn: 73783 | 
| | 
| 
| 
| 
| 
| 
| | as signed max tests. Along with r73717, this helps CodeGen avoid
emitting code for a maximum operation for this class of loop.
llvm-svn: 73718 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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: 73621 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | failures.
To support this, add some utility functions to Type to help support
vector/scalar-independent code. Change ConstantInt::get and
ConstantFP::get to support vector types, and add an overload to
ConstantInt::get that uses a static IntegerType type, for
convenience.
Introduce a new getConstant method for ScalarEvolution, to simplify
common use cases.
llvm-svn: 73431 | 
| | 
| 
| 
| 
| 
| | SmallVector instead of std::vector.
llvm-svn: 73357 | 
| | 
| 
| 
| | llvm-svn: 72965 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | integer and floating-point opcodes, introducing
FAdd, FSub, and FMul.
For now, the AsmParser, BitcodeReader, and IRBuilder all preserve
backwards compatability, and the Core LLVM APIs preserve backwards
compatibility for IR producers. Most front-ends won't need to change
immediately.
This implements the first step of the plan outlined here:
http://nondot.org/sabre/LLVMNotes/IntegerOverflow.txt
llvm-svn: 72897 | 
| | 
| 
| 
| 
| 
| 
| 
| | rewrite the comparison if there is any implicit extension or truncation
on the induction variable. I'm planning for IVUsers to eventually take
over some of the work of this code, and for it to be generalized.
llvm-svn: 72496 | 
| | 
| 
| 
| 
| 
| 
| | a smaller type, promoted its offset back up to the type of the new
comparison. This fixes PR4222.
llvm-svn: 72493 | 
| | 
| 
| 
| 
| 
| 
| 
| | of the comparison is defined inside the loop. This fixes a
use-before-def problem, because the transformation puts a use
of the RHS outside the loop.
llvm-svn: 72149 | 
| | 
| 
| 
| | llvm-svn: 72131 | 
| | 
| 
| 
| | llvm-svn: 72130 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | instructions. It attempts to create high-level multi-operand GEPs,
though in cases where this isn't possible it falls back to casting
the pointer to i8* and emitting a GEP with that. Using GEP instructions
instead of ptrtoint+arithmetic+inttoptr helps pointer analyses that
don't use ScalarEvolution, such as BasicAliasAnalysis.
Also, make the AddrModeMatcher more aggressive in handling GEPs.
Previously it assumed that operand 0 of a GEP would require a register
in almost all cases. It now does extra checking and can do more
matching if operand 0 of the GEP is foldable. This fixes a problem
that was exposed by SCEVExpander using GEPs.
llvm-svn: 72093 | 
| | 
| 
| 
| 
| 
| | avoid ambiguity with the word "use" in IVStrideUse.
llvm-svn: 72012 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | without one.  Use it where we were using abs on
int64_t objects.
(I strongly suspect the casts to unsigned in the
fragments in LoopStrengthReduce are not doing whatever
the original intent was, but the obvious change to
uint64_t doesn't work.  Maybe later.)
llvm-svn: 71612 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| | postinc iv value. Previously LSR would only optimize those which are in the loop latch block. However, if LSR can prove it is safe (and profitable), it's now possible to change those not in the latch blocks to use postinc values.
Also, if the compare is the only use, LSR would place the iv increment instruction before the compare instead in the latch.
llvm-svn: 71485 | 
| | 
| 
| 
| 
| 
| 
| 
| | count down to 0 instead, under very restricted
circumstances.  Adjust 4 testcases in which this
optimization fires.
llvm-svn: 71439 | 
| | 
| 
| 
| | llvm-svn: 71305 | 
| | 
| 
| 
| | llvm-svn: 71091 | 
| | 
| 
| 
| | llvm-svn: 71090 | 
| | 
| 
| 
| | llvm-svn: 71035 | 
| | 
| 
| 
| | llvm-svn: 71033 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Running /Volumes/Sandbox/Buildbot/llvm/full-llvm/build/llvm.src/test/
CodeGen/X86/dg.exp ...
FAIL: /Volumes/Sandbox/Buildbot/llvm/full-llvm/build/llvm.src/test/
CodeGen/X86/change-compare-stride-1.ll
Failed with exit(1) at line 2
while running: grep {cmpq       $-478,} change-compare-stride-1.ll.tmp
child process exited abnormally
llvm-svn: 71013 | 
| | 
| 
| 
| | llvm-svn: 71008 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | CallbackVH, with fixes. allUsesReplacedWith need to
walk the def-use chains and invalidate all users of a
value that is replaced. SCEVs of users need to be
recalcualted even if the new value is equivalent. Also,
make forgetLoopPHIs walk def-use chains, since any
SCEV that depends on a PHI should be recalculated when
more information about that PHI becomes available.
llvm-svn: 70927 | 
| | 
| 
| 
| | llvm-svn: 70919 | 
| | 
| 
| 
| | llvm-svn: 70661 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | makes ScalarEvolution::deleteValueFromRecords, and it's code that
subtly needed to be called before ReplaceAllUsesWith, unnecessary.
It also makes ValueDeletionListener unnecessary.
llvm-svn: 70645 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | of returning a list of pointers to Values that are deleted. This was
unsafe, because the pointers in the list are, by nature of what
RecursivelyDeleteDeadInstructions does, always dangling. Replace this
with a simple callback mechanism. This may eventually be removed if
all clients can reasonably be expected to use CallbackVH.
Use this to factor out the dead-phi-cycle-elimination code from LSR
utility function, and generalize it to use the
RecursivelyDeleteTriviallyDeadInstructions utility function.
This makes LSR more aggressive about eliminating dead PHI cycles;
adjust tests to either be less trivial or to simply expect fewer
instructions.
llvm-svn: 70636 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | of LSR. This makes the AddUsersIfInteresting phase of LSR a pure
analysis instead of a phase that potentially does CFG modifications.
The conditions where this code would actually perform a split are
rare, and in the cases where it actually would do a split the split
is usually undone by CodeGenPrepare, and in cases where splits
actually survive into codegen, they appear to hurt more often than
they help.
llvm-svn: 70625 | 
| | 
| 
| 
| 
| 
| 
| 
| | target hooks canLosslesslyBitCastTo and isTruncateFree. This allows
targets to avoid worrying about handling all combinations of integer
and pointer types.
llvm-svn: 70555 | 
| | 
| 
| 
| | llvm-svn: 70551 | 
| | 
| 
| 
| | llvm-svn: 70546 | 
| | 
| 
| 
| | llvm-svn: 70427 | 
| | 
| 
| 
| 
| 
| 
| | between the comparison's iv stride and the candidate stride is
exactly -1.
llvm-svn: 70244 |