2002-10-28 01:21:55 +00:00
|
|
|
//===-- llvm/CodeGen/MachineBasicBlock.h ------------------------*- C++ -*-===//
|
2002-07-08 22:40:34 +00:00
|
|
|
//
|
2003-10-20 20:19:47 +00:00
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file was developed by the LLVM research group and is distributed under
|
|
|
|
// the University of Illinois Open Source License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
2002-10-27 20:49:47 +00:00
|
|
|
// Collect the sequence of machine instructions for a basic block.
|
|
|
|
//
|
2002-10-28 01:21:55 +00:00
|
|
|
//===----------------------------------------------------------------------===//
|
2002-07-08 22:40:34 +00:00
|
|
|
|
2002-10-28 00:28:31 +00:00
|
|
|
#ifndef LLVM_CODEGEN_MACHINEBASICBLOCK_H
|
|
|
|
#define LLVM_CODEGEN_MACHINEBASICBLOCK_H
|
2002-07-08 22:40:34 +00:00
|
|
|
|
2004-02-12 02:27:10 +00:00
|
|
|
#include "llvm/CodeGen/MachineInstr.h"
|
2004-02-12 19:12:03 +00:00
|
|
|
#include "Support/ilist"
|
2004-02-13 04:40:15 +00:00
|
|
|
#include <iosfwd>
|
2003-11-11 22:41:34 +00:00
|
|
|
|
|
|
|
namespace llvm {
|
|
|
|
|
2004-02-12 19:12:03 +00:00
|
|
|
// ilist_traits
|
|
|
|
template <>
|
|
|
|
class ilist_traits<MachineInstr>
|
|
|
|
{
|
|
|
|
typedef ilist_traits<MachineInstr> self;
|
|
|
|
|
|
|
|
// this is only set by the MachineBasicBlock owning the ilist
|
|
|
|
friend class MachineBasicBlock;
|
|
|
|
MachineBasicBlock* parent;
|
|
|
|
|
|
|
|
public:
|
|
|
|
ilist_traits<MachineInstr>() : parent(0) { }
|
|
|
|
|
|
|
|
static MachineInstr* getPrev(MachineInstr* N) { return N->prev; }
|
|
|
|
static MachineInstr* getNext(MachineInstr* N) { return N->next; }
|
|
|
|
|
|
|
|
static const MachineInstr*
|
|
|
|
getPrev(const MachineInstr* N) { return N->prev; }
|
|
|
|
|
|
|
|
static const MachineInstr*
|
|
|
|
getNext(const MachineInstr* N) { return N->next; }
|
|
|
|
|
|
|
|
static void setPrev(MachineInstr* N, MachineInstr* prev) { N->prev = prev; }
|
|
|
|
static void setNext(MachineInstr* N, MachineInstr* next) { N->next = next; }
|
|
|
|
|
|
|
|
static MachineInstr* createNode() { return new MachineInstr(0, 0); }
|
|
|
|
|
|
|
|
void addNodeToList(MachineInstr* N) {
|
|
|
|
assert(N->parent == 0 && "machine instruction already in a basic block");
|
|
|
|
N->parent = parent;
|
|
|
|
}
|
|
|
|
|
|
|
|
void removeNodeFromList(MachineInstr* N) {
|
|
|
|
assert(N->parent != 0 && "machine instruction not in a basic block");
|
|
|
|
N->parent = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void transferNodesFromList(iplist<MachineInstr, self>& toList,
|
|
|
|
ilist_iterator<MachineInstr> first,
|
|
|
|
ilist_iterator<MachineInstr> last) {
|
|
|
|
if (parent != toList.parent)
|
|
|
|
for (; first != last; ++first)
|
|
|
|
first->parent = toList.parent;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2002-10-28 01:53:00 +00:00
|
|
|
class BasicBlock;
|
2002-07-08 22:40:34 +00:00
|
|
|
|
2002-10-28 05:30:46 +00:00
|
|
|
class MachineBasicBlock {
|
2004-02-12 02:27:10 +00:00
|
|
|
public:
|
|
|
|
typedef ilist<MachineInstr> Instructions;
|
|
|
|
Instructions Insts;
|
2002-10-28 02:08:43 +00:00
|
|
|
MachineBasicBlock *Prev, *Next;
|
2003-07-26 23:30:37 +00:00
|
|
|
const BasicBlock *BB;
|
2002-07-08 22:40:34 +00:00
|
|
|
public:
|
2004-02-12 18:49:07 +00:00
|
|
|
MachineBasicBlock(const BasicBlock *bb = 0) : Prev(0), Next(0), BB(bb) {
|
|
|
|
Insts.parent = this;
|
|
|
|
}
|
2002-10-28 00:28:31 +00:00
|
|
|
~MachineBasicBlock() {}
|
2002-07-08 22:40:34 +00:00
|
|
|
|
2002-10-28 05:30:46 +00:00
|
|
|
/// getBasicBlock - Return the LLVM basic block that this instance
|
|
|
|
/// corresponded to originally.
|
|
|
|
///
|
2003-07-26 23:30:37 +00:00
|
|
|
const BasicBlock *getBasicBlock() const { return BB; }
|
2002-07-08 22:40:34 +00:00
|
|
|
|
2004-02-12 02:27:10 +00:00
|
|
|
typedef ilist<MachineInstr>::iterator iterator;
|
|
|
|
typedef ilist<MachineInstr>::const_iterator const_iterator;
|
2002-07-08 22:40:34 +00:00
|
|
|
typedef std::reverse_iterator<const_iterator> const_reverse_iterator;
|
|
|
|
typedef std::reverse_iterator<iterator> reverse_iterator;
|
|
|
|
|
|
|
|
unsigned size() const { return Insts.size(); }
|
|
|
|
bool empty() const { return Insts.empty(); }
|
|
|
|
|
2004-02-12 02:27:10 +00:00
|
|
|
const MachineInstr& operator[](unsigned i) const {
|
|
|
|
const_iterator it = Insts.begin();
|
|
|
|
std::advance(it, i);
|
|
|
|
return *it;
|
|
|
|
}
|
|
|
|
MachineInstr& operator[](unsigned i) {
|
|
|
|
iterator it = Insts.begin();
|
|
|
|
std::advance(it, i);
|
|
|
|
return *it;
|
|
|
|
}
|
2002-07-08 22:40:34 +00:00
|
|
|
|
2004-02-12 02:27:10 +00:00
|
|
|
MachineInstr& front() { return Insts.front(); }
|
|
|
|
MachineInstr& back() { return Insts.back(); }
|
2002-07-08 22:40:34 +00:00
|
|
|
|
|
|
|
iterator begin() { return Insts.begin(); }
|
|
|
|
const_iterator begin() const { return Insts.begin(); }
|
|
|
|
iterator end() { return Insts.end(); }
|
|
|
|
const_iterator end() const { return Insts.end(); }
|
|
|
|
reverse_iterator rbegin() { return Insts.rbegin(); }
|
|
|
|
const_reverse_iterator rbegin() const { return Insts.rbegin(); }
|
|
|
|
reverse_iterator rend () { return Insts.rend(); }
|
|
|
|
const_reverse_iterator rend () const { return Insts.rend(); }
|
|
|
|
|
|
|
|
void push_back(MachineInstr *MI) { Insts.push_back(MI); }
|
|
|
|
template<typename IT>
|
|
|
|
void insert(iterator I, IT S, IT E) { Insts.insert(I, S, E); }
|
|
|
|
iterator insert(iterator I, MachineInstr *M) { return Insts.insert(I, M); }
|
|
|
|
|
2002-09-20 00:55:57 +00:00
|
|
|
// erase - Remove the specified element or range from the instruction list.
|
2004-02-12 02:27:10 +00:00
|
|
|
// These functions delete any instructions removed.
|
2002-07-08 22:40:34 +00:00
|
|
|
//
|
2002-09-20 00:55:57 +00:00
|
|
|
iterator erase(iterator I) { return Insts.erase(I); }
|
2002-07-08 22:40:34 +00:00
|
|
|
iterator erase(iterator I, iterator E) { return Insts.erase(I, E); }
|
2004-02-12 02:27:10 +00:00
|
|
|
MachineInstr* remove(iterator &I) { return Insts.remove(I); }
|
2002-10-28 02:08:43 +00:00
|
|
|
|
2004-02-13 04:40:15 +00:00
|
|
|
// Debugging methods.
|
|
|
|
void dump() const;
|
|
|
|
void print(std::ostream &OS) const;
|
|
|
|
|
2002-10-28 02:08:43 +00:00
|
|
|
private: // Methods used to maintain doubly linked list of blocks...
|
|
|
|
friend class ilist_traits<MachineBasicBlock>;
|
|
|
|
|
|
|
|
MachineBasicBlock *getPrev() const { return Prev; }
|
|
|
|
MachineBasicBlock *getNext() const { return Next; }
|
|
|
|
void setPrev(MachineBasicBlock *P) { Prev = P; }
|
|
|
|
void setNext(MachineBasicBlock *N) { Next = N; }
|
2002-07-08 22:40:34 +00:00
|
|
|
};
|
|
|
|
|
2003-11-11 22:41:34 +00:00
|
|
|
} // End llvm namespace
|
2002-07-08 22:40:34 +00:00
|
|
|
|
|
|
|
#endif
|