1f22ef01cSRoman Divacky //===-- MachineFunctionPass.cpp -------------------------------------------===// 2f22ef01cSRoman Divacky // 3f22ef01cSRoman Divacky // The LLVM Compiler Infrastructure 4f22ef01cSRoman Divacky // 5f22ef01cSRoman Divacky // This file is distributed under the University of Illinois Open Source 6f22ef01cSRoman Divacky // License. See LICENSE.TXT for details. 7f22ef01cSRoman Divacky // 8f22ef01cSRoman Divacky //===----------------------------------------------------------------------===// 9f22ef01cSRoman Divacky // 10f22ef01cSRoman Divacky // This file contains the definitions of the MachineFunctionPass members. 11f22ef01cSRoman Divacky // 12f22ef01cSRoman Divacky //===----------------------------------------------------------------------===// 13f22ef01cSRoman Divacky 14f22ef01cSRoman Divacky #include "llvm/Function.h" 15f22ef01cSRoman Divacky #include "llvm/Analysis/AliasAnalysis.h" 16f22ef01cSRoman Divacky #include "llvm/CodeGen/MachineFunctionAnalysis.h" 17f22ef01cSRoman Divacky #include "llvm/CodeGen/MachineFunctionPass.h" 18f22ef01cSRoman Divacky #include "llvm/CodeGen/Passes.h" 19f22ef01cSRoman Divacky using namespace llvm; 20f22ef01cSRoman Divacky 21f22ef01cSRoman Divacky Pass *MachineFunctionPass::createPrinterPass(raw_ostream &O, 22f22ef01cSRoman Divacky const std::string &Banner) const { 23f22ef01cSRoman Divacky return createMachineFunctionPrinterPass(O, Banner); 24f22ef01cSRoman Divacky } 25f22ef01cSRoman Divacky 26f22ef01cSRoman Divacky bool MachineFunctionPass::runOnFunction(Function &F) { 27f22ef01cSRoman Divacky // Do not codegen any 'available_externally' functions at all, they have 28f22ef01cSRoman Divacky // definitions outside the translation unit. 29f22ef01cSRoman Divacky if (F.hasAvailableExternallyLinkage()) 30f22ef01cSRoman Divacky return false; 31f22ef01cSRoman Divacky 32f22ef01cSRoman Divacky MachineFunction &MF = getAnalysis<MachineFunctionAnalysis>().getMF(); 33f22ef01cSRoman Divacky return runOnMachineFunction(MF); 34f22ef01cSRoman Divacky } 35f22ef01cSRoman Divacky 36f22ef01cSRoman Divacky void MachineFunctionPass::getAnalysisUsage(AnalysisUsage &AU) const { 37f22ef01cSRoman Divacky AU.addRequired<MachineFunctionAnalysis>(); 38f22ef01cSRoman Divacky AU.addPreserved<MachineFunctionAnalysis>(); 39f22ef01cSRoman Divacky 40f22ef01cSRoman Divacky // MachineFunctionPass preserves all LLVM IR passes, but there's no 41f22ef01cSRoman Divacky // high-level way to express this. Instead, just list a bunch of 42f22ef01cSRoman Divacky // passes explicitly. This does not include setPreservesCFG, 43f22ef01cSRoman Divacky // because CodeGen overloads that to mean preserving the MachineBasicBlock 44f22ef01cSRoman Divacky // CFG in addition to the LLVM IR CFG. 45f22ef01cSRoman Divacky AU.addPreserved<AliasAnalysis>(); 46f22ef01cSRoman Divacky AU.addPreserved("scalar-evolution"); 47f22ef01cSRoman Divacky AU.addPreserved("iv-users"); 48f22ef01cSRoman Divacky AU.addPreserved("memdep"); 49f22ef01cSRoman Divacky AU.addPreserved("live-values"); 50f22ef01cSRoman Divacky AU.addPreserved("domtree"); 51f22ef01cSRoman Divacky AU.addPreserved("domfrontier"); 52f22ef01cSRoman Divacky AU.addPreserved("loops"); 53f22ef01cSRoman Divacky AU.addPreserved("lda"); 54f22ef01cSRoman Divacky 55f22ef01cSRoman Divacky FunctionPass::getAnalysisUsage(AU); 56f22ef01cSRoman Divacky } 57