|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| | This almost guarantees that the COPY will be coalesced.
llvm-svn: 125140 | 
| | 
| 
| 
| 
| 
| 
| 
| | register.
The target hook doesn't know how to do that. (Neither do I).
llvm-svn: 125108 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | physical register numbers.
This makes the hack used in LiveInterval official, and lets LiveInterval be
oblivious of stack slots.
The isPhysicalRegister() and isVirtualRegister() predicates don't know about
this, so when a variable may contain a stack slot, isStackSlot() should always
be tested first.
llvm-svn: 123128 | 
| | 
| 
| 
| | llvm-svn: 122135 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | use before rematerializing the load.
This allows us to produce:
    addps	LCPI0_1(%rip), %xmm2
Instead of:
    movaps	LCPI0_1(%rip), %xmm3
    addps	%xmm3, %xmm2
Saving a register and an instruction. The standard spiller already knows how to
do this.
llvm-svn: 122133 | 
| | 
| 
| 
| 
| 
| 
| 
| | createMachineVerifierPass and MachineFunction::verify.
The banner is printed before the machine code dump, just like the printer pass.
llvm-svn: 122113 | 
| | 
| 
| 
| 
| 
| 
| 
| | The spiller should only spill. The register allocator will drive live range
splitting, it has the needed information about register pressure and
interferences.
llvm-svn: 121590 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | live ranges for the spill register are also defined at the use slot instead of
the normal def slot.
This fixes PR8612 for the inline spiller. A use was being allocated to the same
register as a spilled early clobber def.
This problem exists in all the spillers. A fix for the standard spiller is
forthcoming.
llvm-svn: 119182 | 
| | 
| 
| 
| 
| 
| | constant loads.
llvm-svn: 118741 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | benchmarks hitting an assertion.
Adds LiveIntervalUnion::collectInterferingVRegs.
Fixes "late spilling" by checking for any unspillable live vregs among
all physReg aliases.
llvm-svn: 118701 | 
| | 
| 
| 
| | llvm-svn: 118661 | 
| | 
| 
| 
| 
| 
| 
| 
| | This way, InlineSpiller does the same amount of splitting as the standard
spiller. Splitting should really be guided by the register allocator, and
doesn't belong in the spiller at all.
llvm-svn: 118216 | 
| | 
| 
| 
| | llvm-svn: 118193 | 
| | 
| 
| 
| 
| 
| | give them individual stack slots once the are actually spilled.
llvm-svn: 117945 | 
| | 
| 
| 
| | llvm-svn: 117761 | 
| | 
| 
| 
| | llvm-svn: 117629 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | proper SSA updating.
This doesn't cause MachineDominators to be recomputed since we are already
requiring MachineLoopInfo which uses dominators as well.
llvm-svn: 117598 | 
| | 
| 
| 
| 
| 
| | split.
llvm-svn: 117597 | 
| | 
| 
| 
| | llvm-svn: 117338 | 
| | 
| 
| 
| | llvm-svn: 116951 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | All registers created during splitting or spilling are assigned to the same
stack slot as the parent register.
When splitting or rematting, we may not spill at all. In that case the stack
slot is still assigned, but it will be dead.
llvm-svn: 116546 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | splitting or spillling, and to help with rematerialization.
Use LiveRangeEdit in InlineSpiller and SplitKit. This will eventually make it
possible to share remat code between InlineSpiller and SplitKit.
llvm-svn: 116543 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | never kept after splitting.
Keeping the original interval made sense when the split region doesn't modify
the register, and the original is spilled. We can get the same effect by
detecting reloaded values when spilling around copies.
llvm-svn: 115695 | 
| | 
| 
| 
| 
| 
| | overhead where possible. Thanks to Jakob for the suggestions.
llvm-svn: 114798 | 
| | 
| 
| 
| 
| 
| | whether LiveIntervals::getInstructionFromIndex(def) returns NULL.
llvm-svn: 114791 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | The earliestStart argument is entirely specific to linear scan allocation, and
can be easily calculated by RegAllocLinearScan.
Replace std::vector with SmallVector.
llvm-svn: 111055 | 
| | 
| 
| 
| 
| 
| 
| 
| | When a live range is contained a single block, we can split it around
instruction clusters. The current approach is very primitive, splitting before
and after the largest gap between uses.
llvm-svn: 111043 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Before spilling a live range, we split it into a separate range for each basic
block where it is used. That way we only get one reload per basic block if the
new smaller ranges can allocate to a register.
This type of splitting is already present in the standard spiller.
llvm-svn: 110934 | 
| | 
| 
| 
| 
| 
| 
| 
| | The live interval may be used for a spill slot as well, and that spill slot
could be shared by split registers. We cannot shrink it, even if we know the
current register won't need the spill slot in that range.
llvm-svn: 110721 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | necessary.
Sometimes, live range splitting doesn't shrink the current interval, but simply
changes some instructions to use a new interval. That makes the original more
suitable for spilling. In this case, we don't need to duplicate the original.
llvm-svn: 110481 | 
| | 
| 
| 
| | llvm-svn: 110464 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This helps avoid silly code:
    %R0<def = LOAD <fi#5>
    STORE <fi#5>, %R0<kill>
llvm-svn: 110266 | 
| | 
| 
| 
| 
| 
| 
| | We are now at a point where we can split around simple single-entry, single-exit
loops, although still with some bugs.
llvm-svn: 110257 | 
| | 
| 
| 
| 
| 
| 
| 
| | rewrite instructions for live range splitting.
Still work in progress.
llvm-svn: 109469 | 
| | 
| 
| 
| 
| 
| 
| 
| | The spillers can pluck the analyses they need from the pass reference.
Switch some never-null pointers to references.
llvm-svn: 108969 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This is a work in progress. So far we have some basic loop analysis to help
determine where it is useful to split a live range around a loop.
The actual loop splitting code from Splitter.cpp is also going to move in here.
llvm-svn: 108842 | 
| | 
| 
| 
| 
| 
| | non-const.
llvm-svn: 108734 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | inserted in a MBB, and return an already inserted MI.
This target API change is necessary to allow foldMemoryOperand to call
storeToStackSlot and loadFromStackSlot when folding a COPY to a stack slot
reference in a target independent way.
The foldMemoryOperandImpl hook is going to change in the same way, but I'll wait
until COPY folding is actually implemented. Most targets only fold copies and
won't need to specialize this hook at all.
llvm-svn: 107991 | 
| | 
| 
| 
| | llvm-svn: 107505 | 
| | 
| 
| 
| | llvm-svn: 107503 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | This allows us to recognize the common case where all uses could be
rematerialized, and no stack slot allocation is necessary.
If some values could be fully rematerialized, remove them from the live range
before allocating a stack slot for the rest.
llvm-svn: 107492 | 
| | 
| 
| 
| | llvm-svn: 107355 | 
| | 
| 
| 
| | llvm-svn: 107351 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | LocalRewriter::runOnMachineFunction uses this information to mark dead spill
slots.
This means that InlineSpiller now also works for functions that spill.
llvm-svn: 107302 | 
|  | InlineSpiller inserts loads and spills immediately instead of deferring to
VirtRegMap. This is possible now because SlotIndexes allows instructions to be
inserted and renumbered.
This is work in progress, and is mostly a copy of TrivialSpiller so far. It
works very well for functions that don't require spilling.
llvm-svn: 107227 |