|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | (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 | 
| | 
| 
| 
| | llvm-svn: 41751 | 
| | 
| 
| 
| | llvm-svn: 41739 | 
| | 
| 
| 
| 
| 
| | This reduces coalescing time on siod Mac OS X PPC by 35%. Also remove the back ptr from VNInfo to LiveInterval and other tweaks.
llvm-svn: 41729 | 
| | 
| 
| 
| | llvm-svn: 41669 | 
| | 
| 
| 
| | llvm-svn: 41641 | 
| | 
| 
| 
| 
| 
| 
| | Changes related modules so VNInfo's are not copied. This decrease
copy coalescing time by 45% and overall compilation time by 10% on siod.
llvm-svn: 41579 | 
| | 
| 
| 
| 
| 
| 
| 
| | 1. Eliminate the costly live interval "swapping".
2. Change ValueNumberInfo container from SmallVector to std::vector. The former
   performs slowly when the vector size is very large.
llvm-svn: 41536 | 
| | 
| 
| 
| | llvm-svn: 41064 | 
| | 
| 
| 
| | llvm-svn: 41043 | 
| | 
| 
| 
| | llvm-svn: 41016 | 
| | 
| 
| 
| | llvm-svn: 40921 | 
| | 
| 
| 
| 
| 
| 
| | - Fix some minor bugs related to special markers on val# def. ~0U means
  undefined, ~1U means dead val#.
llvm-svn: 40916 | 
| | 
| 
| 
| | llvm-svn: 40914 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | kill instruction #, and source register number (iff the value# is defined by a
copy).
- Now def instruction # is set for every value#, not just for copy defined ones.
- Update some outdated code related inactive live ranges.
- Kill info not yet set. That's next patch.
llvm-svn: 40913 | 
| | 
| 
| 
| 
| 
| | a live interval.
llvm-svn: 36216 |