[llvm-commits] [regalloc_linearscan] CVS: llvm/lib/Target/X86/X86TargetMachine.cpp
Alkis Evlogimenos
alkis at cs.uiuc.edu
Wed Oct 1 14:42:00 PDT 2003
Changes in directory llvm/lib/Target/X86:
X86TargetMachine.cpp updated: 1.25 -> 1.25.2.1
---
Log message:
Added command line option for linear scan allocator
---
Diffs of the changes:
Index: llvm/lib/Target/X86/X86TargetMachine.cpp
diff -u llvm/lib/Target/X86/X86TargetMachine.cpp:1.25 llvm/lib/Target/X86/X86TargetMachine.cpp:1.25.2.1
--- llvm/lib/Target/X86/X86TargetMachine.cpp:1.25 Sun Aug 24 14:49:48 2003
+++ llvm/lib/Target/X86/X86TargetMachine.cpp Wed Oct 1 14:41:38 2003
@@ -16,6 +16,14 @@
#include "Support/Statistic.h"
namespace {
+ cl::opt<RegAllocName>
+ RegAlloc("regalloc",
+ cl::desc("Register allocator to use:"), cl::Prefix,
+ cl::values(clEnumVal(simple, "simple register allocator)"),
+ clEnumVal(local, "local register allocator"),
+ clEnumVal(linearscan, "linear scan global register allocator")),
+ cl::init(local));
+
cl::opt<bool> NoLocalRA("disable-local-ra",
cl::desc("Use Simple RA instead of Local RegAlloc"));
cl::opt<bool> PrintCode("print-machineinstrs",
@@ -113,10 +121,19 @@
PM.add(createMachineFunctionPrinterPass());
// Perform register allocation to convert to a concrete x86 representation
- if (NoLocalRA)
+ switch (RegAlloc) {
+ case simple:
PM.add(createSimpleRegisterAllocator());
- else
+ break;
+ case local:
PM.add(createLocalRegisterAllocator());
+ break;
+ case linearscan:
+ PM.add(createLinearScanRegisterAllocator());
+ break;
+ default:
+ assert(0 && "no register allocator selected");
+ }
if (PrintCode)
PM.add(createMachineFunctionPrinterPass());
More information about the llvm-commits
mailing list