MCJIT.h revision 7803ec3d458ec73372760b838469292cdf38fe67
1//===-- MCJIT.h - Class definition for the MCJIT ----------------*- C++ -*-===//
2//
3//                     The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#ifndef LLVM_LIB_EXECUTIONENGINE_MCJIT_H
11#define LLVM_LIB_EXECUTIONENGINE_MCJIT_H
12
13#include "llvm/PassManager.h"
14#include "llvm/ExecutionEngine/ExecutionEngine.h"
15#include "llvm/ExecutionEngine/RuntimeDyld.h"
16#include "llvm/ADT/SmallVector.h"
17#include "llvm/Support/raw_ostream.h"
18
19namespace llvm {
20
21// FIXME: This makes all kinds of horrible assumptions for the time being,
22// like only having one module, not needing to worry about multi-threading,
23// blah blah. Purely in get-it-up-and-limping mode for now.
24
25class MCJIT : public ExecutionEngine {
26  MCJIT(Module *M, TargetMachine *tm, TargetJITInfo &tji,
27        RTDyldMemoryManager *MemMgr, bool AllocateGVsWithCode);
28
29  TargetMachine *TM;
30  MCContext *Ctx;
31  RTDyldMemoryManager *MemMgr;
32
33  // FIXME: These may need moved to a separate 'jitstate' member like the
34  // non-MC JIT does for multithreading and such. Just keep them here for now.
35  PassManager PM;
36  Module *M;
37  // FIXME: This really doesn't belong here.
38  SmallVector<char, 4096> Buffer; // Working buffer into which we JIT.
39  raw_svector_ostream OS;
40
41  RuntimeDyld Dyld;
42
43public:
44  ~MCJIT();
45
46  /// @name ExecutionEngine interface implementation
47  /// @{
48
49  virtual void *getPointerToBasicBlock(BasicBlock *BB);
50
51  virtual void *getPointerToFunction(Function *F);
52
53  virtual void *recompileAndRelinkFunction(Function *F);
54
55  virtual void freeMachineCodeForFunction(Function *F);
56
57  virtual GenericValue runFunction(Function *F,
58                                   const std::vector<GenericValue> &ArgValues);
59
60  /// getPointerToNamedFunction - This method returns the address of the
61  /// specified function by using the dlsym function call.  As such it is only
62  /// useful for resolving library symbols, not code generated symbols.
63  ///
64  /// If AbortOnFailure is false and no function with the given name is
65  /// found, this function silently returns a null pointer. Otherwise,
66  /// it prints a message to stderr and aborts.
67  ///
68  virtual void *getPointerToNamedFunction(const std::string &Name,
69                                          bool AbortOnFailure = true);
70
71  /// mapSectionAddress - map a section to its target address space value.
72  /// Map the address of a JIT section as returned from the memory manager
73  /// to the address in the target process as the running code will see it.
74  /// This is the address which will be used for relocation resolution.
75  virtual void mapSectionAddress(void *LocalAddress, uint64_t TargetAddress) {
76    Dyld.mapSectionAddress(LocalAddress, TargetAddress);
77  }
78
79  /// @}
80  /// @name (Private) Registration Interfaces
81  /// @{
82
83  static void Register() {
84    MCJITCtor = createJIT;
85  }
86
87  static ExecutionEngine *createJIT(Module *M,
88                                    std::string *ErrorStr,
89                                    JITMemoryManager *JMM,
90                                    bool GVsWithCode,
91                                    TargetMachine *TM);
92
93  // @}
94};
95
96} // End llvm namespace
97
98#endif
99