blob: 155c5ecec7722189e2e78051638010e86c899fe2 [file] [log] [blame]
Owen Anderson80fc0762010-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"
Chandler Carruth8a8cd2b2014-01-07 11:48:04 +000017#include "llvm/PassRegistry.h"
Owen Anderson80fc0762010-10-07 18:41:20 +000018
19using namespace llvm;
20
21/// initializeCodeGen - Initialize all passes linked into the CodeGen library.
22void llvm::initializeCodeGen(PassRegistry &Registry) {
Robin Morisset59c23cd2014-08-21 21:50:01 +000023 initializeAtomicExpandPass(Registry);
Andrew Trick58648e42012-02-08 21:22:48 +000024 initializeBranchFolderPassPass(Registry);
Quentin Colombeta3490842014-02-22 00:07:45 +000025 initializeCodeGenPreparePass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000026 initializeDeadMachineInstructionElimPass(Registry);
Reid Klecknerbe0a0502015-03-09 22:45:16 +000027 initializeDwarfEHPreparePass(Registry);
Jakob Stoklund Olesenf8a63a12012-07-04 00:09:54 +000028 initializeEarlyIfConverterPass(Registry);
Chandler Carruth301ed0c2015-02-20 02:15:36 +000029 initializeExpandISelPseudosPass(Registry);
Reid Klecknerbe0a0502015-03-09 22:45:16 +000030 initializeExpandPostRAPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000031 initializeFinalizeMachineBundlesPass(Registry);
32 initializeGCMachineCodeAnalysisPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000033 initializeGCModuleInfoPass(Registry);
34 initializeIfConverterPass(Registry);
Jakob Stoklund Olesend4900a62010-11-30 02:17:10 +000035 initializeLiveDebugVariablesPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000036 initializeLiveIntervalsPass(Registry);
37 initializeLiveStacksPass(Registry);
38 initializeLiveVariablesPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000039 initializeLocalStackSlotPassPass(Registry);
Reid Klecknerbe0a0502015-03-09 22:45:16 +000040 initializeLowerIntrinsicsPass(Registry);
Jakub Staszak875ebd52011-07-25 19:25:40 +000041 initializeMachineBlockFrequencyInfoPass(Registry);
Chandler Carruth10281422011-10-21 06:46:38 +000042 initializeMachineBlockPlacementPass(Registry);
Chandler Carruthae4e8002011-11-02 07:17:12 +000043 initializeMachineBlockPlacementStatsPass(Registry);
Chandler Carruth301ed0c2015-02-20 02:15:36 +000044 initializeMachineCSEPass(Registry);
Sanjoy Das69fad072015-06-15 18:44:27 +000045 initializeImplicitNullChecksPass(Registry);
Reid Klecknerbe0a0502015-03-09 22:45:16 +000046 initializeMachineCombinerPass(Registry);
47 initializeMachineCopyPropagationPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000048 initializeMachineDominatorTreePass(Registry);
Reid Klecknerbe0a0502015-03-09 22:45:16 +000049 initializeMachineFunctionPrinterPassPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000050 initializeMachineLICMPass(Registry);
51 initializeMachineLoopInfoPass(Registry);
52 initializeMachineModuleInfoPass(Registry);
Reid Klecknerbe0a0502015-03-09 22:45:16 +000053 initializeMachinePostDominatorTreePass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000054 initializeMachineSchedulerPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000055 initializeMachineSinkingPass(Registry);
56 initializeMachineVerifierPassPass(Registry);
57 initializeOptimizePHIsPass(Registry);
Reid Klecknerbe0a0502015-03-09 22:45:16 +000058 initializePEIPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000059 initializePHIEliminationPass(Registry);
60 initializePeepholeOptimizerPass(Registry);
Andrew Trick17080b92013-12-28 21:56:51 +000061 initializePostMachineSchedulerPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000062 initializePostRASchedulerPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000063 initializeProcessImplicitDefsPass(Registry);
Rafael Espindola676c4052011-06-26 22:34:10 +000064 initializeRegisterCoalescerPass(Registry);
Quentin Colombet61b305e2015-05-05 17:38:16 +000065 initializeShrinkWrapPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000066 initializeSlotIndexesPass(Registry);
Chandler Carruth301ed0c2015-02-20 02:15:36 +000067 initializeStackColoringPass(Registry);
Reid Klecknerbe0a0502015-03-09 22:45:16 +000068 initializeStackMapLivenessPass(Registry);
69 initializeStackProtectorPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000070 initializeStackSlotColoringPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000071 initializeTailDuplicatePassPass(Registry);
Andrew Trickb7551332012-02-04 02:56:45 +000072 initializeTargetPassConfigPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000073 initializeTwoAddressInstructionPassPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000074 initializeUnpackMachineBundlesPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000075 initializeUnreachableBlockElimPass(Registry);
76 initializeUnreachableMachineBlockElimPass(Registry);
77 initializeVirtRegMapPass(Registry);
Jakob Stoklund Olesen12243122012-06-08 23:44:45 +000078 initializeVirtRegRewriterPass(Registry);
Reid Klecknerbe0a0502015-03-09 22:45:16 +000079 initializeWinEHPreparePass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000080}
81
82void LLVMInitializeCodeGen(LLVMPassRegistryRef R) {
83 initializeCodeGen(*unwrap(R));
84}