mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-04 10:30:01 +00:00
Add mechanism to select register allocator to use
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@5079 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b74e83c898
commit
439a27ac42
@ -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());
|
||||
|
Loading…
x
Reference in New Issue
Block a user