[llvm-commits] CVS: llvm/lib/CodeGen/RegAllocLinearScan.cpp

Alkis Evlogimenos alkis at cs.uiuc.edu
Sun Dec 28 12:05:00 PST 2003


Changes in directory llvm/lib/CodeGen:

RegAllocLinearScan.cpp updated: 1.20 -> 1.21

---
Log message:

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.


---
Diffs of the changes:  (+8 -8)

Index: llvm/lib/CodeGen/RegAllocLinearScan.cpp
diff -u llvm/lib/CodeGen/RegAllocLinearScan.cpp:1.20 llvm/lib/CodeGen/RegAllocLinearScan.cpp:1.21
--- llvm/lib/CodeGen/RegAllocLinearScan.cpp:1.20	Sun Dec 28 11:58:18 2003
+++ llvm/lib/CodeGen/RegAllocLinearScan.cpp	Sun Dec 28 12:03:52 2003
@@ -238,17 +238,17 @@
     // 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 */
 





More information about the llvm-commits mailing list