diff options
author | Alkis Evlogimenos <alkis@evlogimenos.com> | 2003-12-28 18:03:52 +0000 |
---|---|---|
committer | Alkis Evlogimenos <alkis@evlogimenos.com> | 2003-12-28 18:03:52 +0000 |
commit | a158dc81047e36e8250b8ed44fb12a7e2895326a (patch) | |
tree | a604164f726cc8607884f628491dafaba932f5ab /llvm | |
parent | 43b587d94d8f094d1596635fff98e31203f4d748 (diff) | |
download | bcm5719-llvm-a158dc81047e36e8250b8ed44fb12a7e2895326a.tar.gz bcm5719-llvm-a158dc81047e36e8250b8ed44fb12a7e2895326a.zip |
Reserve ECX and EDI instead of EBX and EDI. Since EBX is a callee
saved register it has a longer free range than ECX (which is defined
every time there is a fnuction call) which makes ECX a better register
to reserve.
llvm-svn: 10635
Diffstat (limited to 'llvm')
-rw-r--r-- | llvm/lib/CodeGen/RegAllocLinearScan.cpp | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/llvm/lib/CodeGen/RegAllocLinearScan.cpp b/llvm/lib/CodeGen/RegAllocLinearScan.cpp index e2c1a18b440..e677ce8824b 100644 --- a/llvm/lib/CodeGen/RegAllocLinearScan.cpp +++ b/llvm/lib/CodeGen/RegAllocLinearScan.cpp @@ -238,17 +238,17 @@ bool RA::runOnMachineFunction(MachineFunction &fn) { // aliasing) number of temp registers to reserve so that we have 2 // registers for each register class available. - // reserve R32: EDI, EBX, - // R16: DI, BX, - // R8: BH, BL + // reserve R8: CH, CL + // R16: CX, DI, + // R32: ECX, EDI, // RFP: FP5, FP6 reserved_.assign(MRegisterInfo::FirstVirtualRegister, false); - reserved_[19] = true; /* EDI */ - reserved_[17] = true; /* EBX */ + reserved_[ 8] = true; /* CH */ + reserved_[ 9] = true; /* CL */ + reserved_[10] = true; /* CX */ reserved_[12] = true; /* DI */ - reserved_[ 7] = true; /* BX */ - reserved_[ 4] = true; /* BH */ - reserved_[ 5] = true; /* BL */ + reserved_[18] = true; /* ECX */ + reserved_[19] = true; /* EDI */ reserved_[28] = true; /* FP5 */ reserved_[29] = true; /* FP6 */ |