|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| | This can't be just an assertion, users can always write impossible inline
assembly. Such an assembly statement should be included in the error message.
llvm-svn: 131024 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | On the x86-64 and thumb2 targets, some registers are more expensive to encode
than others in the same register class.
Add a CostPerUse field to the TableGen register description, and make it
available from TRI->getCostPerUse. This represents the cost of a REX prefix or a
32-bit instruction encoding required by choosing a high register.
Teach the greedy register allocator to prefer cheap registers for busy live
ranges (as indicated by spill weight).
llvm-svn: 129864 | 
| | 
| 
| 
| 
| 
| | accidentally be skipped.
llvm-svn: 129373 | 
| | 
| 
| 
| 
| 
| | when compiling many small functions.
llvm-svn: 129321 | 
| | 
| 
| 
| 
| 
| 
| 
| | allocation.
LiveIntervals::findLiveInMBBs has to do a full binary search for each segment.
llvm-svn: 129292 | 
| | 
| 
| 
| | llvm-svn: 129276 | 
| | 
| 
| 
| | llvm-svn: 128935 | 
| | 
| 
| 
| 
| 
| 
| | It is using a trivial rewriter that doesn't know how to insert spill code
requested by the standard spiller.
llvm-svn: 128688 | 
| | 
| 
| 
| 
| 
| | Empty ranges may represent undef values.
llvm-svn: 128144 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | register number.
The live range of a virtual register may change which invalidates the cached
interference information.
llvm-svn: 127772 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Live range splitting can create a number of small live ranges containing only a
single real use. Spill these small live ranges along with the large range they
are connected to with copies. This enables memory operand folding and maximizes
the spill to fill distance.
Work in progress with known bugs.
llvm-svn: 127529 | 
| | 
| 
| 
| 
| 
| 
| | This makes it possible to register delegates and get callbacks when the spiller
edits live ranges.
llvm-svn: 127389 | 
| | 
| 
| 
| 
| 
| | SmallVectors.
llvm-svn: 127388 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | allocated first.
This is based on the observation that long live ranges are more difficult to
allocate, so there is a better chance of solving the puzzle by handling the big
pieces first. The allocator will evict and split long alive ranges when they get
in the way.
RABasic is still using spill weights for its priority queue, so the interface to
the queue has been virtualized.
llvm-svn: 126259 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| | llvm-svn: 125802 | 
| | 
| 
| 
| | llvm-svn: 125789 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Registers are not allocated strictly in spill weight order when live range
splitting and spilling has created new shorter intervals with higher spill
weights.
When one of the new heavy intervals conflicts with a single lighter interval,
simply evict the old interval instead of trying to split the heavy one.
The lighter interval is a better candidate for splitting, it has a smaller use
density.
llvm-svn: 125151 | 
| | 
| 
| 
| 
| 
| 
| 
| | createMachineVerifierPass and MachineFunction::verify.
The banner is printed before the machine code dump, just like the printer pass.
llvm-svn: 122113 | 
| | 
| 
| 
| 
| 
| 
| 
| | RegAllocBase::VerifyEnabled.
Run the machine code verifier in a few interesting places during RegAllocGreedy.
llvm-svn: 122107 | 
| | 
| 
| 
| | llvm-svn: 121801 | 
| | 
| 
| 
| 
| 
| | LiveIntervalUnions.
llvm-svn: 121781 | 
| | 
| 
| 
| | llvm-svn: 121604 | 
| | 
| 
| 
| | llvm-svn: 121599 | 
| | 
| 
| 
| 
| 
| 
| | heuristic to reshuffle register assignments when we can't find an
available reg.
llvm-svn: 121388 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | abstract priority queue interface in subclasses that want to override the
priority calculations.
Subclasses must provide a getPriority() implementation instead.
This approach requires less code as long as priorities are expressable as simple
floats, and it avoids the dangers of defining potentially expensive priority
comparison functions.
It also should speed up priority_queue operations since they no longer have to
chase pointers when comparing registers. This is not measurable, though.
Preferably, we shouldn't use floats to guide code generation. The use of floats
here is derived from the use of floats for spill weights. Spill weights have a
dynamic range that doesn't lend itself easily to a fixpoint implementation.
When someone invents a stable spill weight representation, it can be reused for
allocation priorities.
llvm-svn: 121294 | 
| | 
| 
| 
| 
| 
| 
| | Minor optimization to the use of IntervalMap iterators. They are fairly
heavyweight, so prefer SI.valid() over SI != end().
llvm-svn: 121217 | 
| | 
| 
| 
| 
| 
| 
| | This speeds up RegAllocBasic by 20%, not counting releaseMemory which becomes
way faster.
llvm-svn: 121201 | 
| | 
| 
| 
| | llvm-svn: 121162 | 
| | 
| 
| 
| 
| 
| 
| 
| | in favor of the widespread llvm style. Capitalize variables and add
newlines for visual parsing. Rename variables for readability.
And other cleanup.
llvm-svn: 120490 | 
| | 
| 
| 
| | llvm-svn: 120146 | 
| | 
| 
| 
| | llvm-svn: 119896 | 
| | 
| 
| 
| | llvm-svn: 119895 | 
| | 
| 
| 
| 
| 
| 
| 
| | it makes no sense for allocation_order iterators to visit reserved regs.
The inline spiller depends on AliasAnalysis.
Manage the Query state to avoid uninitialized or stale results.
llvm-svn: 118800 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | benchmarks hitting an assertion.
Adds LiveIntervalUnion::collectInterferingVRegs.
Fixes "late spilling" by checking for any unspillable live vregs among
all physReg aliases.
llvm-svn: 118701 | 
| | 
| 
| 
| 
| 
| | (retry now that the windows build is green)
llvm-svn: 118630 | 
| | 
| 
| 
| | llvm-svn: 118613 | 
| | 
| 
| 
| | llvm-svn: 118604 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | handle cases in which a register is unavailable for spill code.
Adds LiveIntervalUnion::extract. While processing interferences on a
live virtual register, reuses the same Query object for each
physcial reg.
llvm-svn: 118423 | 
| | 
| 
| 
| 
| 
| | splitting needs them.
llvm-svn: 118194 | 
| | 
| 
| 
| | llvm-svn: 117384 | 
|  | framework. It's purpose is not to improve register allocation per se,
but to make it easier to develop powerful live range splitting. I call
it the basic allocator because it is as simple as a global allocator
can be but provides the building blocks for sophisticated register
allocation with live range splitting. 
A minimal implementation is provided that trivially spills whenever it
runs out of registers. I'm checking in now to get high-level design
and style feedback. I've only done minimal testing. The next step is
implementing a "greedy" allocation algorithm that does some register
reassignment and makes better splitting decisions.
llvm-svn: 117174 |