102 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C++
		
	
	
	
//===-- PPC32CodeEmitter.cpp - JIT Code Emitter for PowerPC32 -----*- 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.
 | 
						|
// 
 | 
						|
//===----------------------------------------------------------------------===//
 | 
						|
// 
 | 
						|
//
 | 
						|
//===----------------------------------------------------------------------===//
 | 
						|
 | 
						|
#include "PPC32JITInfo.h"
 | 
						|
#include "PPC32TargetMachine.h"
 | 
						|
#include "llvm/CodeGen/MachineCodeEmitter.h"
 | 
						|
#include "llvm/CodeGen/MachineFunctionPass.h"
 | 
						|
#include "llvm/CodeGen/Passes.h"
 | 
						|
#include "Support/Debug.h"
 | 
						|
 | 
						|
namespace llvm {
 | 
						|
 | 
						|
namespace {
 | 
						|
  class PPC32CodeEmitter : public MachineFunctionPass {
 | 
						|
    TargetMachine &TM;
 | 
						|
    MachineCodeEmitter &MCE;
 | 
						|
 | 
						|
  public:
 | 
						|
    PPC32CodeEmitter(TargetMachine &T, MachineCodeEmitter &M) 
 | 
						|
      : TM(T), MCE(M) {}
 | 
						|
 | 
						|
    const char *getPassName() const { return "PowerPC Machine Code Emitter"; }
 | 
						|
 | 
						|
    /// runOnMachineFunction - emits the given MachineFunction to memory
 | 
						|
    ///
 | 
						|
    bool runOnMachineFunction(MachineFunction &MF);
 | 
						|
 | 
						|
    /// emitBasicBlock - emits the given MachineBasicBlock to memory
 | 
						|
    ///
 | 
						|
    void emitBasicBlock(MachineBasicBlock &MBB);
 | 
						|
 | 
						|
    /// emitWord - write a 32-bit word to memory at the current PC
 | 
						|
    ///
 | 
						|
    void emitWord(unsigned w) { MCE.emitWord(w); }
 | 
						|
 | 
						|
    unsigned getValueBit(int64_t Val, unsigned bit);
 | 
						|
 | 
						|
    /// getBinaryCodeForInstr - returns the assembled code for an instruction
 | 
						|
    ///
 | 
						|
    unsigned getBinaryCodeForInstr(MachineInstr &MI) { return 0; }
 | 
						|
  };
 | 
						|
}
 | 
						|
 | 
						|
/// addPassesToEmitMachineCode - Add passes to the specified pass manager to get
 | 
						|
/// machine code emitted.  This uses a MachineCodeEmitter object to handle
 | 
						|
/// actually outputting the machine code and resolving things like the address
 | 
						|
/// of functions.  This method should returns true if machine code emission is
 | 
						|
/// not supported.
 | 
						|
///
 | 
						|
bool PPC32TargetMachine::addPassesToEmitMachineCode(FunctionPassManager &PM,
 | 
						|
                                                    MachineCodeEmitter &MCE) {
 | 
						|
  // Machine code emitter pass for PowerPC
 | 
						|
  PM.add(new PPC32CodeEmitter(*this, MCE)); 
 | 
						|
  // Delete machine code for this function after emitting it:
 | 
						|
  PM.add(createMachineCodeDeleter());
 | 
						|
  // We don't yet support machine code emission
 | 
						|
  return true;
 | 
						|
}
 | 
						|
 | 
						|
bool PPC32CodeEmitter::runOnMachineFunction(MachineFunction &MF) {
 | 
						|
  MCE.startFunction(MF);
 | 
						|
  MCE.emitConstantPool(MF.getConstantPool());
 | 
						|
  for (MachineFunction::iterator I = MF.begin(), E = MF.end(); I != E; ++I)
 | 
						|
    emitBasicBlock(*I);
 | 
						|
  MCE.finishFunction(MF);
 | 
						|
  return false;
 | 
						|
}
 | 
						|
 | 
						|
void PPC32CodeEmitter::emitBasicBlock(MachineBasicBlock &MBB) {
 | 
						|
  for (MachineBasicBlock::iterator I = MBB.begin(), E = MBB.end(); I != E; ++I)
 | 
						|
    emitWord(getBinaryCodeForInstr(*I));
 | 
						|
}
 | 
						|
 | 
						|
unsigned PPC32CodeEmitter::getValueBit(int64_t Val, unsigned bit) {
 | 
						|
  Val >>= bit;
 | 
						|
  return (Val & 1);
 | 
						|
}
 | 
						|
 | 
						|
void *PPC32JITInfo::getJITStubForFunction(Function *F,
 | 
						|
                                          MachineCodeEmitter &MCE) {
 | 
						|
  assert (0 && "PPC32JITInfo::getJITStubForFunction not implemented");
 | 
						|
  return 0;
 | 
						|
}
 | 
						|
 | 
						|
void PPC32JITInfo::replaceMachineCodeForFunction (void *Old, void *New) {
 | 
						|
  assert (0 && "PPC32JITInfo::replaceMachineCodeForFunction not implemented");
 | 
						|
}
 | 
						|
 | 
						|
//#include "PowerPCGenCodeEmitter.inc"
 | 
						|
 | 
						|
} // end llvm namespace
 | 
						|
 |