mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-31 08:16:47 +00:00 
			
		
		
		
	git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@11392 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			157 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			157 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //===-- llvm/CodeGen/MachineBasicBlock.h ------------------------*- C++ -*-===//
 | |
| // 
 | |
| //                     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.
 | |
| // 
 | |
| //===----------------------------------------------------------------------===//
 | |
| // 
 | |
| // Collect the sequence of machine instructions for a basic block.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| #ifndef LLVM_CODEGEN_MACHINEBASICBLOCK_H
 | |
| #define LLVM_CODEGEN_MACHINEBASICBLOCK_H
 | |
| 
 | |
| #include "llvm/CodeGen/MachineInstr.h"
 | |
| #include "Support/ilist"
 | |
| #include <iosfwd>
 | |
| 
 | |
| namespace llvm {
 | |
| 
 | |
| // 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;
 | |
|   }
 | |
| };
 | |
| 
 | |
| class BasicBlock;
 | |
| 
 | |
| class MachineBasicBlock {
 | |
| public:
 | |
|   typedef ilist<MachineInstr> Instructions;
 | |
|   Instructions Insts;
 | |
|   MachineBasicBlock *Prev, *Next;
 | |
|   const BasicBlock *BB;
 | |
| public:
 | |
|   MachineBasicBlock(const BasicBlock *bb = 0) : Prev(0), Next(0), BB(bb) {
 | |
|     Insts.parent = this;
 | |
|   }
 | |
|   ~MachineBasicBlock() {}
 | |
|   
 | |
|   /// getBasicBlock - Return the LLVM basic block that this instance
 | |
|   /// corresponded to originally.
 | |
|   ///
 | |
|   const BasicBlock *getBasicBlock() const { return BB; }
 | |
|   
 | |
|   typedef ilist<MachineInstr>::iterator                       iterator;
 | |
|   typedef ilist<MachineInstr>::const_iterator           const_iterator;
 | |
|   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(); }
 | |
| 
 | |
|   // This is a really inefficient way of accessing a basic
 | |
|   // block. These methods will be removed when all of their uses are
 | |
|   // eliminated.
 | |
|   inline const MachineInstr& operator[](unsigned i) const DEPRECATED;
 | |
|   inline MachineInstr& operator[](unsigned i) DEPRECATED;
 | |
| 
 | |
|   MachineInstr& front() { return Insts.front(); }
 | |
|   MachineInstr& back()  { return Insts.back(); }
 | |
| 
 | |
|   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); }
 | |
| 
 | |
|   // erase - Remove the specified element or range from the instruction list.
 | |
|   // These functions delete any instructions removed.
 | |
|   //
 | |
|   iterator erase(iterator I)             { return Insts.erase(I); }
 | |
|   iterator erase(iterator I, iterator E) { return Insts.erase(I, E); }
 | |
|   MachineInstr* remove(iterator &I)      { return Insts.remove(I); }
 | |
| 
 | |
|   // Debugging methods.
 | |
|   void dump() const;
 | |
|   void print(std::ostream &OS) const;
 | |
| 
 | |
| 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; }
 | |
| };
 | |
| 
 | |
| const MachineInstr& MachineBasicBlock::operator[](unsigned i) const
 | |
| {
 | |
|   const_iterator it = Insts.begin();
 | |
|   std::advance(it, i);
 | |
|   return *it;
 | |
| }
 | |
| 
 | |
| MachineInstr& MachineBasicBlock::operator[](unsigned i)
 | |
| {
 | |
|   iterator it = Insts.begin();
 | |
|   std::advance(it, i);
 | |
|   return *it;
 | |
| }
 | |
| 
 | |
| 
 | |
| } // End llvm namespace
 | |
| 
 | |
| #endif
 |