2004-04-25 07:04:49 +00:00
|
|
|
//===- SparcV9JITInfo.h - SparcV9 Target JIT interface ----------*- C++ -*-===//
|
2005-04-21 23:30:14 +00:00
|
|
|
//
|
2003-12-20 01:22:19 +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.
|
2005-04-21 23:30:14 +00:00
|
|
|
//
|
2003-12-20 01:22:19 +00:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
2004-04-25 07:04:49 +00:00
|
|
|
// This file contains the SparcV9 implementation of the TargetJITInfo class,
|
|
|
|
// which makes target-specific hooks available to the target-independent
|
|
|
|
// LLVM JIT compiler.
|
2003-12-20 01:22:19 +00:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2004-04-25 07:04:49 +00:00
|
|
|
#ifndef SPARCV9JITINFO_H
|
|
|
|
#define SPARCV9JITINFO_H
|
2003-12-20 01:22:19 +00:00
|
|
|
|
|
|
|
#include "llvm/Target/TargetJITInfo.h"
|
|
|
|
|
|
|
|
namespace llvm {
|
|
|
|
class TargetMachine;
|
2003-12-28 09:46:33 +00:00
|
|
|
|
2004-02-25 18:44:15 +00:00
|
|
|
class SparcV9JITInfo : public TargetJITInfo {
|
2003-12-20 01:22:19 +00:00
|
|
|
TargetMachine &TM;
|
|
|
|
public:
|
2005-07-29 23:32:02 +00:00
|
|
|
SparcV9JITInfo(TargetMachine &tm) : TM(tm) {useGOT = 0;}
|
2003-12-20 01:22:19 +00:00
|
|
|
|
|
|
|
/// addPassesToJITCompile - Add passes to the specified pass manager to
|
|
|
|
/// implement a fast dynamic compiler for this target. Return true if this
|
|
|
|
/// is not supported for this target.
|
|
|
|
///
|
|
|
|
virtual void addPassesToJITCompile(FunctionPassManager &PM);
|
2005-04-21 23:30:14 +00:00
|
|
|
|
2003-12-20 01:22:19 +00:00
|
|
|
/// replaceMachineCodeForFunction - Make it so that calling the function
|
|
|
|
/// whose machine code is at OLD turns into a call to NEW, perhaps by
|
|
|
|
/// overwriting OLD with a branch to NEW. This is used for self-modifying
|
|
|
|
/// code.
|
|
|
|
///
|
|
|
|
virtual void replaceMachineCodeForFunction (void *Old, void *New);
|
2004-11-22 20:24:42 +00:00
|
|
|
|
|
|
|
|
|
|
|
/// emitFunctionStub - Use the specified MachineCodeEmitter object to emit a
|
|
|
|
/// small native function that simply calls the function at the specified
|
|
|
|
/// address. Return the address of the resultant function.
|
|
|
|
virtual void *emitFunctionStub(void *Fn, MachineCodeEmitter &MCE);
|
|
|
|
|
|
|
|
/// getLazyResolverFunction - This method is used to initialize the JIT,
|
|
|
|
/// giving the target the function that should be used to compile a
|
|
|
|
/// function, and giving the JIT the target function used to do the lazy
|
|
|
|
/// resolving.
|
|
|
|
virtual LazyResolverFn getLazyResolverFunction(JITCompilerFn);
|
|
|
|
|
|
|
|
/// relocate - Before the JIT can run a block of code that has been emitted,
|
|
|
|
/// it must rewrite the code to contain the actual addresses of any
|
|
|
|
/// referenced global symbols.
|
|
|
|
virtual void relocate(void *Function, MachineRelocation *MR,
|
2005-07-22 20:49:37 +00:00
|
|
|
unsigned NumRelocs, unsigned char* GOTBase);
|
2003-12-20 01:22:19 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|