|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| | llvm-svn: 43644 | 
| | 
| 
| 
| 
| 
| 
| 
| | modref.
- Remove a bogus assertion.
llvm-svn: 43211 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Turn a store folding instruction into a load folding instruction. e.g.
     xorl  %edi, %eax
     movl  %eax, -32(%ebp)
     movl  -36(%ebp), %eax
     orl   %eax, -32(%ebp)
=>
     xorl  %edi, %eax
     orl   -36(%ebp), %eax
     mov   %eax, -32(%ebp)
This enables the unfolding optimization for a subsequent instruction which will
also eliminate the newly introduced store instruction.
llvm-svn: 43192 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Turn this:
movswl  %ax, %eax
movl    %eax, -36(%ebp)
xorl    %edi, -36(%ebp)
into
movswl  %ax, %eax
xorl    %edi, %eax
movl    %eax, -36(%ebp)
by unfolding the load / store xorl into an xorl and a store when we know the
value in the spill slot is available in a register. This doesn't change the
number of instructions but reduce the number of times memory is accessed.
Also unfold some load folding instructions and reuse the value when similar
situation presents itself.
llvm-svn: 42947 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | (almost) a register copy. However, it always coalesced to the register of the
RHS (the super-register). All uses of the result of a EXTRACT_SUBREG are sub-
register uses which adds subtle complications to load folding, spiller rewrite,
etc.
llvm-svn: 42899 | 
| | 
| 
| 
| 
| 
| | Tested with "make check"!
llvm-svn: 42346 | 
| | 
| 
| 
| 
| 
| 
| | isRegister, isImmediate, and isMachineBasicBlock, which are equivalent,
and more popular.
llvm-svn: 41958 | 
| | 
| 
| 
| | llvm-svn: 41744 | 
| | 
| 
| 
| 
| 
| | essentially a load from stack slot. It's ok to mark the stack slot value as available for reuse. But it should not be clobbered since the destination of the move is live.
llvm-svn: 41109 | 
| | 
| 
| 
| 
| 
| 
| | - If the defs of a spilled rematerializable MI are dead after the spill store is deleted, delete
  the def MI as well.
llvm-svn: 41086 | 
| | 
| 
| 
| 
| 
| | dead, mark the def operand as isDead.
llvm-svn: 41083 | 
| | 
| 
| 
| 
| 
| 
| | no more uses within the MBB and the spilled value isn't live out of the MBB.
Then it's safe to delete the spill store.
llvm-svn: 41069 | 
| | 
| 
| 
| 
| 
| | spilled value is available for reuse.
llvm-svn: 41067 | 
| | 
| 
| 
| 
| 
| | intervals that are coalesced to be rematerialized.
llvm-svn: 41060 | 
| | 
| 
| 
| 
| 
| | restore.
llvm-svn: 39748 | 
| | 
| 
| 
| | llvm-svn: 38534 | 
| | 
| 
| 
| | llvm-svn: 38525 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | with a general target hook to identify rematerializable instructions. Some
instructions are only rematerializable with specific operands, such as loads
from constant pools, while others are always rematerializable. This hook
allows both to be identified as being rematerializable with the same
mechanism.
llvm-svn: 37644 | 
| | 
| 
| 
| 
| 
| 
| 
| | and an
implementation for x86.
llvm-svn: 37576 | 
| | 
| 
| 
| | llvm-svn: 36483 | 
| | 
| 
| 
| | llvm-svn: 36452 | 
| | 
| 
| 
| | llvm-svn: 35660 | 
| | 
| 
| 
| 
| 
| | register more than once.
llvm-svn: 35513 | 
| | 
| 
| 
| 
| 
| | TID->numOperands.
llvm-svn: 35375 | 
| | 
| 
| 
| | llvm-svn: 35365 | 
| | 
| 
| 
| | llvm-svn: 35208 | 
| | 
| 
| 
| | llvm-svn: 34878 | 
| | 
| 
| 
| 
| 
| | - Available value use may be deleted (e.g. noop move).
llvm-svn: 34841 | 
| | 
| 
| 
| | llvm-svn: 34839 | 
| | 
| 
| 
| 
| 
| | the last use of the targetted register.
llvm-svn: 34773 | 
| | 
| 
| 
| 
| 
| | last kill should be updated accordingly.
llvm-svn: 34597 | 
| | 
| 
| 
| 
| 
| | that reuse it.
llvm-svn: 34536 | 
| | 
| 
| 
| 
| 
| | spiller, its live range has to be extended.
llvm-svn: 34517 | 
| | 
| 
| 
| | llvm-svn: 34460 | 
| | 
| 
| 
| | llvm-svn: 34435 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The code sequence before the spiller is something like:
                 = tMOVrr
        %reg1117 = tMOVrr
        %reg1078 = tLSLri %reg1117, 2
