|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| | Most of this stuff was supporting the old deferred spill code insertion
mechanism.  Modern spillers just edit machine code in place.
llvm-svn: 144484 | 
| | 
| 
| 
| 
| 
| 
| | The information was only used by the register allocator in
StackSlotColoring.
llvm-svn: 144482 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | For example:
  %vreg10:dsub_0<def,undef> = COPY %vreg1
  %vreg10:dsub_1<def> = COPY %vreg2
is rewritten as:
  %D2<def> = COPY %D0, %Q1<imp-def>
  %D3<def> = COPY %D1, %Q1<imp-use,kill>, %Q1<imp-def>
The first COPY doesn't care about the previous value of %Q1, so it
doesn't read that register.
The second COPY is a partial redefinition of %Q1, so it implicitly kills
and redefines that register.
This makes it possible to recognize instructions that can harmlessly
clobber the full super-register.  The write and don't read the
super-register.
llvm-svn: 141139 | 
| | 
| 
| 
| 
| 
| | Fix the stats counters to reflect that.
llvm-svn: 139819 | 
| | 
| 
| 
| | llvm-svn: 130996 | 
| | 
| 
| 
| 
| 
| 
| | We cannot rely on the <imp-def> operands added by LiveIntervals in all cases as
demonstrated by the test case.
llvm-svn: 130313 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | liveness.
Turn them into noop KILL instructions instead. This lets the scavenger know when
super-registers are killed and defined.
llvm-svn: 128645 | 
| | 
| 
| 
| | llvm-svn: 128143 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | The rewriter works almost identically to -rewriter=trivial, except it also
eliminates any identity copies.
This makes the new register allocators independent of VirtRegRewriter.cpp which
will be going away at the same time as RegAllocLinearScan.
llvm-svn: 125967 | 
| | 
| 
| 
| 
| 
| 
| 
| | These functions not longer assert when passed 0, but simply return false instead.
No functional change intended.
llvm-svn: 123155 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | when no virtual registers have been allocated.
It was only used to resize IndexedMaps, so provide an IndexedMap::resize()
method such that
 Map.grow(MRI.getLastVirtReg());
can be replaced with the simpler
 Map.resize(MRI.getNumVirtRegs());
