summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorAlkis Evlogimenos <alkis@evlogimenos.com>2003-12-28 18:03:52 +0000
committerAlkis Evlogimenos <alkis@evlogimenos.com>2003-12-28 18:03:52 +0000
commita158dc81047e36e8250b8ed44fb12a7e2895326a (patch)
treea604164f726cc8607884f628491dafaba932f5ab /llvm
parent43b587d94d8f094d1596635fff98e31203f4d748 (diff)
downloadbcm5719-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.cpp16
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 */
OpenPOWER on IntegriCloud