mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-01 01:14:12 +00:00
c4c6257c1a
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@26742 91177308-0d34-0410-b5e6-96231b3b80d8
49 lines
1.7 KiB
C++
49 lines
1.7 KiB
C++
//===- PPCJITInfo.h - PowerPC impl. of the JIT interface --------*- 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.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file contains the PowerPC implementation of the TargetJITInfo class.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef POWERPC_JITINFO_H
|
|
#define POWERPC_JITINFO_H
|
|
|
|
#include "llvm/Target/TargetJITInfo.h"
|
|
|
|
namespace llvm {
|
|
class PPCTargetMachine;
|
|
|
|
class PPCJITInfo : public TargetJITInfo {
|
|
protected:
|
|
PPCTargetMachine &TM;
|
|
public:
|
|
PPCJITInfo(PPCTargetMachine &tm) : TM(tm) {useGOT = 0;}
|
|
|
|
/// 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);
|
|
|
|
virtual void *emitFunctionStub(void *Fn, MachineCodeEmitter &MCE);
|
|
virtual LazyResolverFn getLazyResolverFunction(JITCompilerFn);
|
|
virtual void relocate(void *Function, MachineRelocation *MR,
|
|
unsigned NumRelocs, unsigned char* GOTBase);
|
|
|
|
/// 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);
|
|
};
|
|
}
|
|
|
|
#endif
|