This works correctly when no virtuals are allocated, and it bypasses the to/from
index conversions.
llvm-svn: 123130 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | without a TRI instance.
Print virtual registers numbered from 0 instead of the arbitrary
FirstVirtualRegister. The first virtual register is printed as %vreg0.
TRI::NoRegister is printed as %noreg.
llvm-svn: 123107 | 
| | 
| 
| 
| 
| 
| 
| 
| | depending on TRI::FirstVirtualRegister.
Also use TRI::printReg instead of printing virtual registers directly.
llvm-svn: 123101 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Use amazing new function call technology instead of writing identical code in
multiple places.
This fixes PR8604.
llvm-svn: 119306 | 
| | 
| 
| 
| | llvm-svn: 115996 | 
| | 
| 
| 
| | llvm-svn: 109045 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | PPCInstrInfo::foldMemoryOperandImpl().
The PowerPC floating point registers can represent both f32 and f64 via the
two register classes F4RC and F8RC. F8RC is considered a subclass of F4RC to
allow cross-class coalescing. This coalescing only affects whether registers
are spilled as f32 or f64.
Spill slots must be accessed with load/store instructions corresponding to the
class of the spilled register. PPCInstrInfo::foldMemoryOperandImpl was looking
at the instruction opcode which is wrong.
X86 has similar floating point register classes, but doesn't try to fold
memory operands, so there is no problem there.
llvm-svn: 97262 | 
| | 
| 
| 
| | llvm-svn: 95781 | 
| | 
| 
| 
| | llvm-svn: 92587 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | slots.  The AsmPrinter will use this information to determine whether to
print a spill/reload comment.
Remove default argument values.  It's too easy to pass a wrong argument
value when multiple arguments have default values.  Make everything
explicit to trap bugs early.
Update all targets to adhere to the new interfaces..
llvm-svn: 87022 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This introduces a new pass, SlotIndexes, which is responsible for numbering
instructions for register allocation (and other clients). SlotIndexes numbering
is designed to match the existing scheme, so this patch should not cause any
changes in the generated code.
For consistency, and to avoid naming confusion, LiveIndex has been renamed
SlotIndex.
The processImplicitDefs method of the LiveIntervals analysis has been moved
into its own pass so that it can be run prior to SlotIndexes. This was
necessary to match the existing numbering scheme.
llvm-svn: 85979 | 
| | 
| 
| 
| 
| 
| | get FixedStack PseudoSourceValues.
llvm-svn: 84326 | 
| | 
| 
| 
| | llvm-svn: 79842 | 
| | 
| 
| 
| 
| 
| | LiveInterval, etc to raw_ostream.
llvm-svn: 76965 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Change register allocation hint to a pair of unsigned integers. The hint type is zero (which means prefer the register specified as second part of the pair) or entirely target dependent.
- Allow targets to specify alternative register allocation orders based on allocation hint.
Part 2.
- Use the register allocation hint system to implement more aggressive load / store multiple formation.
- Aggressively form LDRD / STRD. These are formed *before* register allocation. It has to be done this way to shorten live interval of base and offset registers. e.g.
v1025 = LDR v1024, 0
v1026 = LDR v1024, 0
=>
v1025,v1026 = LDRD v1024, 0
If this transformation isn't done before allocation, v1024 will overlap v1025 which means it more difficult to allocate a register pair.
- Even with the register allocation hint, it may not be possible to get the desired allocation. In that case, the post-allocation load / store multiple pass must fix the ldrd / strd instructions. They can either become ldm / stm instructions or back to a pair of ldr / str instructions.
This is work in progress, not yet enabled.
llvm-svn: 73381 | 
| | 
| 
| 
| 
| 
| | MachineRegisterInfo. This allows more passes to set them.
llvm-svn: 73346 | 
| | 
| 
| 
| 
| 
| | class.
llvm-svn: 70821 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | not utilizing registers at all. The fundamental problem is linearscan's backtracking can end up freeing more than one allocated registers. However,  reloads and restores might be folded into uses / defs and freed registers might not be used at all.
VirtRegMap keeps track of allocations so it knows what's not used. As a horrible hack, the stack coloring can color spill slots with *free* registers. That is, it replace reload and spills with copies from and to the free register. It unfold instructions that load and store the spill slot and replace them with register using variants.
Not yet enabled. This is part 1. More coming.
llvm-svn: 70787 | 
| | 
| 
| 
| | llvm-svn: 68099 | 
| | 
| 
| 
| | llvm-svn: 68092 | 
| | 
| 
| 
| | llvm-svn: 67000 | 
| | 
| 
| 
| | llvm-svn: 66870 | 
| | 
| 
| 
| 
| 
| | No (intended) functionality change.
llvm-svn: 66720 | 
| | 
| 
| 
| 
| 
| | the same instruction as kill. This fixes PR3706.
llvm-svn: 66428 | 
| | 
| 
| 
| | llvm-svn: 66363 | 
| | 
| 
| 
| | llvm-svn: 65679 | 
| | 
| 
| 
| 
| 
| | already marked livein.
llvm-svn: 65498 | 
| | 
| 
| 
| 
| 
| | Sorry, it's impossible to reduce a sensible test case. It basically requires the moon and stars to align in order to cause a failure.
llvm-svn: 65497 | 
| | 
| 
| 
| 
| 
| | exposed by recent availability fallthrough changes.
llvm-svn: 64745 | 
| | 
| 
| 
| | llvm-svn: 64428 | 
| | 
| 
| 
| 
| 
| 
| | the new way, where all of the information is passed on SDNodes and machine
instructions.
llvm-svn: 64427 | 
| | 
| 
| 
| | llvm-svn: 64381 | 
| | 
| 
| 
| 
| 
| | basic blocks, e.g. x86 fp stack registers.
llvm-svn: 64374 | 
| | 
| 
| 
| 
| 
| | registers to live-in set.
llvm-svn: 64372 | 
| | 
| 
| 
| 
| 
| | a previous instruction.
llvm-svn: 64339 | 
| | 
| 
| 
| 
| 
| | availability information over BB boundaries. It visits BB's in depth first order. After visiting a BB if it find a successor which has a single predecessor it visits the successor next without clearing the availability information. This allows the successor to omit reloads or change them into copies.
llvm-svn: 64298 | 
| | 
| 
| 
| | llvm-svn: 63599 | 
| | 
| 
| 
| 
| 
| | sub-register indices as well.
llvm-svn: 62600 | 
| | 
| 
| 
| | llvm-svn: 60392 | 
| | 
| 
| 
| 
| 
| 
| 
| | reuse happened.
Patch by Lang Hames!
llvm-svn: 57720 |