blob: c838e6fb31b9a12180715d17c44d78e5a6ecc3b8 [file] [log] [blame]
Owen Anderson78b15242010-10-07 18:41:20 +00001//===-- CodeGen.cpp -------------------------------------------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This file implements the common initialization routines for the
11// CodeGen library.
12//
13//===----------------------------------------------------------------------===//
14
15#include "llvm/InitializePasses.h"
16#include "llvm-c/Initialization.h"
17
18using namespace llvm;
19
20/// initializeCodeGen - Initialize all passes linked into the CodeGen library.
21void llvm::initializeCodeGen(PassRegistry &Registry) {
Andrew Trick61f1e3d2012-02-08 21:22:48 +000022 initializeBranchFolderPassPass(Registry);
Owen Anderson78b15242010-10-07 18:41:20 +000023 initializeCalculateSpillWeightsPass(Registry);
24 initializeDeadMachineInstructionElimPass(Registry);
25 initializeGCModuleInfoPass(Registry);
26 initializeIfConverterPass(Registry);
Jakob Stoklund Olesenbb7b23f2010-11-30 02:17:10 +000027 initializeLiveDebugVariablesPass(Registry);
Owen Anderson78b15242010-10-07 18:41:20 +000028 initializeLiveIntervalsPass(Registry);
29 initializeLiveStacksPass(Registry);
30 initializeLiveVariablesPass(Registry);
Jakub Staszakf55c1c82011-07-25 19:25:40 +000031 initializeMachineBlockFrequencyInfoPass(Registry);
Chandler Carruthdb350872011-10-21 06:46:38 +000032 initializeMachineBlockPlacementPass(Registry);
Chandler Carruth37efc9f2011-11-02 07:17:12 +000033 initializeMachineBlockPlacementStatsPass(Registry);
Owen Anderson78b15242010-10-07 18:41:20 +000034 initializeMachineCSEPass(Registry);
35 initializeMachineDominatorTreePass(Registry);
36 initializeMachineLICMPass(Registry);
37 initializeMachineLoopInfoPass(Registry);
38 initializeMachineModuleInfoPass(Registry);
39 initializeMachineSinkingPass(Registry);
40 initializeMachineVerifierPassPass(Registry);
41 initializeOptimizePHIsPass(Registry);
42 initializePHIEliminationPass(Registry);
43 initializePeepholeOptimizerPass(Registry);
Owen Anderson78b15242010-10-07 18:41:20 +000044 initializeProcessImplicitDefsPass(Registry);
45 initializePEIPass(Registry);
Rafael Espindola5b220212011-06-26 22:34:10 +000046 initializeRegisterCoalescerPass(Registry);
Andrew Trick42b7a712012-01-17 06:55:03 +000047 initializeMachineSchedulerPass(Registry);
Owen Anderson78b15242010-10-07 18:41:20 +000048 initializeRenderMachineFunctionPass(Registry);
Owen Anderson78b15242010-10-07 18:41:20 +000049 initializeSlotIndexesPass(Registry);
Owen Anderson78b15242010-10-07 18:41:20 +000050 initializeStackProtectorPass(Registry);
51 initializeStackSlotColoringPass(Registry);
52 initializeStrongPHIEliminationPass(Registry);
Andrew Trick74613342012-02-04 02:56:45 +000053 initializeTargetPassConfigPass(Registry);
Owen Anderson78b15242010-10-07 18:41:20 +000054 initializeTwoAddressInstructionPassPass(Registry);
55 initializeUnreachableBlockElimPass(Registry);
56 initializeUnreachableMachineBlockElimPass(Registry);
57 initializeVirtRegMapPass(Registry);
Owen Anderson081c34b2010-10-19 17:21:58 +000058 initializeLowerIntrinsicsPass(Registry);
Owen Anderson78b15242010-10-07 18:41:20 +000059}
60
61void LLVMInitializeCodeGen(LLVMPassRegistryRef R) {
62 initializeCodeGen(*unwrap(R));
63}