diff --git a/include/llvm/CodeGen/MBasicBlock.h b/include/llvm/CodeGen/MBasicBlock.h deleted file mode 100644 index f846de588cb..00000000000 --- a/include/llvm/CodeGen/MBasicBlock.h +++ /dev/null @@ -1,64 +0,0 @@ -//===-- llvm/CodeGen/MBasicBlock.h - Machine Specific BB rep ----*- C++ -*-===// -// -// This class provides a way to represent a basic block in a machine-specific -// form. A basic block is represented as a list of machine specific -// instructions. -// -//===----------------------------------------------------------------------===// - -#ifndef CODEGEN_MBASICBLOCK_H -#define CODEGEN_MBASICBLOCK_H - -#include "llvm/CodeGen/MInstruction.h" -#include "Support/ilist" - -class MBasicBlock { - MBasicBlock *Prev, *Next; - iplist InstList; - // FIXME: we should maintain a pointer to the function we are embedded into! -public: - MBasicBlock() {} - - // Provide accessors for the MBasicBlock list... - typedef iplist InstListType; - typedef InstListType::iterator iterator; - typedef InstListType::const_iterator const_iterator; - typedef std::reverse_iterator const_reverse_iterator; - typedef std::reverse_iterator reverse_iterator; - - //===--------------------------------------------------------------------===// - /// Instruction iterator methods - /// - inline iterator begin() { return InstList.begin(); } - inline const_iterator begin() const { return InstList.begin(); } - inline iterator end () { return InstList.end(); } - inline const_iterator end () const { return InstList.end(); } - - inline reverse_iterator rbegin() { return InstList.rbegin(); } - inline const_reverse_iterator rbegin() const { return InstList.rbegin(); } - inline reverse_iterator rend () { return InstList.rend(); } - inline const_reverse_iterator rend () const { return InstList.rend(); } - - inline unsigned size() const { return InstList.size(); } - inline bool empty() const { return InstList.empty(); } - inline const MInstruction &front() const { return InstList.front(); } - inline MInstruction &front() { return InstList.front(); } - inline const MInstruction &back() const { return InstList.back(); } - inline MInstruction &back() { return InstList.back(); } - - /// getInstList() - Return the underlying instruction list container. You - /// need to access it directly if you want to modify it currently. - /// - const InstListType &getInstList() const { return InstList; } - InstListType &getInstList() { return InstList; } - -private: // Methods used to maintain doubly linked list of blocks... - friend class ilist_traits; - - MBasicBlock *getPrev() const { return Prev; } - MBasicBlock *getNext() const { return Next; } - void setPrev(MBasicBlock *P) { Prev = P; } - void setNext(MBasicBlock *N) { Next = N; } -}; - -#endif diff --git a/include/llvm/CodeGen/MInstruction.h b/include/llvm/CodeGen/MInstruction.h deleted file mode 100644 index b96a88f0796..00000000000 --- a/include/llvm/CodeGen/MInstruction.h +++ /dev/null @@ -1,150 +0,0 @@ -//===-- llvm/CodeGen/MInstruction.h - Machine Instruction -------*- C++ -*-===// -// -// This class represents a single machine instruction for the LLVM backend. -// This instruction is represented in a completely generic way to allow all -// backends to share a common representation. MInstructions are embedded into -// MBasicBlocks, and are maintained as a doubly linked list. -// -// Because there are a lot of machine instruction that may be in use at a time -// (being manipulated), we are sure to keep a very compact representation that -// is extremely light-weight. -// -// This class is used to represent an instruction when it is in SSA form as well -// as when it has been register allocated to use physical registers. -// -// FIXME: This should eventually be merged with the MachineInstr class. -// -//===----------------------------------------------------------------------===// - -#ifndef CODEGEN_MINSTRUCTION_H -#define CODEGEN_MINSTRUCTION_H - -#include -template struct ilist_traits; -class MBasicBlock; - -/// MOperand - This class represents a single operand in an instruction. -/// Interpretation of this operand is not really possible without information -/// from the machine instruction that it is embedded into. -/// -class MOperand { - union { - unsigned uVal; - int iVal; - }; -public: - MOperand(unsigned Value) : uVal(Value) {} - MOperand(int Value) : iVal(Value) {} - - /// Interpretation - This enum is used by the MInstruction class to interpret - /// the untyped value field of the operand. - enum Interpretation { - Register, // This is some register number - SignExtImmediate, // This is a sign extended immediate - ZeroExtImmediate, // This is a zero extended immediate - PCRelativeDisp // This is a displacement relative to the PC - // FIXME: We need a symbolic value here, like global variable address - }; - - unsigned getUnsignedValue() const { return uVal; } - unsigned getSignedValue() const { return iVal; } -}; - -/// MInstruction - Represent a single machine instruction in the code generator. -/// This is meant to be a light weight representation that is completely -/// independant of the target machine being code generated for. -/// -class MInstruction { - MInstruction *Prev, *Next; // Doubly linked list of instructions... - - unsigned Opcode; // Opcode of the instruction - unsigned Dest; // Destination register written (or 0 if none) - - std::vector Operands; // Operands of the instruction... - - /// OperandInterpretation - This array specifies how the operands of the - /// instruction are to be interpreted (is it a register?, an immediate - /// constant?, a PC relative displacement?, etc...). Only four values are - /// allowed, so any instruction with more than four operands (should be - /// exceedingly rare, perhaps only PHI nodes) are assumed to have register - /// operands beyond the fourth. - /// - unsigned char OperandInterpretation[4]; -public: - /// MInstruction ctor - Create a new machine instruction, with the specified - /// opcode and destination register. Operands are then added with the - /// addOperand method. - /// - MInstruction(unsigned O = 0, unsigned D = 0) : Opcode(O), Dest(D) {} - - /// MInstruction ctor - Create a new instruction, and append it to the - /// specified basic block. - /// - MInstruction(MBasicBlock *BB, unsigned Opcode = 0, unsigned Dest = 0); - - /// getOpcode - Return the opcode for this machine instruction. The value of - /// the opcode defines how to interpret the operands of the instruction. - /// - unsigned getOpcode() const { return Opcode; } - - /// getDestinationReg - This method returns the register written to by this - /// instruction. If this returns zero, the instruction does not produce a - /// value, because register #0 is always the garbage marker. - /// - unsigned getDestinationReg() const { return Dest; } - - /// setDestinationReg - This method changes the register written to by this - /// instruction. Note that if SSA form is currently active then the SSA table - /// needs to be updated to match this, thus this method shouldn't be used - /// directly. - /// - void setDestinationReg(unsigned R) { Dest = R; } - - /// getNumOperands - Return the number of operands the instruction currently - /// has. - /// - unsigned getNumOperands() const { return Operands.size(); } - - /// getOperandInterpretation - Return the interpretation of operand #Op - /// - MOperand::Interpretation getOperandInterpretation(unsigned Op) const { - if (Op < 4) return (MOperand::Interpretation)OperandInterpretation[Op]; - return MOperand::Register; // Operands >= 4 are all registers - } - - unsigned getRegisterOperand(unsigned Op) const { - assert(getOperandInterpretation(Op) == MOperand::Register && - "Operand isn't a register!"); - return Operands[Op].getUnsignedValue(); - } - int getSignExtOperand(unsigned Op) const { - assert(getOperandInterpretation(Op) == MOperand::SignExtImmediate && - "Operand isn't a sign extended immediate!"); - return Operands[Op].getSignedValue(); - } - unsigned getZeroExtOperand(unsigned Op) const { - assert(getOperandInterpretation(Op) == MOperand::ZeroExtImmediate && - "Operand isn't a zero extended immediate!"); - return Operands[Op].getUnsignedValue(); - } - int getPCRelativeOperand(unsigned Op) const { - assert(getOperandInterpretation(Op) == MOperand::PCRelativeDisp && - "Operand isn't a PC relative displacement!"); - return Operands[Op].getSignedValue(); - } - - /// addOperand - Add a new operand to the instruction with the specified value - /// and interpretation. - /// - void addOperand(unsigned Value, MOperand::Interpretation Ty); - -private: // Methods used to maintain doubly linked list of instructions... - friend class ilist_traits; - - MInstruction *getPrev() const { return Prev; } - MInstruction *getNext() const { return Next; } - void setPrev(MInstruction *P) { Prev = P; } - void setNext(MInstruction *N) { Next = N; } -}; - -#endif diff --git a/lib/CodeGen/MInstruction.cpp b/lib/CodeGen/MInstruction.cpp deleted file mode 100644 index d6740e5212d..00000000000 --- a/lib/CodeGen/MInstruction.cpp +++ /dev/null @@ -1,31 +0,0 @@ -//===-- MInstruction.cpp - Implementation code for the MInstruction class -===// -// -// This file contains a printer that converts from our internal representation -// of LLVM code to a nice human readable form that is suitable for debuggging. -// -//===----------------------------------------------------------------------===// - -#include "llvm/CodeGen/MBasicBlock.h" - -/// MInstruction ctor - Create a new instruction, and append it to the -/// specified basic block. -/// -MInstruction::MInstruction(MBasicBlock *BB, unsigned O, unsigned D) - : Opcode(O), Dest(D) { - // Add this instruction to the specified basic block - BB->getInstList().push_back(this); -} - - -/// addOperand - Add a new operand to the instruction with the specified value -/// and interpretation. -/// -void MInstruction::addOperand(unsigned Value, MOperand::Interpretation Ty) { - if (Operands.size() < 4) { - OperandInterpretation[Operands.size()] = Ty; // Save interpretation - } else { - assert(Ty == MOperand::Register && - "Trying to add 5th operand that is not a register to MInstruction!"); - } - Operands.push_back(Value); -}