aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/Target/X86/X86TargetMachine.cpp13
1 files changed, 11 insertions, 2 deletions
diff --git a/lib/Target/X86/X86TargetMachine.cpp b/lib/Target/X86/X86TargetMachine.cpp
index d710eb473d..cdb7dea415 100644
--- a/lib/Target/X86/X86TargetMachine.cpp
+++ b/lib/Target/X86/X86TargetMachine.cpp
@@ -8,11 +8,17 @@
#include "llvm/Transforms/Scalar.h"
#include "llvm/Target/TargetMachineImpls.h"
#include "llvm/CodeGen/MachineFunction.h"
-#include "Support/Statistic.h"
#include "llvm/PassManager.h"
#include "X86.h"
+#include "Support/CommandLine.h"
+#include "Support/Statistic.h"
#include <iostream>
+namespace {
+ cl::opt<bool> UseLocalRA("local-ra",
+ cl::desc("Use Local RegAlloc instead of Simple RA"));
+}
+
// allocateX86TargetMachine - Allocate and return a subclass of TargetMachine
// that implements the X86 backend.
//
@@ -43,7 +49,10 @@ bool X86TargetMachine::addPassesToJITCompile(PassManager &PM) {
DEBUG(PM.add(createMachineFunctionPrinterPass()));
// Perform register allocation to convert to a concrete x86 representation
- PM.add(createSimpleRegisterAllocator(*this));
+ if (UseLocalRA)
+ PM.add(createLocalRegisterAllocator(*this));
+ else
+ PM.add(createSimpleRegisterAllocator(*this));
// Print the instruction selected machine code...
// PM.add(createMachineFunctionPrinterPass());