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