|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | is trivially rematerializable and integrate it into
TargetInstrInfo::isTriviallyReMaterializable. This way, all places that
need to know whether an instruction is rematerializable will get the
same answer.
This enables the useful parts of the aggressive-remat option by
default -- using AliasAnalysis to determine whether a memory location
is invariant, and removes the questionable parts -- rematting operations
with virtual register inputs that may not be live everywhere.
llvm-svn: 83687 | 
| | 
| 
| 
| 
| 
| 
| | TargetInstrDesc::isRematerializable flag, so it isn't necessary to do
this check in its callers.
llvm-svn: 83671 | 
| | 
| 
| 
| | llvm-svn: 83624 | 
| | 
| 
| 
| 
| 
| | licm'ed out of loop.
llvm-svn: 83622 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | implementations with a new MachineInstr::isInvariantLoad, which uses
MachineMemOperands and is target-independent. This brings MachineLICM
and other functionality to targets which previously lacked an
isInvariantLoad implementation.
llvm-svn: 83475 | 
| | 
| 
| 
| 
| 
| 
| | allocatable. Even if it doesn't appear to have any defs, it may latter
on after register allocation.
llvm-svn: 82834 | 
| | 
| 
| 
| | llvm-svn: 82825 | 
| | 
| 
| 
| | llvm-svn: 79754 | 
| | 
| 
| 
| | llvm-svn: 78677 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | - 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 | 
| | 
| 
| 
| 
| 
| | implicit_def's.
llvm-svn: 65592 | 
| | 
| 
| 
| 
| 
| | size. For now, disable it for optimizing for size.
llvm-svn: 63856 | 
| | 
| 
| 
| | llvm-svn: 63854 | 
| | 
| 
| 
| | llvm-svn: 63729 | 
| | 
| 
| 
| 
| 
| | LICM "cheap" instructions are not particularly beneficial to start with. This will just end up making the copies harder to coalesce.
llvm-svn: 63728 | 
| | 
| 
| 
| 
| 
| | register pressure. We want to avoid spilling more instructions if it's possible.
llvm-svn: 63725 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | loops, hoisting instructions all the way out in one step rather
than hoisting them one nest level at a time. Also, make a few
other code simplifications. This speeds up MachineLICM
by several fold.
llvm-svn: 62283 | 
| | 
| 
| 
| | llvm-svn: 61715 | 
| | 
| 
| 
| 
| 
| 
| 
| | several places. isTerminator() returns true for a superset
of cases, and includes things like FP_REG_KILL, which are
nither return or branch but aren't safe to move/remat/etc.
llvm-svn: 61373 | 
| | 
| 
| 
| | llvm-svn: 61184 | 
| | 
| 
| 
| 
| 
| | isReg, etc., from isRegister, etc.
llvm-svn: 57006 | 
| | 
| 
| 
| | llvm-svn: 55779 | 
| | 
| 
| 
| | llvm-svn: 55578 | 
| | 
| 
| 
| | llvm-svn: 55074 | 
| | 
| 
| 
| 
| 
| | hoisting out some "test" and "cmp" instructions. This was obvious badness.
llvm-svn: 54908 | 
| | 
| 
| 
| | llvm-svn: 53166 | 
| | 
| 
| 
| 
| 
| 
| | several things that were neither in an anonymous namespace nor static
but not intended to be global.
llvm-svn: 51017 | 
| | 
| 
| 
| | llvm-svn: 50990 | 
| | 
| 
| 
| 
| 
| 
| 
| | possible for it to produce worse code than before.
The rest of this patch is code cleanup.
llvm-svn: 50987 | 
| | 
| 
| 
| | llvm-svn: 48142 | 
| | 
| 
| 
| | llvm-svn: 47629 | 
| | 
| 
| 
| 
| 
| | would have been a Godsend here!
llvm-svn: 47625 | 
| | 
| 
| 
| | llvm-svn: 46930 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | both work right according to the new flags.
This removes the TII::isReallySideEffectFree predicate, and adds
TII::isInvariantLoad. 
It removes NeverHasSideEffects+MayHaveSideEffects and adds
UnmodeledSideEffects as machine instr flags.  Now the clients
can decide everything they need.
I think isRematerializable can be implemented in terms of the
flags we have now, though I will let others tackle that.
llvm-svn: 45843 | 
| | 
| 
| 
| 
| 
| 
| | Make MachineInstr::getDesc return a reference instead
of a pointer, since it can never be null.
llvm-svn: 45695 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | that it is cheap and efficient to get.
Move a variety of predicates from TargetInstrInfo into 
TargetInstrDescriptor, which makes it much easier to query a predicate
when you don't have TII around.  Now you can use MI->getDesc()->isBranch()
instead of going through TII, and this is much more efficient anyway. Not
all of the predicates have been moved over yet.
Update old code that used MI->getInstrDescriptor()->Flags to use the
new predicates in many places.
llvm-svn: 45674 | 
| | 
| 
| 
| | llvm-svn: 45573 | 
| | 
| 
| 
| | llvm-svn: 45572 | 
| | 
| 
| 
| | llvm-svn: 45571 | 
| | 
| 
| 
| | llvm-svn: 45569 | 
| | 
| 
| 
| | llvm-svn: 45499 | 
| | 
| 
| 
| | llvm-svn: 45496 | 
| | 
| 
| 
| 
| 
| 
| | instruction. Also, use "splice" to move the new instruction instead of
remove/insert (where it was leaking memory anyway).
llvm-svn: 45492 | 
| | 
| 
| 
| | llvm-svn: 45418 | 
| | 
| 
| 
| | llvm-svn: 45245 | 
| | 
| 
| 
| | llvm-svn: 45178 | 
| | 
| 
| 
| | llvm-svn: 44892 | 
| | 
| 
| 
| | llvm-svn: 44881 | 
| | 
| 
| 
| | llvm-svn: 44874 | 
| | 
| 
| 
| 
| 
| | - Fix subtle bug when creating initially creating this map.
llvm-svn: 44873 |