From: Chris Lattner Date: Fri, 25 Oct 2002 22:54:41 +0000 (+0000) Subject: Initial checkin of codegen infrastructure for LLVM-JIT X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=78cee7e7ab9fde0453d3f1b7a317b1c1b41a1b4c;p=oota-llvm.git Initial checkin of codegen infrastructure for LLVM-JIT git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@4282 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/MFunction.cpp b/lib/CodeGen/MFunction.cpp new file mode 100644 index 00000000000..f586f4c5988 --- /dev/null +++ b/lib/CodeGen/MFunction.cpp @@ -0,0 +1,76 @@ +//===-- MFunction.cpp - Implementation code for the MFunction 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/MFunction.h" +#include "llvm/Target/MInstructionInfo.h" +#include "llvm/Target/MRegisterInfo.h" +#include + +static void printMRegister(unsigned RegNo, const MRegisterInfo &MRI, + std::ostream &OS) { + if (RegNo < MRegisterInfo::FirstVirtualRegister) { + OS << "%" << MRI[RegNo].Name; // Hard registers are prefixed with % + } else { + OS << "reg" << RegNo; // SSA registers are printed with 'reg' prefix + } +} + +static void printMInstruction(const MInstruction &MI, std::ostream &OS, + const MInstructionInfo &MII) { + const MRegisterInfo &MRI = MII.getRegisterInfo(); + OS << "\t"; + if (MI.getDestinationReg() != MRegisterInfo::NoRegister) {// Produces a value? + printMRegister(MI.getDestinationReg(), MRI, OS); + OS << " = "; + } + + OS << MII[MI.getOpcode()].Name << " "; + + for (unsigned i = 0, e = MI.getNumOperands(); i != e; ++i) { + if (i != 0) OS << ", "; + switch (MI.getOperandInterpretation(i)) { + case MOperand::Register: + printMRegister(MI.getRegisterOperand(i), MRI, OS); + break; + case MOperand::SignExtImmediate: + OS << MI.getSignExtOperand(i) << "s"; + break; + case MOperand::ZeroExtImmediate: + OS << MI.getZeroExtOperand(i) << "z"; + break; + case MOperand::PCRelativeDisp: + if (MI.getPCRelativeOperand(i) >= 0) + OS << "pc+" << MI.getPCRelativeOperand(i); + else + OS << "pc" << MI.getPCRelativeOperand(i); + break; + default: + OS << "*UNKNOWN OPERAND INTERPRETATION*"; + break; + } + } + OS << "\n"; +} + +/// print - Provide a way to get a simple debugging dump. This dumps the +/// machine code in a simple "assembly" language that is not really suitable +/// for an assembler, but is useful for debugging. This is completely target +/// independant. +/// +void MFunction::print(std::ostream &OS, const MInstructionInfo &MII) const { + for (const_iterator I = begin(), E = end(); I != E; ++I) { + for (MBasicBlock::const_iterator II = I->begin(), IE = I->end(); + II != IE; ++II) + printMInstruction(*II, OS, MII); + OS << "\n"; // blank line between basic blocks... + } +} + +void MFunction::dump(const MInstructionInfo &MII) const { + print(std::cerr, MII); +} + diff --git a/lib/CodeGen/MInstruction.cpp b/lib/CodeGen/MInstruction.cpp new file mode 100644 index 00000000000..d6740e5212d --- /dev/null +++ b/lib/CodeGen/MInstruction.cpp @@ -0,0 +1,31 @@ +//===-- 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); +} diff --git a/lib/CodeGen/Makefile b/lib/CodeGen/Makefile index c235800f878..6f2a330d3ed 100644 --- a/lib/CodeGen/Makefile +++ b/lib/CodeGen/Makefile @@ -1,4 +1,5 @@ LEVEL = ../.. -PARALLEL_DIRS = PreOpts InstrSelection InstrSched RegAlloc PostOpts Mapping +PARALLEL_DIRS = PreOpts InstrSelection InstrSched RegAlloc PostOpts Mapping +LIBRARYNAME = codegen include $(LEVEL)/Makefile.common