summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
Diffstat (limited to 'llvm')
-rw-r--r--llvm/include/llvm/BasicBlock.h8
-rw-r--r--llvm/lib/VMCore/BasicBlock.cpp7
2 files changed, 14 insertions, 1 deletions
diff --git a/llvm/include/llvm/BasicBlock.h b/llvm/include/llvm/BasicBlock.h
index c0922d62905..aa201c3c84b 100644
--- a/llvm/include/llvm/BasicBlock.h
+++ b/llvm/include/llvm/BasicBlock.h
@@ -29,12 +29,14 @@
class Instruction;
class Method;
class TerminatorInst;
+class MachineCodeForBasicBlock;
class BasicBlock : public Value { // Basic blocks are data objects also
public:
typedef ValueHolder<Instruction, BasicBlock, Method> InstListType;
private :
InstListType InstList;
+ MachineCodeForBasicBlock* machineInstrVec;
friend class ValueHolder<BasicBlock,Method,Method>;
void setParent(Method *parent);
@@ -67,6 +69,12 @@ public:
TerminatorInst *getTerminator();
const TerminatorInst *const getTerminator() const;
+
+ // Machine code accessor...
+ inline MachineCodeForBasicBlock& getMachineInstrVec() const {
+ return *machineInstrVec;
+ }
+
//===--------------------------------------------------------------------===//
// Instruction iterator methods
inline iterator begin() { return InstList.begin(); }
diff --git a/llvm/lib/VMCore/BasicBlock.cpp b/llvm/lib/VMCore/BasicBlock.cpp
index 04941075e3e..cf8fc41bd74 100644
--- a/llvm/lib/VMCore/BasicBlock.cpp
+++ b/llvm/lib/VMCore/BasicBlock.cpp
@@ -13,6 +13,7 @@
#include "llvm/Type.h"
#include "llvm/CFG.h"
#include "llvm/iOther.h"
+#include "llvm/CodeGen/MachineInstr.h"
// Instantiate Templates - This ugliness is the price we have to pay
// for having a ValueHolderImpl.h file seperate from ValueHolder.h! :(
@@ -20,7 +21,10 @@
template class ValueHolder<Instruction, BasicBlock, Method>;
BasicBlock::BasicBlock(const string &name, Method *Parent)
- : Value(Type::LabelTy, Value::BasicBlockVal, name), InstList(this, 0) {
+ : Value(Type::LabelTy, Value::BasicBlockVal, name),
+ InstList(this, 0),
+ machineInstrVec(new MachineCodeForBasicBlock)
+{
if (Parent)
Parent->getBasicBlocks().push_back(this);
}
@@ -28,6 +32,7 @@ BasicBlock::BasicBlock(const string &name, Method *Parent)
BasicBlock::~BasicBlock() {
dropAllReferences();
InstList.delete_all();
+ delete machineInstrVec;
}
// Specialize setName to take care of symbol table majik
OpenPOWER on IntegriCloud