The it starts spilling:
        %r0 = tRestore <fi#5>, 0
        %r1 = tRestore <fi#7>, 0
        %r1 = tMOVrr %r1<kill>
        tSpill %r1, <fi#5>, 0
        %reg1078 = tLSLri %reg1117, 2
It restores the value while processing the first tMOVrr. At this point, the
spiller remembers fi#5 is available in %r0. Next it processes the second move.
It restores the source before the move and spills the result afterwards. The
move becomes a noop and is deleted. However, a spill has been inserted and that
should invalidate reuse of %r0 for fi#5 and add reuse of %r1 for fi#5.
Therefore, %reg1117 (which is also assigned fi#5) should get %r1, not %r0.
llvm-svn: 34039 | 
| | 
| 
| 
| | llvm-svn: 33457 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | rejected during its quest to find a suitable reload register. This avoids an infinite loop in case like this:
  t1 := op t2, t3
  t2 <- assigned r0 for use by the reload but ended up reuse r1
  t3 <- assigned r1 for use by the reload but ended up reuse r0
  t1 <- desires r1
        sees r1 is taken by t2, tries t2's reload register r0
        sees r0 is taken by t3, tries t3's reload register r1
        sees r1 is taken by t2, tries t2's reload register r0 ...
llvm-svn: 33382 | 
| | 
| 
| 
| | llvm-svn: 32698 | 
| | 
| 
| 
| 
| 
| 
| | rework the hacks that had us passing OStream in. We pass in std::ostream*
instead, check for null, and then dispatch to the correct print() method.
llvm-svn: 32636 | 
| | 
| 
| 
| | llvm-svn: 32593 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | If a spillslot value is available in a register, and there is a noop copy that
targets that register, the spiller correctly decide not to invalidate the
spillslot register.
However, even though the noop copy does not clobbers the value. It does start a
new intersecting live range. That means the spillslot register is available for
use but should not be reused for a two-address instruction modref operand which
would clobber the new live range.
When we remove the noop copy, update the available information by clearing the
canClobber bit.
llvm-svn: 32576 | 
| | 
| 
| 
| | llvm-svn: 32366 | 
| | 
| 
| 
| 
| 
| 
| | tied to another oeprand, 2) whether is is being tied to by another operand. So
the destination operand of a two-address MI can be correctly identified.
llvm-svn: 32354 | 
| | 
| 
| 
| 
| 
| | Reverted.
llvm-svn: 32305 | 
| | 
| 
| 
| 
| 
| | now cerr, cout, and NullStream resp.
llvm-svn: 32298 | 
| | 
| 
| 
| | llvm-svn: 32296 | 
| | 
| 
| 
| 
| 
| | constraint. This bug was causing excessive spills.
llvm-svn: 32295 | 
| | 
| 
| 
| 
| 
| | is 'unsigned'.
llvm-svn: 32279 | 
| | 
| 
| 
| | llvm-svn: 32098 |