|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 99883 | 
| | 
| 
| 
| | llvm-svn: 93261 | 
| | 
| 
| 
| | llvm-svn: 92528 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | When a call is placed to spill an interval this spiller will first try to
break the interval up into its component values. Single value intervals and
intervals which have already been split (or are the result of previous splits)
are spilled by the default spiller.
Splitting intervals as described above may improve the performance of generated
code in some circumstances. This work is experimental however, and it still
miscompiles many benchmarks. It's not recommended for general use yet.
llvm-svn: 90951 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| | llvm-svn: 83255 | 
| | 
| 
| 
| | llvm-svn: 83254 | 
| | 
| 
| 
| | llvm-svn: 81605 | 
| | 
| 
| 
| 
| 
| 
| 
| | a new class, MachineInstrIndex, which hides arithmetic details from
most clients. This is a step towards allowing the register allocator
to update/insert code during allocation.
llvm-svn: 81040 | 
| | 
| 
| 
| | llvm-svn: 79814 | 
| | 
| 
| 
| 
| 
| | register interval, or the defining register for a stack interval. Access is via getCopy/setCopy and getReg/setReg.
llvm-svn: 78620 | 
| | 
| 
| 
| | llvm-svn: 76966 | 
| | 
| 
| 
| 
| 
| | LiveInterval, etc to raw_ostream.
llvm-svn: 76965 | 
| | 
| 
| 
| | llvm-svn: 76808 | 
| | 
| 
| 
| | llvm-svn: 76775 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | range's weight properly.  This is turned off right now in the sense that
you'll get an assert if you get into a situation that can only be caused
by an iterative coalescer.  All other code paths operate exactly as
before so there is no functional change with this patch.  The asserts
should be disabled if/when an iterative coalescer gets added to trunk.
llvm-svn: 76680 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | as an (index,bool) pair. The bool flag records whether the kill is a
PHI kill or not. This code will be used to enable splitting of live
intervals containing PHI-kills.
A slight change to live interval weights introduced an extra spill
into lsr-code-insertion (outside the critical sections). The test 
condition has been updated to reflect this.
llvm-svn: 75097 | 
| | 
| 
| 
| 
| 
| | removed old TODO comments.
llvm-svn: 74054 | 
| | 
| 
| 
| | llvm-svn: 73634 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - 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 | 
| | 
| 
| 
| 
| 
| | trivial rewriter.
llvm-svn: 72729 | 
| | 
| 
| 
| | llvm-svn: 70291 | 
| | 
| 
| 
| | llvm-svn: 70212 | 
| | 
| 
| 
| | llvm-svn: 70069 | 
| | 
| 
| 
| 
| 
| | physical sub-register live interval. When coalescer is merging in clobbered virtaul register live interval into a physical register live interval, give each virtual register val# a separate val# in the physical register live interval. Otherwise, the coalescer would have lost track of the definitions   information it needs to make correct coalescing decisions.
llvm-svn: 70026 | 
| | 
| 
| 
| 
| 
| | a range specified by [Start, End).
llvm-svn: 69434 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | with SUBREG_TO_REG, teach SimpleRegisterCoalescing to coalesce
SUBREG_TO_REG instructions (which are similar to INSERT_SUBREG
instructions), and teach the DAGCombiner to take advantage of this on
targets which support it. This eliminates many redundant
zero-extension operations on x86-64.
This adds a new TargetLowering hook, isZExtFree. It's similar to
isTruncateFree, except it only applies to actual definitions, and not
no-op truncates which may not zero the high bits.
Also, this adds a new optimization to SimplifyDemandedBits: transform
operations like x+y into (zext (add (trunc x), (trunc y))) on targets
where all the casts are no-ops. In contexts where the high part of the
add is explicitly masked off, this allows the mask operation to be
eliminated. Fix the DAGCombiner to avoid undoing these transformations
to eliminate casts on targets where the casts are no-ops.
Also, this adds a new two-address lowering heuristic. Since
two-address lowering runs before coalescing, it helps to be able to
look through copies when deciding whether commuting and/or
three-address conversion are profitable.
Also, fix a bug in LiveInterval::MergeInClobberRanges. It didn't handle
the case that a clobber range extended both before and beyond an
existing live range. In that case, multiple live ranges need to be
added. This was exposed by the new subreg coalescing code.
Remove 2008-05-06-SpillerBug.ll. It was bugpoint-reduced, and the
spiller behavior it was looking for no longer occurrs with the new
instruction selection.
llvm-svn: 68576 | 
| | 
| 
| 
| 
| 
| 
| | 1. Use the same value# to represent unknown values being merged into sub-registers.
2. When coalescer commute an instruction and the destination is a physical register, update its sub-registers by merging in the extended ranges.
llvm-svn: 66610 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | direction.
Live interval reconstruction needs to account for this, and scour its maps to
prevent dangling references.
llvm-svn: 63558 | 
| | 
| 
| 
| | llvm-svn: 63267 | 
| | 
| 
| 
| | llvm-svn: 63255 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | RA problem by expanding the live interval of an
earlyclobber def back one slot.  Remove
overlap-earlyclobber throughout.  Remove 
earlyclobber bits and their handling from
live internals.
llvm-svn: 56539 | 
| | 
| 
| 
| 
| 
| 
| | and redo as linked list walk.  Logic moved into RA.
Per review feedback.
llvm-svn: 56326 | 
| | 
| 
| 
| | llvm-svn: 54780 | 
| | 
| 
| 
| 
| 
| | top bit of 'reg' instead. If the top bit is set, than the LiveInterval represents a stack slot live interval.
llvm-svn: 52639 | 
| | 
| 
| 
| | llvm-svn: 51934 | 
| | 
| 
| 
| | llvm-svn: 47629 | 
| | 
| 
| 
| 
| 
| | would have been a Godsend here!
llvm-svn: 47625 | 
| | 
| 
| 
| | llvm-svn: 47368 | 
| | 
| 
| 
| 
| 
| 
| | register defs and uses after each successful coalescing.
- Also removed a number of hacks and fixed some subtle kill information bugs.
llvm-svn: 47167 | 
| | 
| 
| 
| 
| 
| | - removeRange() can now update value# information.
llvm-svn: 47044 | 
| | 
| 
| 
| | llvm-svn: 46930 | 
| | 
| 
| 
| 
| 
| | val# with previous liverange's.
llvm-svn: 46579 | 
| | 
| 
| 
| | llvm-svn: 45971 | 
| | 
| 
| 
| | llvm-svn: 45418 | 
| | 
| 
| 
| | llvm-svn: 44434 | 
| | 
| 
| 
| | llvm-svn: 44427 | 
| | 
| 
| 
| 
| 
| | their value numbers with the specified value number.
llvm-svn: 43062 | 
| | 
| 
| 
| 
| 
| 
| 
| | the source register will be coalesced to the super register of the LHS. Properly
merge in the live ranges of the resulting coalesced interval that were part of
the original source interval to the live interval of the super-register.
llvm-svn: 42961 |