]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - contrib/llvm/include/llvm/ExecutionEngine/Orc/Layer.h
Merge llvm, clang, compiler-rt, libc++, libunwind, lld, lldb and openmp
[FreeBSD/FreeBSD.git] / contrib / llvm / include / llvm / ExecutionEngine / Orc / Layer.h
1 //===---------------- Layer.h -- Layer interfaces --------------*- 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 // Layer interfaces.
11 //
12 //===----------------------------------------------------------------------===//
13
14 #ifndef LLVM_EXECUTIONENGINE_ORC_LAYER_H
15 #define LLVM_EXECUTIONENGINE_ORC_LAYER_H
16
17 #include "llvm/ExecutionEngine/Orc/Core.h"
18 #include "llvm/ExecutionEngine/Orc/ThreadSafeModule.h"
19 #include "llvm/IR/Module.h"
20 #include "llvm/Support/MemoryBuffer.h"
21
22 namespace llvm {
23 namespace orc {
24
25 /// Interface for layers that accept LLVM IR.
26 class IRLayer {
27 public:
28   IRLayer(ExecutionSession &ES);
29   virtual ~IRLayer();
30
31   /// Returns the ExecutionSession for this layer.
32   ExecutionSession &getExecutionSession() { return ES; }
33
34   /// Sets the CloneToNewContextOnEmit flag (false by default).
35   ///
36   /// When set, IR modules added to this layer will be cloned on to a new
37   /// context before emit is called. This can be used by clients who want
38   /// to load all IR using one LLVMContext (to save memory via type and
39   /// constant uniquing), but want to move Modules to fresh contexts before
40   /// compiling them to enable concurrent compilation.
41   /// Single threaded clients, or clients who load every module on a new
42   /// context, need not set this.
43   void setCloneToNewContextOnEmit(bool CloneToNewContextOnEmit) {
44     this->CloneToNewContextOnEmit = CloneToNewContextOnEmit;
45   }
46
47   /// Returns the current value of the CloneToNewContextOnEmit flag.
48   bool getCloneToNewContextOnEmit() const { return CloneToNewContextOnEmit; }
49
50   /// Adds a MaterializationUnit representing the given IR to the given
51   /// JITDylib.
52   virtual Error add(JITDylib &JD, ThreadSafeModule TSM,
53                     VModuleKey K = VModuleKey());
54
55   /// Emit should materialize the given IR.
56   virtual void emit(MaterializationResponsibility R, ThreadSafeModule TSM) = 0;
57
58 private:
59   bool CloneToNewContextOnEmit = false;
60   ExecutionSession &ES;
61 };
62
63 /// IRMaterializationUnit is a convenient base class for MaterializationUnits
64 /// wrapping LLVM IR. Represents materialization responsibility for all symbols
65 /// in the given module. If symbols are overridden by other definitions, then
66 /// their linkage is changed to available-externally.
67 class IRMaterializationUnit : public MaterializationUnit {
68 public:
69   using SymbolNameToDefinitionMap = std::map<SymbolStringPtr, GlobalValue *>;
70
71   /// Create an IRMaterializationLayer. Scans the module to build the
72   /// SymbolFlags and SymbolToDefinition maps.
73   IRMaterializationUnit(ExecutionSession &ES, ThreadSafeModule TSM,
74                         VModuleKey K);
75
76   /// Create an IRMaterializationLayer from a module, and pre-existing
77   /// SymbolFlags and SymbolToDefinition maps. The maps must provide
78   /// entries for each definition in M.
79   /// This constructor is useful for delegating work from one
80   /// IRMaterializationUnit to another.
81   IRMaterializationUnit(ThreadSafeModule TSM, VModuleKey K,
82                         SymbolFlagsMap SymbolFlags,
83                         SymbolNameToDefinitionMap SymbolToDefinition);
84
85   /// Return the ModuleIdentifier as the name for this MaterializationUnit.
86   StringRef getName() const override;
87
88   const ThreadSafeModule &getModule() const { return TSM; }
89
90 protected:
91   ThreadSafeModule TSM;
92   SymbolNameToDefinitionMap SymbolToDefinition;
93
94 private:
95   void discard(const JITDylib &JD, const SymbolStringPtr &Name) override;
96 };
97
98 /// MaterializationUnit that materializes modules by calling the 'emit' method
99 /// on the given IRLayer.
100 class BasicIRLayerMaterializationUnit : public IRMaterializationUnit {
101 public:
102   BasicIRLayerMaterializationUnit(IRLayer &L, VModuleKey K,
103                                   ThreadSafeModule TSM);
104
105 private:
106
107   void materialize(MaterializationResponsibility R) override;
108
109   IRLayer &L;
110   VModuleKey K;
111 };
112
113 /// Interface for Layers that accept object files.
114 class ObjectLayer {
115 public:
116   ObjectLayer(ExecutionSession &ES);
117   virtual ~ObjectLayer();
118
119   /// Returns the execution session for this layer.
120   ExecutionSession &getExecutionSession() { return ES; }
121
122   /// Adds a MaterializationUnit representing the given IR to the given
123   /// JITDylib.
124   virtual Error add(JITDylib &JD, std::unique_ptr<MemoryBuffer> O,
125                     VModuleKey K = VModuleKey());
126
127   /// Emit should materialize the given IR.
128   virtual void emit(MaterializationResponsibility R,
129                     std::unique_ptr<MemoryBuffer> O) = 0;
130
131 private:
132   ExecutionSession &ES;
133 };
134
135 /// Materializes the given object file (represented by a MemoryBuffer
136 /// instance) by calling 'emit' on the given ObjectLayer.
137 class BasicObjectLayerMaterializationUnit : public MaterializationUnit {
138 public:
139   static Expected<std::unique_ptr<BasicObjectLayerMaterializationUnit>>
140   Create(ObjectLayer &L, VModuleKey K, std::unique_ptr<MemoryBuffer> O);
141
142   BasicObjectLayerMaterializationUnit(ObjectLayer &L, VModuleKey K,
143                                       std::unique_ptr<MemoryBuffer> O,
144                                       SymbolFlagsMap SymbolFlags);
145
146   /// Return the buffer's identifier as the name for this MaterializationUnit.
147   StringRef getName() const override;
148
149 private:
150
151   void materialize(MaterializationResponsibility R) override;
152   void discard(const JITDylib &JD, const SymbolStringPtr &Name) override;
153
154   ObjectLayer &L;
155   std::unique_ptr<MemoryBuffer> O;
156 };
157
158 /// Returns a SymbolFlagsMap for the object file represented by the given
159 /// buffer, or an error if the buffer does not contain a valid object file.
160 // FIXME: Maybe move to Core.h?
161 Expected<SymbolFlagsMap> getObjectSymbolFlags(ExecutionSession &ES,
162                                               MemoryBufferRef ObjBuffer);
163
164 } // End namespace orc
165 } // End namespace llvm
166
167 #endif // LLVM_EXECUTIONENGINE_ORC_LAYER_H