From a578cb7a65662415a0321caf6cffe2fb526fe5e6 Mon Sep 17 00:00:00 2001 From: Tanya Lattner Date: Mon, 24 May 2004 06:11:51 +0000 Subject: Added MachineFunction parent* to MachineBasicBlock. Customized ilist template to set the parent when a MachineBasicBlock is added to a MachineFunction. llvm-svn: 13716 --- llvm/lib/CodeGen/MachineBasicBlock.cpp | 29 +++++++++++++++-------------- llvm/lib/CodeGen/MachineFunction.cpp | 19 +++++++++++++++++++ 2 files changed, 34 insertions(+), 14 deletions(-) (limited to 'llvm/lib/CodeGen') diff --git a/llvm/lib/CodeGen/MachineBasicBlock.cpp b/llvm/lib/CodeGen/MachineBasicBlock.cpp index 64f735c48e6..c0b144d26c3 100644 --- a/llvm/lib/CodeGen/MachineBasicBlock.cpp +++ b/llvm/lib/CodeGen/MachineBasicBlock.cpp @@ -20,29 +20,25 @@ #include "Support/LeakDetector.h" using namespace llvm; -const MachineFunction *MachineBasicBlock::getParent() const { - // Get the parent by getting the Function parent of the basic block, and - // getting the MachineFunction from it. - return &MachineFunction::get(getBasicBlock()->getParent()); -} - -MachineFunction *MachineBasicBlock::getParent() { - // Get the parent by getting the Function parent of the basic block, and - // getting the MachineFunction from it. - return &MachineFunction::get(getBasicBlock()->getParent()); -} - // MBBs start out as #-1. When a MBB is added to a MachineFunction, it // gets the next available unique MBB number. If it is removed from a // MachineFunction, it goes back to being #-1. void ilist_traits::addNodeToList (MachineBasicBlock* N) { - N->Number = N->getParent ()->getNextMBBNumber (); + assert(N->Parent == 0 && "machine instruction already in a basic block"); + N->Parent = parent; + N->Number = parent->getNextMBBNumber(); + LeakDetector::removeGarbageObject(N); + + } void ilist_traits::removeNodeFromList (MachineBasicBlock* N) { + assert(N->Parent != 0 && "machine instruction not in a basic block"); + N->Parent = 0; N->Number = -1; + LeakDetector::addGarbageObject(N); } @@ -93,8 +89,13 @@ void MachineBasicBlock::dump() const void MachineBasicBlock::print(std::ostream &OS) const { + if(!getParent()) { + OS << "Can't print out MachineBasicBlock because parent MachineFunction is null\n"; + return; + } const BasicBlock *LBB = getBasicBlock(); - OS << "\n" << LBB->getName() << " (" << (const void*)LBB << "):\n"; + if(LBB) + OS << "\n" << LBB->getName() << " (" << (const void*)LBB << "):\n"; for (const_iterator I = begin(); I != end(); ++I) { OS << "\t"; I->print(OS, getParent()->getTarget()); diff --git a/llvm/lib/CodeGen/MachineFunction.cpp b/llvm/lib/CodeGen/MachineFunction.cpp index f0b06378cad..a3e9211f5c3 100644 --- a/llvm/lib/CodeGen/MachineFunction.cpp +++ b/llvm/lib/CodeGen/MachineFunction.cpp @@ -24,6 +24,8 @@ #include "llvm/Target/TargetFrameInfo.h" #include "llvm/Function.h" #include "llvm/iOther.h" +#include "Support/LeakDetector.h" + using namespace llvm; static AnnotationID MF_AID( @@ -84,6 +86,22 @@ FunctionPass *llvm::createMachineCodeDeleter() { //===---------------------------------------------------------------------===// // MachineFunction implementation //===---------------------------------------------------------------------===// +MachineBasicBlock* ilist_traits::createNode() +{ + MachineBasicBlock* dummy = new MachineBasicBlock(); + LeakDetector::removeGarbageObject(dummy); + return dummy; +} + +void ilist_traits::transferNodesFromList( + iplist >& toList, + ilist_iterator first, + ilist_iterator last) +{ + if (parent != toList.parent) + for (; first != last; ++first) + first->Parent = toList.parent; +} MachineFunction::MachineFunction(const Function *F, const TargetMachine &TM) @@ -92,6 +110,7 @@ MachineFunction::MachineFunction(const Function *F, MFInfo = new MachineFunctionInfo(*this); FrameInfo = new MachineFrameInfo(); ConstantPool = new MachineConstantPool(); + BasicBlocks.parent = this; } MachineFunction::~MachineFunction() { -- cgit v1.2.3