mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-13 23:18:51 +00:00
b95fc31aa2
and code model. This eliminates the need to pass OptLevel flag all over the place and makes it possible for any codegen pass to use this information. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@144788 91177308-0d34-0410-b5e6-96231b3b80d8
58 lines
1.8 KiB
C++
58 lines
1.8 KiB
C++
//===-- MachineFunctionAnalysis.cpp ---------------------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file contains the definitions of the MachineFunctionAnalysis members.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/CodeGen/MachineFunctionAnalysis.h"
|
|
#include "llvm/CodeGen/GCMetadata.h"
|
|
#include "llvm/CodeGen/MachineFunction.h"
|
|
#include "llvm/CodeGen/MachineModuleInfo.h"
|
|
using namespace llvm;
|
|
|
|
char MachineFunctionAnalysis::ID = 0;
|
|
|
|
MachineFunctionAnalysis::MachineFunctionAnalysis(const TargetMachine &tm) :
|
|
FunctionPass(ID), TM(tm), MF(0) {
|
|
initializeMachineModuleInfoPass(*PassRegistry::getPassRegistry());
|
|
}
|
|
|
|
MachineFunctionAnalysis::~MachineFunctionAnalysis() {
|
|
releaseMemory();
|
|
assert(!MF && "MachineFunctionAnalysis left initialized!");
|
|
}
|
|
|
|
void MachineFunctionAnalysis::getAnalysisUsage(AnalysisUsage &AU) const {
|
|
AU.setPreservesAll();
|
|
AU.addRequired<MachineModuleInfo>();
|
|
}
|
|
|
|
bool MachineFunctionAnalysis::doInitialization(Module &M) {
|
|
MachineModuleInfo *MMI = getAnalysisIfAvailable<MachineModuleInfo>();
|
|
assert(MMI && "MMI not around yet??");
|
|
MMI->setModule(&M);
|
|
NextFnNum = 0;
|
|
return false;
|
|
}
|
|
|
|
|
|
bool MachineFunctionAnalysis::runOnFunction(Function &F) {
|
|
assert(!MF && "MachineFunctionAnalysis already initialized!");
|
|
MF = new MachineFunction(&F, TM, NextFnNum++,
|
|
getAnalysis<MachineModuleInfo>(),
|
|
getAnalysisIfAvailable<GCModuleInfo>());
|
|
return false;
|
|
}
|
|
|
|
void MachineFunctionAnalysis::releaseMemory() {
|
|
delete MF;
|
|
MF = 0;
|
|
}
|