blob: f2618282c3acb383f34d128e5f5cc25644275114 [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"
Andrew Trickb7551332012-02-04 02:56:45 +000017#include "llvm/Support/ErrorHandling.h"
Jim Laskey95eda5b2006-08-01 14:21:23 +000018
Chris Lattner27dd6422003-12-28 07:59:53 +000019using namespace llvm;
Brian Gaeke960707c2003-11-11 22:41:34 +000020
Jim Laskey29e635d2006-08-02 12:30:23 +000021//===---------------------------------------------------------------------===//
Andrew Trickb7551332012-02-04 02:56:45 +000022/// TargetPassConfig
23//===---------------------------------------------------------------------===//
24
25INITIALIZE_PASS(TargetPassConfig, "targetpassconfig",
26 "Target Pass Configuration", false, false)
27char TargetPassConfig::ID = 0;
28
29// Out of line virtual method.
30TargetPassConfig::~TargetPassConfig() {}
31
32TargetPassConfig::TargetPassConfig(TargetMachine *tm, PassManagerBase &pm,
33 bool DisableVerifyFlag)
34 : ImmutablePass(ID), TM(tm), PM(pm), DisableVerify(DisableVerifyFlag) {
35 // Register all target independent codegen passes to activate their PassIDs,
36 // including this pass itself.
37 initializeCodeGen(*PassRegistry::getPassRegistry());
38}
39
40/// createPassConfig - Create a pass configuration object to be used by
41/// addPassToEmitX methods for generating a pipeline of CodeGen passes.
42///
43/// Targets may override this to extend TargetPassConfig.
44TargetPassConfig *LLVMTargetMachine::createPassConfig(PassManagerBase &PM,
45 bool DisableVerify) {
46 return new TargetPassConfig(this, PM, DisableVerify);
47}
48
49TargetPassConfig::TargetPassConfig()
50 : ImmutablePass(ID), PM(*(PassManagerBase*)0) {
51 llvm_unreachable("TargetPassConfig should not be constructed on-the-fly");
52}
53
54//===---------------------------------------------------------------------===//
Jim Laskey29e635d2006-08-02 12:30:23 +000055///
56/// RegisterRegAlloc class - Track the registration of register allocators.
57///
58//===---------------------------------------------------------------------===//
59MachinePassRegistry RegisterRegAlloc::Registry;
60
Jakob Stoklund Olesenb613ae22010-05-27 23:57:25 +000061static FunctionPass *createDefaultRegisterAllocator() { return 0; }
62static RegisterRegAlloc
63defaultRegAlloc("default",
64 "pick register allocator based on -O option",
65 createDefaultRegisterAllocator);
Jim Laskey29e635d2006-08-02 12:30:23 +000066
67//===---------------------------------------------------------------------===//
68///
69/// RegAlloc command line options.
70///
71//===---------------------------------------------------------------------===//
Dan Gohmand78c4002008-05-13 00:00:25 +000072static cl::opt<RegisterRegAlloc::FunctionPassCtor, false,
73 RegisterPassParser<RegisterRegAlloc> >
74RegAlloc("regalloc",
Jakob Stoklund Olesenb613ae22010-05-27 23:57:25 +000075 cl::init(&createDefaultRegisterAllocator),
76 cl::desc("Register allocator to use"));
Alkis Evlogimenos5facafa2003-10-02 16:57:49 +000077
Jim Laskey29e635d2006-08-02 12:30:23 +000078
79//===---------------------------------------------------------------------===//
80///
81/// createRegisterAllocator - choose the appropriate register allocator.
82///
83//===---------------------------------------------------------------------===//
Jakob Stoklund Olesenb613ae22010-05-27 23:57:25 +000084FunctionPass *llvm::createRegisterAllocator(CodeGenOpt::Level OptLevel) {
Jim Laskey03593f72006-08-01 18:29:48 +000085 RegisterRegAlloc::FunctionPassCtor Ctor = RegisterRegAlloc::getDefault();
Jakob Stoklund Olesenb613ae22010-05-27 23:57:25 +000086
Jim Laskey95eda5b2006-08-01 14:21:23 +000087 if (!Ctor) {
Jim Laskey29e635d2006-08-02 12:30:23 +000088 Ctor = RegAlloc;
89 RegisterRegAlloc::setDefault(RegAlloc);
Jim Laskey95eda5b2006-08-01 14:21:23 +000090 }
Jakob Stoklund Olesenb613ae22010-05-27 23:57:25 +000091
92 if (Ctor != createDefaultRegisterAllocator)
93 return Ctor();
94
95 // When the 'default' allocator is requested, pick one based on OptLevel.
96 switch (OptLevel) {
97 case CodeGenOpt::None:
Jakob Stoklund Olesen40295962010-06-03 00:39:06 +000098 return createFastRegisterAllocator();
Jakob Stoklund Olesenb613ae22010-05-27 23:57:25 +000099 default:
Jakob Stoklund Olesen6e399a62011-04-30 01:37:54 +0000100 return createGreedyRegisterAllocator();
Jakob Stoklund Olesenb613ae22010-05-27 23:57:25 +0000101 }
Jim Laskeyd1a714e2006-07-27 20:05:00 +0000102}