summaryrefslogtreecommitdiff
path: root/lib/CodeGen/RegAllocPBQP.cpp
diff options
context:
space:
mode:
authorJakob Stoklund Olesen <stoklund@2pi.dk>2012-01-05 00:26:49 +0000
committerJakob Stoklund Olesen <stoklund@2pi.dk>2012-01-05 00:26:49 +0000
commitd9e5c764bfea339fc5082bf17e558db959fd6d28 (patch)
treefd5c1e5c86fda13c754e87965fb64027891a6f68 /lib/CodeGen/RegAllocPBQP.cpp
parentfebaf8401779fedf8db7b02e499c5e39848fb9f5 (diff)
downloadllvm-d9e5c764bfea339fc5082bf17e558db959fd6d28.tar.gz
llvm-d9e5c764bfea339fc5082bf17e558db959fd6d28.tar.bz2
llvm-d9e5c764bfea339fc5082bf17e558db959fd6d28.tar.xz
Freeze reserved registers before starting register allocation.
The register allocators don't currently support adding reserved registers while they are running. Extend the MRI API to keep track of the set of reserved registers when register allocation started. Target hooks like hasFP() and needsStackRealignment() can look at this set to avoid reserving more registers during register allocation. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@147577 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/RegAllocPBQP.cpp')
-rw-r--r--lib/CodeGen/RegAllocPBQP.cpp1
1 files changed, 1 insertions, 0 deletions
diff --git a/lib/CodeGen/RegAllocPBQP.cpp b/lib/CodeGen/RegAllocPBQP.cpp
index a053cccc9e..f8b0b9fa6e 100644
--- a/lib/CodeGen/RegAllocPBQP.cpp
+++ b/lib/CodeGen/RegAllocPBQP.cpp
@@ -619,6 +619,7 @@ bool RegAllocPBQP::runOnMachineFunction(MachineFunction &MF) {
vrm = &getAnalysis<VirtRegMap>();
spiller.reset(createInlineSpiller(*this, MF, *vrm));
+ mri->freezeReservedRegs(MF);
DEBUG(dbgs() << "PBQP Register Allocating for " << mf->getFunction()->getName() << "\n");