|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| | because LiveStackAnalysis was not preserved by VirtRegWriter. This caused
big stack usage regression in some cases.
rdar://12340383
llvm-svn: 164408 | 
| | 
| 
| 
| 
| 
| | It will soon need the context.
llvm-svn: 140896 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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: 117337 | 
| | 
| 
| 
| | llvm-svn: 115996 | 
| | 
| 
| 
| | llvm-svn: 109045 | 
| | 
| 
| 
| | llvm-svn: 106943 | 
| | 
| 
| 
| 
| 
| 
| | only a single type of object to be allocated. Use it to make VNInfo destruction
typesafe.
llvm-svn: 99919 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| | update all code that this affects.
llvm-svn: 79830 | 
| | 
| 
| 
| | llvm-svn: 79814 | 
| | 
| 
| 
| 
| 
| | trivial rewriter.
llvm-svn: 72729 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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: 56476 | 
| | 
| 
| 
| 
| 
| | machine dominators.
llvm-svn: 56475 | 
| | 
| 
| 
| | llvm-svn: 56469 | 
|  | llvm-svn: 51934 |