blob: 44fa92205b282410d13e310b6fd455a50fd6b984 [file] [log] [blame]
Gordon Henriksen2e855e62007-12-23 16:59:28 +00001//===-- ExecutionEngineBindings.cpp - C bindings for EEs ------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
Chris Lattner4ee451d2007-12-29 20:36:04 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Gordon Henriksen2e855e62007-12-23 16:59:28 +00007//
8//===----------------------------------------------------------------------===//
9//
10// This file defines the C bindings for the ExecutionEngine library.
11//
12//===----------------------------------------------------------------------===//
13
14#define DEBUG_TYPE "jit"
15#include "llvm-c/ExecutionEngine.h"
Gordon Henriksen2e855e62007-12-23 16:59:28 +000016#include "llvm/ExecutionEngine/ExecutionEngine.h"
Chandler Carruthd04a8d42012-12-03 16:50:05 +000017#include "llvm/ExecutionEngine/GenericValue.h"
Torok Edwinc25e7582009-07-11 20:10:48 +000018#include "llvm/Support/ErrorHandling.h"
Anton Korobeynikovae9f3a32008-02-20 11:08:44 +000019#include <cstring>
Gordon Henriksen2e855e62007-12-23 16:59:28 +000020
21using namespace llvm;
22
Eric Christopher3e397312013-04-22 22:47:22 +000023// Wrapping the C bindings types.
24DEFINE_SIMPLE_CONVERSION_FUNCTIONS(GenericValue, LLVMGenericValueRef )
Eric Christopher3e397312013-04-22 22:47:22 +000025
26inline DataLayout *unwrap(LLVMTargetDataRef P) {
27 return reinterpret_cast<DataLayout*>(P);
28}
29
30inline LLVMTargetDataRef wrap(const DataLayout *P) {
31 return reinterpret_cast<LLVMTargetDataRef>(const_cast<DataLayout*>(P));
32}
33
34inline TargetLibraryInfo *unwrap(LLVMTargetLibraryInfoRef P) {
35 return reinterpret_cast<TargetLibraryInfo*>(P);
36}
37
38inline LLVMTargetLibraryInfoRef wrap(const TargetLibraryInfo *P) {
39 TargetLibraryInfo *X = const_cast<TargetLibraryInfo*>(P);
40 return reinterpret_cast<LLVMTargetLibraryInfoRef>(X);
41}
42
Gordon Henriksen2e855e62007-12-23 16:59:28 +000043/*===-- Operations on generic values --------------------------------------===*/
44
45LLVMGenericValueRef LLVMCreateGenericValueOfInt(LLVMTypeRef Ty,
46 unsigned long long N,
Chris Lattnerd686c8e2010-01-09 22:27:07 +000047 LLVMBool IsSigned) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +000048 GenericValue *GenVal = new GenericValue();
49 GenVal->IntVal = APInt(unwrap<IntegerType>(Ty)->getBitWidth(), N, IsSigned);
50 return wrap(GenVal);
51}
52
53LLVMGenericValueRef LLVMCreateGenericValueOfPointer(void *P) {
54 GenericValue *GenVal = new GenericValue();
55 GenVal->PointerVal = P;
56 return wrap(GenVal);
57}
58
59LLVMGenericValueRef LLVMCreateGenericValueOfFloat(LLVMTypeRef TyRef, double N) {
60 GenericValue *GenVal = new GenericValue();
61 switch (unwrap(TyRef)->getTypeID()) {
62 case Type::FloatTyID:
63 GenVal->FloatVal = N;
64 break;
65 case Type::DoubleTyID:
66 GenVal->DoubleVal = N;
67 break;
68 default:
Torok Edwinc23197a2009-07-14 16:55:14 +000069 llvm_unreachable("LLVMGenericValueToFloat supports only float and double.");
Gordon Henriksen2e855e62007-12-23 16:59:28 +000070 }
71 return wrap(GenVal);
72}
73
74unsigned LLVMGenericValueIntWidth(LLVMGenericValueRef GenValRef) {
75 return unwrap(GenValRef)->IntVal.getBitWidth();
76}
77
78unsigned long long LLVMGenericValueToInt(LLVMGenericValueRef GenValRef,
Chris Lattnerd686c8e2010-01-09 22:27:07 +000079 LLVMBool IsSigned) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +000080 GenericValue *GenVal = unwrap(GenValRef);
81 if (IsSigned)
82 return GenVal->IntVal.getSExtValue();
83 else
84 return GenVal->IntVal.getZExtValue();
85}
86
87void *LLVMGenericValueToPointer(LLVMGenericValueRef GenVal) {
88 return unwrap(GenVal)->PointerVal;
89}
90
91double LLVMGenericValueToFloat(LLVMTypeRef TyRef, LLVMGenericValueRef GenVal) {
92 switch (unwrap(TyRef)->getTypeID()) {
93 case Type::FloatTyID:
94 return unwrap(GenVal)->FloatVal;
95 case Type::DoubleTyID:
96 return unwrap(GenVal)->DoubleVal;
97 default:
Torok Edwinc23197a2009-07-14 16:55:14 +000098 llvm_unreachable("LLVMGenericValueToFloat supports only float and double.");
Gordon Henriksen2e855e62007-12-23 16:59:28 +000099 }
100}
101
102void LLVMDisposeGenericValue(LLVMGenericValueRef GenVal) {
103 delete unwrap(GenVal);
104}
105
106/*===-- Operations on execution engines -----------------------------------===*/
107
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000108LLVMBool LLVMCreateExecutionEngineForModule(LLVMExecutionEngineRef *OutEE,
109 LLVMModuleRef M,
110 char **OutError) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000111 std::string Error;
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000112 EngineBuilder builder(unwrap(M));
Reid Kleckner4b1511b2009-07-18 00:42:18 +0000113 builder.setEngineKind(EngineKind::Either)
114 .setErrorStr(&Error);
115 if (ExecutionEngine *EE = builder.create()){
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000116 *OutEE = wrap(EE);
117 return 0;
118 }
119 *OutError = strdup(Error.c_str());
120 return 1;
121}
122
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000123LLVMBool LLVMCreateInterpreterForModule(LLVMExecutionEngineRef *OutInterp,
124 LLVMModuleRef M,
125 char **OutError) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000126 std::string Error;
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000127 EngineBuilder builder(unwrap(M));
Reid Kleckner4b1511b2009-07-18 00:42:18 +0000128 builder.setEngineKind(EngineKind::Interpreter)
129 .setErrorStr(&Error);
130 if (ExecutionEngine *Interp = builder.create()) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000131 *OutInterp = wrap(Interp);
132 return 0;
133 }
134 *OutError = strdup(Error.c_str());
135 return 1;
136}
137
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000138LLVMBool LLVMCreateJITCompilerForModule(LLVMExecutionEngineRef *OutJIT,
139 LLVMModuleRef M,
140 unsigned OptLevel,
141 char **OutError) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000142 std::string Error;
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000143 EngineBuilder builder(unwrap(M));
Reid Kleckner4b1511b2009-07-18 00:42:18 +0000144 builder.setEngineKind(EngineKind::JIT)
145 .setErrorStr(&Error)
146 .setOptLevel((CodeGenOpt::Level)OptLevel);
147 if (ExecutionEngine *JIT = builder.create()) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000148 *OutJIT = wrap(JIT);
149 return 0;
150 }
151 *OutError = strdup(Error.c_str());
152 return 1;
153}
154
Andrew Kaylord2755af2013-04-29 17:49:40 +0000155LLVMBool LLVMCreateMCJITCompilerForModule(LLVMExecutionEngineRef *OutJIT,
156 LLVMModuleRef M,
157 LLVMMCJITCompilerOptions *PassedOptions,
158 size_t SizeOfPassedOptions,
159 char **OutError) {
160 LLVMMCJITCompilerOptions options;
161 // If the user passed a larger sized options struct, then they were compiled
162 // against a newer LLVM. Tell them that something is wrong.
163 if (SizeOfPassedOptions > sizeof(options)) {
164 *OutError = strdup(
165 "Refusing to use options struct that is larger than my own; assuming LLVM "
166 "library mismatch.");
167 return 1;
168 }
169
170 // Defend against the user having an old version of the API by ensuring that
171 // any fields they didn't see are cleared. We must defend against fields being
172 // set to the bitwise equivalent of zero, and assume that this means "do the
173 // default" as if that option hadn't been available.
174 memset(&options, 0, sizeof(options));
175 memcpy(&options, PassedOptions, SizeOfPassedOptions);
176
177 TargetOptions targetOptions;
178 targetOptions.NoFramePointerElim = options.NoFramePointerElim;
179
180 std::string Error;
181 EngineBuilder builder(unwrap(M));
182 builder.setEngineKind(EngineKind::JIT)
183 .setErrorStr(&Error)
184 .setUseMCJIT(true)
185 .setOptLevel((CodeGenOpt::Level)options.OptLevel)
186 .setTargetOptions(targetOptions);
187 if (ExecutionEngine *JIT = builder.create()) {
188 *OutJIT = wrap(JIT);
189 return 0;
190 }
191 *OutError = strdup(Error.c_str());
192 return 1;
193}
194
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000195LLVMBool LLVMCreateExecutionEngine(LLVMExecutionEngineRef *OutEE,
196 LLVMModuleProviderRef MP,
197 char **OutError) {
198 /* The module provider is now actually a module. */
199 return LLVMCreateExecutionEngineForModule(OutEE,
200 reinterpret_cast<LLVMModuleRef>(MP),
201 OutError);
202}
203
204LLVMBool LLVMCreateInterpreter(LLVMExecutionEngineRef *OutInterp,
205 LLVMModuleProviderRef MP,
206 char **OutError) {
207 /* The module provider is now actually a module. */
208 return LLVMCreateInterpreterForModule(OutInterp,
209 reinterpret_cast<LLVMModuleRef>(MP),
210 OutError);
211}
212
213LLVMBool LLVMCreateJITCompiler(LLVMExecutionEngineRef *OutJIT,
214 LLVMModuleProviderRef MP,
215 unsigned OptLevel,
216 char **OutError) {
217 /* The module provider is now actually a module. */
218 return LLVMCreateJITCompilerForModule(OutJIT,
219 reinterpret_cast<LLVMModuleRef>(MP),
220 OptLevel, OutError);
221}
222
223
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000224void LLVMDisposeExecutionEngine(LLVMExecutionEngineRef EE) {
225 delete unwrap(EE);
226}
227
228void LLVMRunStaticConstructors(LLVMExecutionEngineRef EE) {
229 unwrap(EE)->runStaticConstructorsDestructors(false);
230}
231
232void LLVMRunStaticDestructors(LLVMExecutionEngineRef EE) {
233 unwrap(EE)->runStaticConstructorsDestructors(true);
234}
235
236int LLVMRunFunctionAsMain(LLVMExecutionEngineRef EE, LLVMValueRef F,
237 unsigned ArgC, const char * const *ArgV,
238 const char * const *EnvP) {
Andrew Kaylord2755af2013-04-29 17:49:40 +0000239 unwrap(EE)->finalizeObject();
240
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000241 std::vector<std::string> ArgVec;
242 for (unsigned I = 0; I != ArgC; ++I)
243 ArgVec.push_back(ArgV[I]);
244
245 return unwrap(EE)->runFunctionAsMain(unwrap<Function>(F), ArgVec, EnvP);
246}
247
248LLVMGenericValueRef LLVMRunFunction(LLVMExecutionEngineRef EE, LLVMValueRef F,
249 unsigned NumArgs,
250 LLVMGenericValueRef *Args) {
Andrew Kaylord2755af2013-04-29 17:49:40 +0000251 unwrap(EE)->finalizeObject();
252
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000253 std::vector<GenericValue> ArgVec;
254 ArgVec.reserve(NumArgs);
255 for (unsigned I = 0; I != NumArgs; ++I)
256 ArgVec.push_back(*unwrap(Args[I]));
257
258 GenericValue *Result = new GenericValue();
259 *Result = unwrap(EE)->runFunction(unwrap<Function>(F), ArgVec);
260 return wrap(Result);
261}
262
263void LLVMFreeMachineCodeForFunction(LLVMExecutionEngineRef EE, LLVMValueRef F) {
264 unwrap(EE)->freeMachineCodeForFunction(unwrap<Function>(F));
265}
266
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000267void LLVMAddModule(LLVMExecutionEngineRef EE, LLVMModuleRef M){
268 unwrap(EE)->addModule(unwrap(M));
269}
270
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000271void LLVMAddModuleProvider(LLVMExecutionEngineRef EE, LLVMModuleProviderRef MP){
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000272 /* The module provider is now actually a module. */
273 LLVMAddModule(EE, reinterpret_cast<LLVMModuleRef>(MP));
274}
275
276LLVMBool LLVMRemoveModule(LLVMExecutionEngineRef EE, LLVMModuleRef M,
277 LLVMModuleRef *OutMod, char **OutError) {
278 Module *Mod = unwrap(M);
279 unwrap(EE)->removeModule(Mod);
280 *OutMod = wrap(Mod);
281 return 0;
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000282}
283
Chris Lattnerd686c8e2010-01-09 22:27:07 +0000284LLVMBool LLVMRemoveModuleProvider(LLVMExecutionEngineRef EE,
285 LLVMModuleProviderRef MP,
286 LLVMModuleRef *OutMod, char **OutError) {
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000287 /* The module provider is now actually a module. */
288 return LLVMRemoveModule(EE, reinterpret_cast<LLVMModuleRef>(MP), OutMod,
289 OutError);
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000290}
291
Chris Lattnerd686c8e2010-01-09 22:27:07 +0000292LLVMBool LLVMFindFunction(LLVMExecutionEngineRef EE, const char *Name,
293 LLVMValueRef *OutFn) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000294 if (Function *F = unwrap(EE)->FindFunctionNamed(Name)) {
295 *OutFn = wrap(F);
296 return 0;
297 }
298 return 1;
299}
Erick Tryzelaar7c1483b2008-03-27 00:27:14 +0000300
Duncan Sandsd90fee92010-07-19 09:33:13 +0000301void *LLVMRecompileAndRelinkFunction(LLVMExecutionEngineRef EE, LLVMValueRef Fn) {
Duncan Sandse117b632010-07-19 09:36:45 +0000302 return unwrap(EE)->recompileAndRelinkFunction(unwrap<Function>(Fn));
Duncan Sandsd90fee92010-07-19 09:33:13 +0000303}
304
Erick Tryzelaar7c1483b2008-03-27 00:27:14 +0000305LLVMTargetDataRef LLVMGetExecutionEngineTargetData(LLVMExecutionEngineRef EE) {
Micah Villmow3574eca2012-10-08 16:38:25 +0000306 return wrap(unwrap(EE)->getDataLayout());
Erick Tryzelaar7c1483b2008-03-27 00:27:14 +0000307}
Gordon Henriksen54227f62008-06-20 02:16:11 +0000308
309void LLVMAddGlobalMapping(LLVMExecutionEngineRef EE, LLVMValueRef Global,
310 void* Addr) {
311 unwrap(EE)->addGlobalMapping(unwrap<GlobalValue>(Global), Addr);
312}
Chris Lattner1e42c5b2009-01-21 18:11:10 +0000313
314void *LLVMGetPointerToGlobal(LLVMExecutionEngineRef EE, LLVMValueRef Global) {
Andrew Kaylord2755af2013-04-29 17:49:40 +0000315 unwrap(EE)->finalizeObject();
316
Chris Lattner1e42c5b2009-01-21 18:11:10 +0000317 return unwrap(EE)->getPointerToGlobal(unwrap<GlobalValue>(Global));
318}