|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | UseSlots.
This allows us to always keep the smaller slot for an instruction which is what
we want when a register has early clobber defines.
Drop the UsingInstrs set and the UsingBlocks map. They are no longer needed.
llvm-svn: 128886 | 
| | 
| 
| 
| | llvm-svn: 128875 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | inlined path for the common case.
Most basic blocks don't contain a call that may throw, so the last split point
os simply the first terminator.
llvm-svn: 128874 | 
| | 
| 
| 
| | llvm-svn: 128821 | 
| | 
| 
| 
| 
| 
| | The spill weight is not recomputed for an unspillable register - it stays infinite.
llvm-svn: 128490 | 
| | 
| 
| 
| | llvm-svn: 128450 | 
| | 
| 
| 
| | llvm-svn: 128398 | 
| | 
| 
| 
| | llvm-svn: 127973 | 
| | 
| 
| 
| 
| 
| 
| 
| | and early clobbers.
Assert when trying to find an undefined value.
llvm-svn: 127856 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | components.
I have convinced myself that it can only happen when a phi value dies. When it
happens, allocate new virtual registers for the components.
llvm-svn: 127827 | 
| | 
| 
| 
| | llvm-svn: 127779 | 
| | 
| 
| 
| | llvm-svn: 127697 | 
| | 
| 
| 
| 
| 
| 
| 
| | LiveRangeEdit::eliminateDeadDefs() will eventually be used by coalescing,
splitting, and spilling for dead code elimination. It can delete chains of dead
instructions as long as there are no dependency loops.
llvm-svn: 127287 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The coalescer can in very rare cases leave too large live intervals around after
rematerializing cheap-as-a-move instructions.
Linear scan doesn't really care, but live range splitting gets very confused
when a live range is killed by a ghost instruction.
I will fix this properly in the coalescer after 2.9 branches.
llvm-svn: 127096 | 
| | 
| 
| 
| | llvm-svn: 127006 | 
| | 
| 
| 
| 
| 
| 
| | This speeds up updateSSA() so it only accounts for 5% of the live range
splitting time.
llvm-svn: 126972 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | time.
This speeds up the greedy register allocator by 15%.
DenseMap is not as fast as one might hope.
llvm-svn: 126921 | 
| | 
| 
| 
| 
| 
| | multiple splits.
llvm-svn: 126912 | 
| | 
| 
| 
| 
| 
| | When only a single value has been seen, new PHIDefs are never needed.
llvm-svn: 126911 | 
| | 
| 
| 
| 
| 
| | No functional change.
llvm-svn: 126898 | 
| | 
| 
| 
| 
| 
| 
| 
| | Values that map to a single new value in a new interval after splitting don't
need new PHIDefs, and if the parent value was never rematerialized the live
range will be the same.
llvm-svn: 126894 | 
| | 
| 
| 
| | llvm-svn: 126893 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Extract the updateSSA() method from the too long extendRange().
LiveOutCache can be shared among all the new intervals since there is at most
one of the new ranges live out from each basic block.
llvm-svn: 126818 | 
| | 
| 
| 
| 
| 
| | Simplify the signature - The return value and ParentVNI are no longer needed.
llvm-svn: 126809 | 
| | 
| 
| 
| 
| 
| 
| | This method could probably be used by LiveIntervalAnalysis::shrinkToUses, and
now it can use extendIntervalEndTo() which coalesces ranges.
llvm-svn: 126803 | 
| | 
| 
| 
| | llvm-svn: 126801 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The value map is currently not used, all values are 'complex mapped' and
LiveIntervalMap::mapValue is used to dig them out.
This is the first step in a series changes leading to the removal of
LiveIntervalMap. Its data structures can be shared among all the live intervals
created by a split, so it is wasteful to create a copy for each.
llvm-svn: 126800 | 
| | 
| 
| 
| 
| 
| 
| | Local live range splitting is better driven by interference. This code was just
guessing.
llvm-svn: 126799 | 
| | 
| 
| 
| 
| 
| | No code will be inserted after the split point anyway.
llvm-svn: 126319 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | terminate.
An original endpoint is an instruction that killed or defined the original live
range before any live ranges were split.
When splitting global live ranges, avoid creating local live ranges without any
original endpoints. We may still create global live ranges without original
endpoints, but such a range won't be split again, and live range splitting still
terminates.
llvm-svn: 126151 | 
| | 
| 
| 
| | llvm-svn: 126005 | 
| | 
| 
| 
| | llvm-svn: 126003 | 
| | 
| 
| 
| 
| 
| 
| | Loop splitting is better handled by the more generic global region splitting
based on the edge bundle graph.
llvm-svn: 125243 | 
| | 
| 
| 
| 
| 
| 
| | This fixes a bug where splitSingleBlocks() could split a live range after a
terminator instruction.
llvm-svn: 125237 | 
| | 
| 
| 
| 
| 
| | No functional changes intended.
llvm-svn: 125231 | 
| | 
| 
| 
| | llvm-svn: 125226 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | are live.
If a live range is used by a terminator instruction, and that live range needs
to leave the block on the stack or in a different register, it can be necessary
to have both sides of the split live at the terminator instruction.
Example:
  %vreg2 = COPY %vreg1
  JMP %vreg1
Becomes after spilling %vreg2:
  SPILL %vreg1
  JMP %vreg1
The spill doesn't kill the register as is normally the case.
llvm-svn: 125102 | 
| | 
| 
| 
| | llvm-svn: 125101 | 
| | 
| 
| 
| 
| 
| 
| 
| | A live range cannot be split everywhere in a basic block. A split must go before
the first terminator, and if the variable is live into a landing pad, the split
must happen before the call that can throw.
llvm-svn: 124894 | 
| | 
| 
| 
| | llvm-svn: 124842 | 
| | 
| 
| 
| | llvm-svn: 124813 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | If the found value is not live-through the block, we should only add liveness up
to the requested slot index. When the value is live-through, the whole block
should be colored.
Bug found by SSA verification in the machine code verifier.
llvm-svn: 124812 | 
| | 
| 
| 
| 
| 
| 
| | These end points come from the inserted copies, and can be passed directly to
useIntv. This simplifies the coloring code.
llvm-svn: 124799 | 
| | 
| 
| 
| | llvm-svn: 124779 | 
| | 
| 
| 
| | llvm-svn: 124778 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The greedy register allocator revealed some problems with the value mapping in
SplitKit. We would sometimes start mapping values before all defs were known,
and that could change a value from a simple 1-1 mapping to a multi-def mapping
that requires ssa update.
The new approach collects all defs and register assignments first without
filling in any live intervals. Only when finish() is called, do we compute
liveness and mapped values. At this time we know with certainty which values map
to multiple values in a split range.
This also has the advantage that we can compute live ranges based on the
remaining uses after rematerializing at split points.
The current implementation has many opportunities for compile time optimization.
llvm-svn: 124765 | 
| | 
| 
| 
| 
| 
| | No functional change.
llvm-svn: 124257 | 
| | 
| 
| 
| 
| 
| | update algorithm.
llvm-svn: 123925 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Region splitting includes loop splitting as a subset, and it is more generic.
The splitting heuristics for variables that are live in more than one block are
now:
1. Try to create a region that covers multiple basic blocks.
2. Try to create a new live range for each block with multiple uses.
3. Spill.
Steps 2 and 3 are similar to what the standard spiller is doing.
llvm-svn: 123853 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Analyze the live range's behavior entering and leaving basic blocks. Compute an
interference pattern for each allocation candidate, and use SpillPlacement to
find an optimal region where that register can be live.
This code is still not enabled.
llvm-svn: 123774 |