74 lines
2.9 KiB
C++
74 lines
2.9 KiB
C++
|
//===-- CodeGen.cpp -------------------------------------------------------===//
|
||
|
//
|
||
|
// The LLVM Compiler Infrastructure
|
||
|
//
|
||
|
// This file is distributed under the University of Illinois Open Source
|
||
|
// License. See LICENSE.TXT for details.
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
//
|
||
|
// This file implements the common initialization routines for the
|
||
|
// CodeGen library.
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
|
||
|
#include "llvm/InitializePasses.h"
|
||
|
#include "llvm-c/Initialization.h"
|
||
|
|
||
|
using namespace llvm;
|
||
|
|
||
|
/// initializeCodeGen - Initialize all passes linked into the CodeGen library.
|
||
|
void llvm::initializeCodeGen(PassRegistry &Registry) {
|
||
|
initializeBranchFolderPassPass(Registry);
|
||
|
initializeCalculateSpillWeightsPass(Registry);
|
||
|
initializeCodePlacementOptPass(Registry);
|
||
|
initializeDeadMachineInstructionElimPass(Registry);
|
||
|
initializeExpandPostRAPass(Registry);
|
||
|
initializeExpandISelPseudosPass(Registry);
|
||
|
initializeFinalizeMachineBundlesPass(Registry);
|
||
|
initializeGCMachineCodeAnalysisPass(Registry);
|
||
|
initializeGCModuleInfoPass(Registry);
|
||
|
initializeIfConverterPass(Registry);
|
||
|
initializeLiveDebugVariablesPass(Registry);
|
||
|
initializeLiveIntervalsPass(Registry);
|
||
|
initializeLiveStacksPass(Registry);
|
||
|
initializeLiveVariablesPass(Registry);
|
||
|
initializeLocalStackSlotPassPass(Registry);
|
||
|
initializeMachineBlockFrequencyInfoPass(Registry);
|
||
|
initializeMachineBlockPlacementPass(Registry);
|
||
|
initializeMachineBlockPlacementStatsPass(Registry);
|
||
|
initializeMachineCopyPropagationPass(Registry);
|
||
|
initializeMachineCSEPass(Registry);
|
||
|
initializeMachineDominatorTreePass(Registry);
|
||
|
initializeMachineLICMPass(Registry);
|
||
|
initializeMachineLoopInfoPass(Registry);
|
||
|
initializeMachineModuleInfoPass(Registry);
|
||
|
initializeMachineSchedulerPass(Registry);
|
||
|
initializeMachineSinkingPass(Registry);
|
||
|
initializeMachineVerifierPassPass(Registry);
|
||
|
initializeOptimizePHIsPass(Registry);
|
||
|
initializePHIEliminationPass(Registry);
|
||
|
initializePeepholeOptimizerPass(Registry);
|
||
|
initializePostRASchedulerPass(Registry);
|
||
|
initializeProcessImplicitDefsPass(Registry);
|
||
|
initializePEIPass(Registry);
|
||
|
initializeRegisterCoalescerPass(Registry);
|
||
|
initializeRenderMachineFunctionPass(Registry);
|
||
|
initializeSlotIndexesPass(Registry);
|
||
|
initializeStackProtectorPass(Registry);
|
||
|
initializeStackSlotColoringPass(Registry);
|
||
|
initializeStrongPHIEliminationPass(Registry);
|
||
|
initializeTailDuplicatePassPass(Registry);
|
||
|
initializeTargetPassConfigPass(Registry);
|
||
|
initializeTwoAddressInstructionPassPass(Registry);
|
||
|
initializeUnpackMachineBundlesPass(Registry);
|
||
|
initializeUnreachableBlockElimPass(Registry);
|
||
|
initializeUnreachableMachineBlockElimPass(Registry);
|
||
|
initializeVirtRegMapPass(Registry);
|
||
|
initializeLowerIntrinsicsPass(Registry);
|
||
|
}
|
||
|
|
||
|
void LLVMInitializeCodeGen(LLVMPassRegistryRef R) {
|
||
|
initializeCodeGen(*unwrap(R));
|
||
|
}
|