blob: 3489db2e9f4f966a401ff9c7ac1ccbf1e58b2f62 [file] [log] [blame]
Chris Lattner27dd6422003-12-28 07:59:53 +00001//===-- Passes.cpp - Target independent code generation passes ------------===//
Misha Brukman835702a2005-04-21 22:36:52 +00002//
John Criswell482202a2003-10-20 19:43:21 +00003// The LLVM Compiler Infrastructure
4//
Chris Lattnerf3ebc3f2007-12-29 20:36:04 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Misha Brukman835702a2005-04-21 22:36:52 +00007//
John Criswell482202a2003-10-20 19:43:21 +00008//===----------------------------------------------------------------------===//
Alkis Evlogimenos5facafa2003-10-02 16:57:49 +00009//
10// This file defines interfaces to access the target independent code
11// generation passes provided by the LLVM backend.
12//
13//===---------------------------------------------------------------------===//
14
Jim Laskey29e635d2006-08-02 12:30:23 +000015#include "llvm/CodeGen/RegAllocRegistry.h"
Alkis Evlogimenos5facafa2003-10-02 16:57:49 +000016#include "llvm/CodeGen/Passes.h"
Jim Laskey95eda5b2006-08-01 14:21:23 +000017
Chris Lattner27dd6422003-12-28 07:59:53 +000018using namespace llvm;
Brian Gaeke960707c2003-11-11 22:41:34 +000019
Jim Laskey29e635d2006-08-02 12:30:23 +000020//===---------------------------------------------------------------------===//
21///
22/// RegisterRegAlloc class - Track the registration of register allocators.
23///
24//===---------------------------------------------------------------------===//
25MachinePassRegistry RegisterRegAlloc::Registry;
26
Jakob Stoklund Olesenb613ae22010-05-27 23:57:25 +000027static FunctionPass *createDefaultRegisterAllocator() { return 0; }
28static RegisterRegAlloc
29defaultRegAlloc("default",
30 "pick register allocator based on -O option",
31 createDefaultRegisterAllocator);
Jim Laskey29e635d2006-08-02 12:30:23 +000032
33//===---------------------------------------------------------------------===//
34///
35/// RegAlloc command line options.
36///
37//===---------------------------------------------------------------------===//
Dan Gohmand78c4002008-05-13 00:00:25 +000038static cl::opt<RegisterRegAlloc::FunctionPassCtor, false,
39 RegisterPassParser<RegisterRegAlloc> >
40RegAlloc("regalloc",
Jakob Stoklund Olesenb613ae22010-05-27 23:57:25 +000041 cl::init(&createDefaultRegisterAllocator),
42 cl::desc("Register allocator to use"));
Alkis Evlogimenos5facafa2003-10-02 16:57:49 +000043
Jim Laskey29e635d2006-08-02 12:30:23 +000044
45//===---------------------------------------------------------------------===//
46///
47/// createRegisterAllocator - choose the appropriate register allocator.
48///
49//===---------------------------------------------------------------------===//
Jakob Stoklund Olesenb613ae22010-05-27 23:57:25 +000050FunctionPass *llvm::createRegisterAllocator(CodeGenOpt::Level OptLevel) {
Jim Laskey03593f72006-08-01 18:29:48 +000051 RegisterRegAlloc::FunctionPassCtor Ctor = RegisterRegAlloc::getDefault();
Jakob Stoklund Olesenb613ae22010-05-27 23:57:25 +000052
Jim Laskey95eda5b2006-08-01 14:21:23 +000053 if (!Ctor) {
Jim Laskey29e635d2006-08-02 12:30:23 +000054 Ctor = RegAlloc;
55 RegisterRegAlloc::setDefault(RegAlloc);
Jim Laskey95eda5b2006-08-01 14:21:23 +000056 }
Jakob Stoklund Olesenb613ae22010-05-27 23:57:25 +000057
58 if (Ctor != createDefaultRegisterAllocator)
59 return Ctor();
60
61 // When the 'default' allocator is requested, pick one based on OptLevel.
62 switch (OptLevel) {
63 case CodeGenOpt::None:
Jakob Stoklund Olesen40295962010-06-03 00:39:06 +000064 return createFastRegisterAllocator();
Jakob Stoklund Olesenb613ae22010-05-27 23:57:25 +000065 default:
66 return createLinearScanRegisterAllocator();
67 }
Jim Laskeyd1a714e2006-07-27 20:05:00 +000068}