blob: f2618282c3acb383f34d128e5f5cc25644275114 [file] [log] [blame]
Chris Lattneraa4c91f2003-12-28 07:59:53 +00001//===-- Passes.cpp - Target independent code generation passes ------------===//
Misha Brukmanedf128a2005-04-21 22:36:52 +00002//
John Criswellb576c942003-10-20 19:43:21 +00003// The LLVM Compiler Infrastructure
4//
Chris Lattner4ee451d2007-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 Brukmanedf128a2005-04-21 22:36:52 +00007//
John Criswellb576c942003-10-20 19:43:21 +00008//===----------------------------------------------------------------------===//
Alkis Evlogimenos7237ece2003-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 Laskeyeb577ba2006-08-02 12:30:23 +000015#include "llvm/CodeGen/RegAllocRegistry.h"
Alkis Evlogimenos7237ece2003-10-02 16:57:49 +000016#include "llvm/CodeGen/Passes.h"
Andrew Trick74613342012-02-04 02:56:45 +000017#include "llvm/Support/ErrorHandling.h"
Jim Laskey13ec7022006-08-01 14:21:23 +000018
Chris Lattneraa4c91f2003-12-28 07:59:53 +000019using namespace llvm;
Brian Gaeked0fde302003-11-11 22:41:34 +000020
Jim Laskeyeb577ba2006-08-02 12:30:23 +000021//===---------------------------------------------------------------------===//
Andrew Trick74613342012-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 Laskeyeb577ba2006-08-02 12:30:23 +000055///
56/// RegisterRegAlloc class - Track the registration of register allocators.
57///
58//===---------------------------------------------------------------------===//
59MachinePassRegistry RegisterRegAlloc::Registry;
60
Jakob Stoklund Olesen700bfad2010-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 Laskeyeb577ba2006-08-02 12:30:23 +000066
67//===---------------------------------------------------------------------===//
68///
69/// RegAlloc command line options.
70///
71//===---------------------------------------------------------------------===//
Dan Gohman844731a2008-05-13 00:00:25 +000072static cl::opt<RegisterRegAlloc::FunctionPassCtor, false,
73 RegisterPassParser<RegisterRegAlloc> >
74RegAlloc("regalloc",
Jakob Stoklund Olesen700bfad2010-05-27 23:57:25 +000075 cl::init(&createDefaultRegisterAllocator),
76 cl::desc("Register allocator to use"));
Alkis Evlogimenos7237ece2003-10-02 16:57:49 +000077
Jim Laskeyeb577ba2006-08-02 12:30:23 +000078
79//===---------------------------------------------------------------------===//
80///
81/// createRegisterAllocator - choose the appropriate register allocator.
82///
83//===---------------------------------------------------------------------===//
Jakob Stoklund Olesen700bfad2010-05-27 23:57:25 +000084FunctionPass *llvm::createRegisterAllocator(CodeGenOpt::Level OptLevel) {
Jim Laskey9ff542f2006-08-01 18:29:48 +000085 RegisterRegAlloc::FunctionPassCtor Ctor = RegisterRegAlloc::getDefault();
Jakob Stoklund Olesen700bfad2010-05-27 23:57:25 +000086
Jim Laskey13ec7022006-08-01 14:21:23 +000087 if (!Ctor) {
Jim Laskeyeb577ba2006-08-02 12:30:23 +000088 Ctor = RegAlloc;
89 RegisterRegAlloc::setDefault(RegAlloc);
Jim Laskey13ec7022006-08-01 14:21:23 +000090 }
Jakob Stoklund Olesen700bfad2010-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 Olesen8b89c642010-06-03 00:39:06 +000098 return createFastRegisterAllocator();
Jakob Stoklund Olesen700bfad2010-05-27 23:57:25 +000099 default:
Jakob Stoklund Olesen5aa32112011-04-30 01:37:54 +0000100 return createGreedyRegisterAllocator();
Jakob Stoklund Olesen700bfad2010-05-27 23:57:25 +0000101 }
Jim Laskey33a0a6d2006-07-27 20:05:00 +0000102}