blob: 12b0411065ad192054f012174922d53585ec4e9d [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) {
Tim Northover037f26f22014-04-17 18:22:47 +000023 initializeAtomicExpandLoadLinkedPass(Registry);
Chandler Carruth664e3542013-01-07 01:37:14 +000024 initializeBasicTTIPass(Registry);
Andrew Trick58648e42012-02-08 21:22:48 +000025 initializeBranchFolderPassPass(Registry);
Quentin Colombeta3490842014-02-22 00:07:45 +000026 initializeCodeGenPreparePass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000027 initializeDeadMachineInstructionElimPass(Registry);
Jakob Stoklund Olesenf8a63a12012-07-04 00:09:54 +000028 initializeEarlyIfConverterPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000029 initializeExpandPostRAPass(Registry);
30 initializeExpandISelPseudosPass(Registry);
31 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);
Jakub Staszak875ebd52011-07-25 19:25:40 +000040 initializeMachineBlockFrequencyInfoPass(Registry);
Chandler Carruth10281422011-10-21 06:46:38 +000041 initializeMachineBlockPlacementPass(Registry);
Chandler Carruthae4e8002011-11-02 07:17:12 +000042 initializeMachineBlockPlacementStatsPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000043 initializeMachineCopyPropagationPass(Registry);
Gerolf Hoflehner5e1207e2014-08-03 21:35:39 +000044 initializeMachineCombinerPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000045 initializeMachineCSEPass(Registry);
46 initializeMachineDominatorTreePass(Registry);
Tom Stellard86af62c2012-09-17 14:08:37 +000047 initializeMachinePostDominatorTreePass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000048 initializeMachineLICMPass(Registry);
49 initializeMachineLoopInfoPass(Registry);
50 initializeMachineModuleInfoPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000051 initializeMachineSchedulerPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000052 initializeMachineSinkingPass(Registry);
53 initializeMachineVerifierPassPass(Registry);
54 initializeOptimizePHIsPass(Registry);
55 initializePHIEliminationPass(Registry);
56 initializePeepholeOptimizerPass(Registry);
Andrew Trick17080b92013-12-28 21:56:51 +000057 initializePostMachineSchedulerPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000058 initializePostRASchedulerPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000059 initializeProcessImplicitDefsPass(Registry);
60 initializePEIPass(Registry);
Rafael Espindola676c4052011-06-26 22:34:10 +000061 initializeRegisterCoalescerPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000062 initializeSlotIndexesPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000063 initializeStackProtectorPass(Registry);
Nadav Rotem7c277da2012-09-06 09:17:37 +000064 initializeStackColoringPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000065 initializeStackSlotColoringPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000066 initializeTailDuplicatePassPass(Registry);
Andrew Trickb7551332012-02-04 02:56:45 +000067 initializeTargetPassConfigPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000068 initializeTwoAddressInstructionPassPass(Registry);
Andrew Trick1fa5bcb2012-02-08 21:23:13 +000069 initializeUnpackMachineBundlesPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000070 initializeUnreachableBlockElimPass(Registry);
71 initializeUnreachableMachineBlockElimPass(Registry);
72 initializeVirtRegMapPass(Registry);
Jakob Stoklund Olesen12243122012-06-08 23:44:45 +000073 initializeVirtRegRewriterPass(Registry);
Owen Anderson6c18d1a2010-10-19 17:21:58 +000074 initializeLowerIntrinsicsPass(Registry);
Bob Wilson33e51882012-05-30 00:17:12 +000075 initializeMachineFunctionPrinterPassPass(Registry);
Juergen Ributzkae8294752013-12-14 06:53:06 +000076 initializeStackMapLivenessPass(Registry);
Owen Anderson80fc0762010-10-07 18:41:20 +000077}
78
79void LLVMInitializeCodeGen(LLVMPassRegistryRef R) {
80 initializeCodeGen(*unwrap(R));
81}