blob: 7c0068eae155d96c01d3c20e3ba648e3dcd913db [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);
Jakob Stoklund Olesenf8a63a12012-07-04 00:09:54 +000027 initializeEarlyIfConverterPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000028 initializeExpandPostRAPass(Registry);
29 initializeExpandISelPseudosPass(Registry);
30 initializeFinalizeMachineBundlesPass(Registry);
31 initializeGCMachineCodeAnalysisPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000032 initializeGCModuleInfoPass(Registry);
33 initializeIfConverterPass(Registry);
Jakob Stoklund Olesend4900a62010-11-30 02:17:10 +000034 initializeLiveDebugVariablesPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000035 initializeLiveIntervalsPass(Registry);
36 initializeLiveStacksPass(Registry);
37 initializeLiveVariablesPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000038 initializeLocalStackSlotPassPass(Registry);
Jakub Staszak875ebd52011-07-25 19:25:40 +000039 initializeMachineBlockFrequencyInfoPass(Registry);
Chandler Carruth10281422011-10-21 06:46:38 +000040 initializeMachineBlockPlacementPass(Registry);
Chandler Carruthae4e8002011-11-02 07:17:12 +000041 initializeMachineBlockPlacementStatsPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000042 initializeMachineCopyPropagationPass(Registry);
Gerolf Hoflehner5e1207e2014-08-03 21:35:39 +000043 initializeMachineCombinerPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000044 initializeMachineCSEPass(Registry);
45 initializeMachineDominatorTreePass(Registry);
Tom Stellard86af62c2012-09-17 14:08:37 +000046 initializeMachinePostDominatorTreePass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000047 initializeMachineLICMPass(Registry);
48 initializeMachineLoopInfoPass(Registry);
49 initializeMachineModuleInfoPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000050 initializeMachineSchedulerPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000051 initializeMachineSinkingPass(Registry);
52 initializeMachineVerifierPassPass(Registry);
53 initializeOptimizePHIsPass(Registry);
54 initializePHIEliminationPass(Registry);
55 initializePeepholeOptimizerPass(Registry);
Andrew Trick17080b92013-12-28 21:56:51 +000056 initializePostMachineSchedulerPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000057 initializePostRASchedulerPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000058 initializeProcessImplicitDefsPass(Registry);
59 initializePEIPass(Registry);
Rafael Espindola676c4052011-06-26 22:34:10 +000060 initializeRegisterCoalescerPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000061 initializeSlotIndexesPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000062 initializeStackProtectorPass(Registry);
Nadav Rotem7c277da2012-09-06 09:17:37 +000063 initializeStackColoringPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000064 initializeStackSlotColoringPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000065 initializeTailDuplicatePassPass(Registry);
Andrew Trickb7551332012-02-04 02:56:45 +000066 initializeTargetPassConfigPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000067 initializeTwoAddressInstructionPassPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000068 initializeUnpackMachineBundlesPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000069 initializeUnreachableBlockElimPass(Registry);
70 initializeUnreachableMachineBlockElimPass(Registry);
71 initializeVirtRegMapPass(Registry);
Jakob Stoklund Olesen12243122012-06-08 23:44:45 +000072 initializeVirtRegRewriterPass(Registry);
Owen Anderson6c18d1a2010-10-19 17:21:58 +000073 initializeLowerIntrinsicsPass(Registry);
Bob Wilson33e51882012-05-30 00:17:12 +000074 initializeMachineFunctionPrinterPassPass(Registry);
Juergen Ributzkae8294752013-12-14 06:53:06 +000075 initializeStackMapLivenessPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000076}
77
78void LLVMInitializeCodeGen(LLVMPassRegistryRef R) {
79 initializeCodeGen(*unwrap(R));
80}