180fc0762SOwen Anderson //===-- CodeGen.cpp -------------------------------------------------------===// 280fc0762SOwen Anderson // 380fc0762SOwen Anderson // The LLVM Compiler Infrastructure 480fc0762SOwen Anderson // 580fc0762SOwen Anderson // This file is distributed under the University of Illinois Open Source 680fc0762SOwen Anderson // License. See LICENSE.TXT for details. 780fc0762SOwen Anderson // 880fc0762SOwen Anderson //===----------------------------------------------------------------------===// 980fc0762SOwen Anderson // 1080fc0762SOwen Anderson // This file implements the common initialization routines for the 1180fc0762SOwen Anderson // CodeGen library. 1280fc0762SOwen Anderson // 1380fc0762SOwen Anderson //===----------------------------------------------------------------------===// 1480fc0762SOwen Anderson 1580fc0762SOwen Anderson #include "llvm/InitializePasses.h" 1680fc0762SOwen Anderson #include "llvm-c/Initialization.h" 1780fc0762SOwen Anderson 1880fc0762SOwen Anderson using namespace llvm; 1980fc0762SOwen Anderson 2080fc0762SOwen Anderson /// initializeCodeGen - Initialize all passes linked into the CodeGen library. 2180fc0762SOwen Anderson void llvm::initializeCodeGen(PassRegistry &Registry) { 2280fc0762SOwen Anderson initializeCalculateSpillWeightsPass(Registry); 2380fc0762SOwen Anderson initializeDeadMachineInstructionElimPass(Registry); 2480fc0762SOwen Anderson initializeGCModuleInfoPass(Registry); 2580fc0762SOwen Anderson initializeIfConverterPass(Registry); 26d4900a64SJakob Stoklund Olesen initializeLiveDebugVariablesPass(Registry); 2780fc0762SOwen Anderson initializeLiveIntervalsPass(Registry); 2880fc0762SOwen Anderson initializeLiveStacksPass(Registry); 2980fc0762SOwen Anderson initializeLiveVariablesPass(Registry); 30875ebd5fSJakub Staszak initializeMachineBlockFrequencyInfoPass(Registry); 3110281425SChandler Carruth initializeMachineBlockPlacementPass(Registry); 32*ae4e800cSChandler Carruth initializeMachineBlockPlacementStatsPass(Registry); 3380fc0762SOwen Anderson initializeMachineCSEPass(Registry); 3480fc0762SOwen Anderson initializeMachineDominatorTreePass(Registry); 3580fc0762SOwen Anderson initializeMachineLICMPass(Registry); 3680fc0762SOwen Anderson initializeMachineLoopInfoPass(Registry); 3780fc0762SOwen Anderson initializeMachineModuleInfoPass(Registry); 3880fc0762SOwen Anderson initializeMachineSinkingPass(Registry); 3980fc0762SOwen Anderson initializeMachineVerifierPassPass(Registry); 4080fc0762SOwen Anderson initializeOptimizePHIsPass(Registry); 4180fc0762SOwen Anderson initializePHIEliminationPass(Registry); 4280fc0762SOwen Anderson initializePeepholeOptimizerPass(Registry); 4380fc0762SOwen Anderson initializeProcessImplicitDefsPass(Registry); 4480fc0762SOwen Anderson initializePEIPass(Registry); 4580fc0762SOwen Anderson initializeRALinScanPass(Registry); 46676c405aSRafael Espindola initializeRegisterCoalescerPass(Registry); 4780fc0762SOwen Anderson initializeRenderMachineFunctionPass(Registry); 4880fc0762SOwen Anderson initializeSlotIndexesPass(Registry); 4980fc0762SOwen Anderson initializeLoopSplitterPass(Registry); 5080fc0762SOwen Anderson initializeStackProtectorPass(Registry); 5180fc0762SOwen Anderson initializeStackSlotColoringPass(Registry); 5280fc0762SOwen Anderson initializeStrongPHIEliminationPass(Registry); 5380fc0762SOwen Anderson initializeTwoAddressInstructionPassPass(Registry); 5480fc0762SOwen Anderson initializeUnreachableBlockElimPass(Registry); 5580fc0762SOwen Anderson initializeUnreachableMachineBlockElimPass(Registry); 5680fc0762SOwen Anderson initializeVirtRegMapPass(Registry); 576c18d1aaSOwen Anderson initializeLowerIntrinsicsPass(Registry); 5880fc0762SOwen Anderson } 5980fc0762SOwen Anderson 6080fc0762SOwen Anderson void LLVMInitializeCodeGen(LLVMPassRegistryRef R) { 6180fc0762SOwen Anderson initializeCodeGen(*unwrap(R)); 6280fc0762SOwen Anderson } 63