blob: f66dc1dfea5e086b0d892555c6b523b78284f595 [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"
Filip Pizlo40be1e82013-05-01 20:59:00 +000018#include "llvm/IR/DerivedTypes.h"
19#include "llvm/IR/Module.h"
Torok Edwinc25e7582009-07-11 20:10:48 +000020#include "llvm/Support/ErrorHandling.h"
Anton Korobeynikovae9f3a32008-02-20 11:08:44 +000021#include <cstring>
Gordon Henriksen2e855e62007-12-23 16:59:28 +000022
23using namespace llvm;
24
Eric Christopher3e397312013-04-22 22:47:22 +000025// Wrapping the C bindings types.
Filip Pizlo40be1e82013-05-01 20:59:00 +000026DEFINE_SIMPLE_CONVERSION_FUNCTIONS(GenericValue, LLVMGenericValueRef)
Eric Christopher3e397312013-04-22 22:47:22 +000027
28inline DataLayout *unwrap(LLVMTargetDataRef P) {
29 return reinterpret_cast<DataLayout*>(P);
30}
31
32inline LLVMTargetDataRef wrap(const DataLayout *P) {
33 return reinterpret_cast<LLVMTargetDataRef>(const_cast<DataLayout*>(P));
34}
35
36inline TargetLibraryInfo *unwrap(LLVMTargetLibraryInfoRef P) {
37 return reinterpret_cast<TargetLibraryInfo*>(P);
38}
39
40inline LLVMTargetLibraryInfoRef wrap(const TargetLibraryInfo *P) {
41 TargetLibraryInfo *X = const_cast<TargetLibraryInfo*>(P);
42 return reinterpret_cast<LLVMTargetLibraryInfoRef>(X);
43}
44
Gordon Henriksen2e855e62007-12-23 16:59:28 +000045/*===-- Operations on generic values --------------------------------------===*/
46
47LLVMGenericValueRef LLVMCreateGenericValueOfInt(LLVMTypeRef Ty,
48 unsigned long long N,
Chris Lattnerd686c8e2010-01-09 22:27:07 +000049 LLVMBool IsSigned) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +000050 GenericValue *GenVal = new GenericValue();
51 GenVal->IntVal = APInt(unwrap<IntegerType>(Ty)->getBitWidth(), N, IsSigned);
52 return wrap(GenVal);
53}
54
55LLVMGenericValueRef LLVMCreateGenericValueOfPointer(void *P) {
56 GenericValue *GenVal = new GenericValue();
57 GenVal->PointerVal = P;
58 return wrap(GenVal);
59}
60
61LLVMGenericValueRef LLVMCreateGenericValueOfFloat(LLVMTypeRef TyRef, double N) {
62 GenericValue *GenVal = new GenericValue();
63 switch (unwrap(TyRef)->getTypeID()) {
64 case Type::FloatTyID:
65 GenVal->FloatVal = N;
66 break;
67 case Type::DoubleTyID:
68 GenVal->DoubleVal = N;
69 break;
70 default:
Torok Edwinc23197a2009-07-14 16:55:14 +000071 llvm_unreachable("LLVMGenericValueToFloat supports only float and double.");
Gordon Henriksen2e855e62007-12-23 16:59:28 +000072 }
73 return wrap(GenVal);
74}
75
76unsigned LLVMGenericValueIntWidth(LLVMGenericValueRef GenValRef) {
77 return unwrap(GenValRef)->IntVal.getBitWidth();
78}
79
80unsigned long long LLVMGenericValueToInt(LLVMGenericValueRef GenValRef,
Chris Lattnerd686c8e2010-01-09 22:27:07 +000081 LLVMBool IsSigned) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +000082 GenericValue *GenVal = unwrap(GenValRef);
83 if (IsSigned)
84 return GenVal->IntVal.getSExtValue();
85 else
86 return GenVal->IntVal.getZExtValue();
87}
88
89void *LLVMGenericValueToPointer(LLVMGenericValueRef GenVal) {
90 return unwrap(GenVal)->PointerVal;
91}
92
93double LLVMGenericValueToFloat(LLVMTypeRef TyRef, LLVMGenericValueRef GenVal) {
94 switch (unwrap(TyRef)->getTypeID()) {
95 case Type::FloatTyID:
96 return unwrap(GenVal)->FloatVal;
97 case Type::DoubleTyID:
98 return unwrap(GenVal)->DoubleVal;
99 default:
Torok Edwinc23197a2009-07-14 16:55:14 +0000100 llvm_unreachable("LLVMGenericValueToFloat supports only float and double.");
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000101 }
102}
103
104void LLVMDisposeGenericValue(LLVMGenericValueRef GenVal) {
105 delete unwrap(GenVal);
106}
107
108/*===-- Operations on execution engines -----------------------------------===*/
109
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000110LLVMBool LLVMCreateExecutionEngineForModule(LLVMExecutionEngineRef *OutEE,
111 LLVMModuleRef M,
112 char **OutError) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000113 std::string Error;
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000114 EngineBuilder builder(unwrap(M));
Reid Kleckner4b1511b2009-07-18 00:42:18 +0000115 builder.setEngineKind(EngineKind::Either)
116 .setErrorStr(&Error);
117 if (ExecutionEngine *EE = builder.create()){
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000118 *OutEE = wrap(EE);
119 return 0;
120 }
121 *OutError = strdup(Error.c_str());
122 return 1;
123}
124
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000125LLVMBool LLVMCreateInterpreterForModule(LLVMExecutionEngineRef *OutInterp,
126 LLVMModuleRef M,
127 char **OutError) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000128 std::string Error;
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000129 EngineBuilder builder(unwrap(M));
Reid Kleckner4b1511b2009-07-18 00:42:18 +0000130 builder.setEngineKind(EngineKind::Interpreter)
131 .setErrorStr(&Error);
132 if (ExecutionEngine *Interp = builder.create()) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000133 *OutInterp = wrap(Interp);
134 return 0;
135 }
136 *OutError = strdup(Error.c_str());
137 return 1;
138}
139
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000140LLVMBool LLVMCreateJITCompilerForModule(LLVMExecutionEngineRef *OutJIT,
141 LLVMModuleRef M,
142 unsigned OptLevel,
143 char **OutError) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000144 std::string Error;
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000145 EngineBuilder builder(unwrap(M));
Reid Kleckner4b1511b2009-07-18 00:42:18 +0000146 builder.setEngineKind(EngineKind::JIT)
147 .setErrorStr(&Error)
148 .setOptLevel((CodeGenOpt::Level)OptLevel);
149 if (ExecutionEngine *JIT = builder.create()) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000150 *OutJIT = wrap(JIT);
151 return 0;
152 }
153 *OutError = strdup(Error.c_str());
154 return 1;
155}
156
Andrew Kaylord2755af2013-04-29 17:49:40 +0000157LLVMBool LLVMCreateMCJITCompilerForModule(LLVMExecutionEngineRef *OutJIT,
158 LLVMModuleRef M,
159 LLVMMCJITCompilerOptions *PassedOptions,
160 size_t SizeOfPassedOptions,
161 char **OutError) {
162 LLVMMCJITCompilerOptions options;
163 // If the user passed a larger sized options struct, then they were compiled
164 // against a newer LLVM. Tell them that something is wrong.
165 if (SizeOfPassedOptions > sizeof(options)) {
166 *OutError = strdup(
167 "Refusing to use options struct that is larger than my own; assuming LLVM "
168 "library mismatch.");
169 return 1;
170 }
171
172 // Defend against the user having an old version of the API by ensuring that
173 // any fields they didn't see are cleared. We must defend against fields being
174 // set to the bitwise equivalent of zero, and assume that this means "do the
175 // default" as if that option hadn't been available.
176 memset(&options, 0, sizeof(options));
177 memcpy(&options, PassedOptions, SizeOfPassedOptions);
178
179 TargetOptions targetOptions;
180 targetOptions.NoFramePointerElim = options.NoFramePointerElim;
181
182 std::string Error;
183 EngineBuilder builder(unwrap(M));
184 builder.setEngineKind(EngineKind::JIT)
185 .setErrorStr(&Error)
186 .setUseMCJIT(true)
187 .setOptLevel((CodeGenOpt::Level)options.OptLevel)
188 .setTargetOptions(targetOptions);
189 if (ExecutionEngine *JIT = builder.create()) {
190 *OutJIT = wrap(JIT);
191 return 0;
192 }
193 *OutError = strdup(Error.c_str());
194 return 1;
195}
196
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000197LLVMBool LLVMCreateExecutionEngine(LLVMExecutionEngineRef *OutEE,
198 LLVMModuleProviderRef MP,
199 char **OutError) {
200 /* The module provider is now actually a module. */
201 return LLVMCreateExecutionEngineForModule(OutEE,
202 reinterpret_cast<LLVMModuleRef>(MP),
203 OutError);
204}
205
206LLVMBool LLVMCreateInterpreter(LLVMExecutionEngineRef *OutInterp,
207 LLVMModuleProviderRef MP,
208 char **OutError) {
209 /* The module provider is now actually a module. */
210 return LLVMCreateInterpreterForModule(OutInterp,
211 reinterpret_cast<LLVMModuleRef>(MP),
212 OutError);
213}
214
215LLVMBool LLVMCreateJITCompiler(LLVMExecutionEngineRef *OutJIT,
216 LLVMModuleProviderRef MP,
217 unsigned OptLevel,
218 char **OutError) {
219 /* The module provider is now actually a module. */
220 return LLVMCreateJITCompilerForModule(OutJIT,
221 reinterpret_cast<LLVMModuleRef>(MP),
222 OptLevel, OutError);
223}
224
225
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000226void LLVMDisposeExecutionEngine(LLVMExecutionEngineRef EE) {
227 delete unwrap(EE);
228}
229
230void LLVMRunStaticConstructors(LLVMExecutionEngineRef EE) {
231 unwrap(EE)->runStaticConstructorsDestructors(false);
232}
233
234void LLVMRunStaticDestructors(LLVMExecutionEngineRef EE) {
235 unwrap(EE)->runStaticConstructorsDestructors(true);
236}
237
238int LLVMRunFunctionAsMain(LLVMExecutionEngineRef EE, LLVMValueRef F,
239 unsigned ArgC, const char * const *ArgV,
240 const char * const *EnvP) {
Andrew Kaylord2755af2013-04-29 17:49:40 +0000241 unwrap(EE)->finalizeObject();
242
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000243 std::vector<std::string> ArgVec;
244 for (unsigned I = 0; I != ArgC; ++I)
245 ArgVec.push_back(ArgV[I]);
246
247 return unwrap(EE)->runFunctionAsMain(unwrap<Function>(F), ArgVec, EnvP);
248}
249
250LLVMGenericValueRef LLVMRunFunction(LLVMExecutionEngineRef EE, LLVMValueRef F,
251 unsigned NumArgs,
252 LLVMGenericValueRef *Args) {
Andrew Kaylord2755af2013-04-29 17:49:40 +0000253 unwrap(EE)->finalizeObject();
254
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000255 std::vector<GenericValue> ArgVec;
256 ArgVec.reserve(NumArgs);
257 for (unsigned I = 0; I != NumArgs; ++I)
258 ArgVec.push_back(*unwrap(Args[I]));
259
260 GenericValue *Result = new GenericValue();
261 *Result = unwrap(EE)->runFunction(unwrap<Function>(F), ArgVec);
262 return wrap(Result);
263}
264
265void LLVMFreeMachineCodeForFunction(LLVMExecutionEngineRef EE, LLVMValueRef F) {
266 unwrap(EE)->freeMachineCodeForFunction(unwrap<Function>(F));
267}
268
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000269void LLVMAddModule(LLVMExecutionEngineRef EE, LLVMModuleRef M){
270 unwrap(EE)->addModule(unwrap(M));
271}
272
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000273void LLVMAddModuleProvider(LLVMExecutionEngineRef EE, LLVMModuleProviderRef MP){
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000274 /* The module provider is now actually a module. */
275 LLVMAddModule(EE, reinterpret_cast<LLVMModuleRef>(MP));
276}
277
278LLVMBool LLVMRemoveModule(LLVMExecutionEngineRef EE, LLVMModuleRef M,
279 LLVMModuleRef *OutMod, char **OutError) {
280 Module *Mod = unwrap(M);
281 unwrap(EE)->removeModule(Mod);
282 *OutMod = wrap(Mod);
283 return 0;
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000284}
285
Chris Lattnerd686c8e2010-01-09 22:27:07 +0000286LLVMBool LLVMRemoveModuleProvider(LLVMExecutionEngineRef EE,
287 LLVMModuleProviderRef MP,
288 LLVMModuleRef *OutMod, char **OutError) {
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000289 /* The module provider is now actually a module. */
290 return LLVMRemoveModule(EE, reinterpret_cast<LLVMModuleRef>(MP), OutMod,
291 OutError);
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000292}
293
Chris Lattnerd686c8e2010-01-09 22:27:07 +0000294LLVMBool LLVMFindFunction(LLVMExecutionEngineRef EE, const char *Name,
295 LLVMValueRef *OutFn) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000296 if (Function *F = unwrap(EE)->FindFunctionNamed(Name)) {
297 *OutFn = wrap(F);
298 return 0;
299 }
300 return 1;
301}
Erick Tryzelaar7c1483b2008-03-27 00:27:14 +0000302
Duncan Sandsd90fee92010-07-19 09:33:13 +0000303void *LLVMRecompileAndRelinkFunction(LLVMExecutionEngineRef EE, LLVMValueRef Fn) {
Duncan Sandse117b632010-07-19 09:36:45 +0000304 return unwrap(EE)->recompileAndRelinkFunction(unwrap<Function>(Fn));
Duncan Sandsd90fee92010-07-19 09:33:13 +0000305}
306
Erick Tryzelaar7c1483b2008-03-27 00:27:14 +0000307LLVMTargetDataRef LLVMGetExecutionEngineTargetData(LLVMExecutionEngineRef EE) {
Micah Villmow3574eca2012-10-08 16:38:25 +0000308 return wrap(unwrap(EE)->getDataLayout());
Erick Tryzelaar7c1483b2008-03-27 00:27:14 +0000309}
Gordon Henriksen54227f62008-06-20 02:16:11 +0000310
311void LLVMAddGlobalMapping(LLVMExecutionEngineRef EE, LLVMValueRef Global,
312 void* Addr) {
313 unwrap(EE)->addGlobalMapping(unwrap<GlobalValue>(Global), Addr);
314}
Chris Lattner1e42c5b2009-01-21 18:11:10 +0000315
316void *LLVMGetPointerToGlobal(LLVMExecutionEngineRef EE, LLVMValueRef Global) {
Andrew Kaylord2755af2013-04-29 17:49:40 +0000317 unwrap(EE)->finalizeObject();
318
Chris Lattner1e42c5b2009-01-21 18:11:10 +0000319 return unwrap(EE)->getPointerToGlobal(unwrap<GlobalValue>(Global));
320}