Get rid of the old byte-at-a-time emission code used when the Sparc JIT was
[oota-llvm.git] / lib / Target / SparcV9 / SparcV9JITInfo.h
1 //===- SparcV9JITInfo.h - SparcV9 implementation of the JIT interface -*-C++-*-===//
2 // 
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file was developed by the LLVM research group and is distributed under
6 // the University of Illinois Open Source License. See LICENSE.TXT for details.
7 // 
8 //===----------------------------------------------------------------------===//
9 //
10 // This file contains the SparcV9 implementation of the TargetJITInfo class.
11 //
12 //===----------------------------------------------------------------------===//
13
14 #ifndef SPARCJITINFO_H
15 #define SPARCJITINFO_H
16
17 #include "llvm/Target/TargetJITInfo.h"
18
19 namespace llvm {
20   class TargetMachine;
21
22   class SparcV9JITInfo : public TargetJITInfo {
23     TargetMachine &TM;
24   public:
25     SparcV9JITInfo(TargetMachine &tm) : TM(tm) {}
26
27     /// addPassesToJITCompile - Add passes to the specified pass manager to
28     /// implement a fast dynamic compiler for this target.  Return true if this
29     /// is not supported for this target.
30     ///
31     virtual void addPassesToJITCompile(FunctionPassManager &PM);
32     
33     /// replaceMachineCodeForFunction - Make it so that calling the function
34     /// whose machine code is at OLD turns into a call to NEW, perhaps by
35     /// overwriting OLD with a branch to NEW.  This is used for self-modifying
36     /// code.
37     ///
38     virtual void replaceMachineCodeForFunction (void *Old, void *New);
39     
40     /// getJITStubForFunction - Create or return a stub for the specified
41     /// function.  This stub acts just like the specified function, except that
42     /// it allows the "address" of the function to be taken without having to
43     /// generate code for it.
44     //virtual void *getJITStubForFunction(Function *F, MachineCodeEmitter &MCE);
45   };
46 }
47
48 #endif