Fix a spelling error in the description of a statistic. NFC
[oota-llvm.git] / lib / CodeGen / CodeGen.cpp
1 //===-- 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 #include "llvm/PassRegistry.h"
18
19 using namespace llvm;
20
21 /// initializeCodeGen - Initialize all passes linked into the CodeGen library.
22 void llvm::initializeCodeGen(PassRegistry &Registry) {
23   initializeAtomicExpandPass(Registry);
24   initializeBranchFolderPassPass(Registry);
25   initializeCodeGenPreparePass(Registry);
26   initializeDeadMachineInstructionElimPass(Registry);
27   initializeDwarfEHPreparePass(Registry);
28   initializeEarlyIfConverterPass(Registry);
29   initializeExpandISelPseudosPass(Registry);
30   initializeExpandPostRAPass(Registry);
31   initializeFinalizeMachineBundlesPass(Registry);
32   initializeGCMachineCodeAnalysisPass(Registry);
33   initializeGCModuleInfoPass(Registry);
34   initializeIfConverterPass(Registry);
35   initializeLiveDebugVariablesPass(Registry);
36   initializeLiveIntervalsPass(Registry);
37   initializeLiveStacksPass(Registry);
38   initializeLiveVariablesPass(Registry);
39   initializeLocalStackSlotPassPass(Registry);
40   initializeLowerIntrinsicsPass(Registry);
41   initializeMachineBlockFrequencyInfoPass(Registry);
42   initializeMachineBlockPlacementPass(Registry);
43   initializeMachineBlockPlacementStatsPass(Registry);
44   initializeMachineCSEPass(Registry);
45   initializeImplicitNullChecksPass(Registry);
46   initializeMachineCombinerPass(Registry);
47   initializeMachineCopyPropagationPass(Registry);
48   initializeMachineDominatorTreePass(Registry);
49   initializeMachineFunctionPrinterPassPass(Registry);
50   initializeMachineLICMPass(Registry);
51   initializeMachineLoopInfoPass(Registry);
52   initializeMachineModuleInfoPass(Registry);
53   initializeMachinePostDominatorTreePass(Registry);
54   initializeMachineSchedulerPass(Registry);
55   initializeMachineSinkingPass(Registry);
56   initializeMachineVerifierPassPass(Registry);
57   initializeOptimizePHIsPass(Registry);
58   initializePEIPass(Registry);
59   initializePHIEliminationPass(Registry);
60   initializePeepholeOptimizerPass(Registry);
61   initializePostMachineSchedulerPass(Registry);
62   initializePostRASchedulerPass(Registry);
63   initializeProcessImplicitDefsPass(Registry);
64   initializeRegisterCoalescerPass(Registry);
65   initializeShrinkWrapPass(Registry);
66   initializeSlotIndexesPass(Registry);
67   initializeStackColoringPass(Registry);
68   initializeStackMapLivenessPass(Registry);
69   initializeStackProtectorPass(Registry);
70   initializeStackSlotColoringPass(Registry);
71   initializeTailDuplicatePassPass(Registry);
72   initializeTargetPassConfigPass(Registry);
73   initializeTwoAddressInstructionPassPass(Registry);
74   initializeUnpackMachineBundlesPass(Registry);
75   initializeUnreachableBlockElimPass(Registry);
76   initializeUnreachableMachineBlockElimPass(Registry);
77   initializeVirtRegMapPass(Registry);
78   initializeVirtRegRewriterPass(Registry);
79   initializeWinEHPreparePass(Registry);
80 }
81
82 void LLVMInitializeCodeGen(LLVMPassRegistryRef R) {
83   initializeCodeGen(*unwrap(R));
84 }