|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | define below all header includes in the lib/CodeGen/... tree. While the
current modules implementation doesn't check for this kind of ODR
violation yet, it is likely to grow support for it in the future. It
also removes one layer of macro pollution across all the included
headers.
Other sub-trees will follow.
llvm-svn: 206837 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Target implementations of getRegAllocationHints() should use the
provided allocation order, and they can never return hints outside the
order. This is already documented in TargetRegisterInfo.h.
<rdar://problem/13240556>
llvm-svn: 175540 | 
| | 
| 
| 
| | llvm-svn: 174817 | 
| | 
| 
| 
| 
| 
| 
| | Allow the central functions to be inlined, and use the argumentless
isHint() function when possible.
llvm-svn: 169319 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | missed in the first pass because the script didn't yet handle include
guards.
Note that the script is now able to handle all of these headers without
manual edits. =]
llvm-svn: 169224 | 
| | 
| 
| 
| 
| 
| 
| | This simplifies the hinting code quite a bit while making the targets
easier to write at the same time.
llvm-svn: 169173 | 
| | 
| 
| 
| 
| 
| | This saves a bit of memory.
llvm-svn: 168852 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | No functional change, just moved header files.
Targets can inject custom passes between register allocation and
rewriting. This makes it possible to tweak the register allocation
before rewriting, using the full global interference checking available
from LiveRegMatrix.
llvm-svn: 168806 | 
| | 
| 
| 
| 
| 
| | Clients can use the equivalent functions in MRI.
llvm-svn: 165990 | 
| | 
| 
| 
| 
| 
| | Allow targets to access this API. It's required for RegisterPressure.
llvm-svn: 158102 | 
| | 
| 
| 
| 
| 
| | static data size.
llvm-svn: 151998 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Also switch the return type to ArrayRef<unsigned> which works out nicely
for ARM's implementation of this function because of the clever ArrayRef
constructors.
The name change indicates that the returned allocation order may contain
reserved registers as has been the case for a while.
llvm-svn: 133216 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Only target-dependent hints require callbacks. The RCI allocation order
has CSR aliases last according to their order of appearance in the
getCalleeSavedRegs list. This can depend on the calling convention.
This way, AllocationOrder::next doesn't have to check for reserved
registers, and CSRs are always allocated last, even with weird calling
conventions.
llvm-svn: 132690 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | of reserved registers.
Use RegisterClassInfo in RABasic as well. This slightly changes som
allocation orders because RegisterClassInfo puts CSR aliases last.
llvm-svn: 132581 | 
| | 
| 
| 
| 
| 
| 
| 
| | These functions not longer assert when passed 0, but simply return false instead.
No functional change intended.
llvm-svn: 123155 | 
| | 
| 
| 
| | llvm-svn: 121584 | 
|  | registers for a given virtual register.
Reserved registers are filtered from the allocation order, and any valid hint is
returned as the first suggestion.
For target dependent hints, a number of arcane target hooks are invoked.
llvm-svn: 121497 |