blob: f9b08a01ea7d61b0ad942dc7c9dcf3d25f7a7ba7 [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
Filip Pizlo0e1327e2013-05-01 22:58:00 +0000157void LLVMInitializeMCJITCompilerOptions(LLVMMCJITCompilerOptions *PassedOptions,
158 size_t SizeOfPassedOptions) {
159 LLVMMCJITCompilerOptions options;
160 options.OptLevel = 0;
161 options.CodeModel = LLVMCodeModelJITDefault;
162 options.NoFramePointerElim = false;
163 options.EnableFastISel = false;
164
165 memcpy(PassedOptions, &options,
166 std::min(sizeof(options), SizeOfPassedOptions));
167}
168
169LLVMBool LLVMCreateMCJITCompilerForModule(
170 LLVMExecutionEngineRef *OutJIT, LLVMModuleRef M,
171 LLVMMCJITCompilerOptions *PassedOptions, size_t SizeOfPassedOptions,
172 char **OutError) {
Andrew Kaylord2755af2013-04-29 17:49:40 +0000173 LLVMMCJITCompilerOptions options;
174 // If the user passed a larger sized options struct, then they were compiled
175 // against a newer LLVM. Tell them that something is wrong.
176 if (SizeOfPassedOptions > sizeof(options)) {
177 *OutError = strdup(
Filip Pizlo0e1327e2013-05-01 22:58:00 +0000178 "Refusing to use options struct that is larger than my own; assuming "
179 "LLVM library mismatch.");
Andrew Kaylord2755af2013-04-29 17:49:40 +0000180 return 1;
181 }
182
183 // Defend against the user having an old version of the API by ensuring that
184 // any fields they didn't see are cleared. We must defend against fields being
185 // set to the bitwise equivalent of zero, and assume that this means "do the
186 // default" as if that option hadn't been available.
Filip Pizlo0e1327e2013-05-01 22:58:00 +0000187 LLVMInitializeMCJITCompilerOptions(&options, sizeof(options));
Andrew Kaylord2755af2013-04-29 17:49:40 +0000188 memcpy(&options, PassedOptions, SizeOfPassedOptions);
189
190 TargetOptions targetOptions;
191 targetOptions.NoFramePointerElim = options.NoFramePointerElim;
Filip Pizlo0e1327e2013-05-01 22:58:00 +0000192 targetOptions.EnableFastISel = options.EnableFastISel;
Andrew Kaylord2755af2013-04-29 17:49:40 +0000193
194 std::string Error;
195 EngineBuilder builder(unwrap(M));
196 builder.setEngineKind(EngineKind::JIT)
197 .setErrorStr(&Error)
198 .setUseMCJIT(true)
199 .setOptLevel((CodeGenOpt::Level)options.OptLevel)
Filip Pizlo0e1327e2013-05-01 22:58:00 +0000200 .setCodeModel(unwrap(options.CodeModel))
Andrew Kaylord2755af2013-04-29 17:49:40 +0000201 .setTargetOptions(targetOptions);
202 if (ExecutionEngine *JIT = builder.create()) {
203 *OutJIT = wrap(JIT);
204 return 0;
205 }
206 *OutError = strdup(Error.c_str());
207 return 1;
208}
209
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000210LLVMBool LLVMCreateExecutionEngine(LLVMExecutionEngineRef *OutEE,
211 LLVMModuleProviderRef MP,
212 char **OutError) {
213 /* The module provider is now actually a module. */
214 return LLVMCreateExecutionEngineForModule(OutEE,
215 reinterpret_cast<LLVMModuleRef>(MP),
216 OutError);
217}
218
219LLVMBool LLVMCreateInterpreter(LLVMExecutionEngineRef *OutInterp,
220 LLVMModuleProviderRef MP,
221 char **OutError) {
222 /* The module provider is now actually a module. */
223 return LLVMCreateInterpreterForModule(OutInterp,
224 reinterpret_cast<LLVMModuleRef>(MP),
225 OutError);
226}
227
228LLVMBool LLVMCreateJITCompiler(LLVMExecutionEngineRef *OutJIT,
229 LLVMModuleProviderRef MP,
230 unsigned OptLevel,
231 char **OutError) {
232 /* The module provider is now actually a module. */
233 return LLVMCreateJITCompilerForModule(OutJIT,
234 reinterpret_cast<LLVMModuleRef>(MP),
235 OptLevel, OutError);
236}
237
238
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000239void LLVMDisposeExecutionEngine(LLVMExecutionEngineRef EE) {
240 delete unwrap(EE);
241}
242
243void LLVMRunStaticConstructors(LLVMExecutionEngineRef EE) {
244 unwrap(EE)->runStaticConstructorsDestructors(false);
245}
246
247void LLVMRunStaticDestructors(LLVMExecutionEngineRef EE) {
248 unwrap(EE)->runStaticConstructorsDestructors(true);
249}
250
251int LLVMRunFunctionAsMain(LLVMExecutionEngineRef EE, LLVMValueRef F,
252 unsigned ArgC, const char * const *ArgV,
253 const char * const *EnvP) {
Andrew Kaylord2755af2013-04-29 17:49:40 +0000254 unwrap(EE)->finalizeObject();
255
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000256 std::vector<std::string> ArgVec;
257 for (unsigned I = 0; I != ArgC; ++I)
258 ArgVec.push_back(ArgV[I]);
259
260 return unwrap(EE)->runFunctionAsMain(unwrap<Function>(F), ArgVec, EnvP);
261}
262
263LLVMGenericValueRef LLVMRunFunction(LLVMExecutionEngineRef EE, LLVMValueRef F,
264 unsigned NumArgs,
265 LLVMGenericValueRef *Args) {
Andrew Kaylord2755af2013-04-29 17:49:40 +0000266 unwrap(EE)->finalizeObject();
267
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000268 std::vector<GenericValue> ArgVec;
269 ArgVec.reserve(NumArgs);
270 for (unsigned I = 0; I != NumArgs; ++I)
271 ArgVec.push_back(*unwrap(Args[I]));
272
273 GenericValue *Result = new GenericValue();
274 *Result = unwrap(EE)->runFunction(unwrap<Function>(F), ArgVec);
275 return wrap(Result);
276}
277
278void LLVMFreeMachineCodeForFunction(LLVMExecutionEngineRef EE, LLVMValueRef F) {
279 unwrap(EE)->freeMachineCodeForFunction(unwrap<Function>(F));
280}
281
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000282void LLVMAddModule(LLVMExecutionEngineRef EE, LLVMModuleRef M){
283 unwrap(EE)->addModule(unwrap(M));
284}
285
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000286void LLVMAddModuleProvider(LLVMExecutionEngineRef EE, LLVMModuleProviderRef MP){
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000287 /* The module provider is now actually a module. */
288 LLVMAddModule(EE, reinterpret_cast<LLVMModuleRef>(MP));
289}
290
291LLVMBool LLVMRemoveModule(LLVMExecutionEngineRef EE, LLVMModuleRef M,
292 LLVMModuleRef *OutMod, char **OutError) {
293 Module *Mod = unwrap(M);
294 unwrap(EE)->removeModule(Mod);
295 *OutMod = wrap(Mod);
296 return 0;
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000297}
298
Chris Lattnerd686c8e2010-01-09 22:27:07 +0000299LLVMBool LLVMRemoveModuleProvider(LLVMExecutionEngineRef EE,
300 LLVMModuleProviderRef MP,
301 LLVMModuleRef *OutMod, char **OutError) {
Erick Tryzelaardf7df072010-03-02 23:58:54 +0000302 /* The module provider is now actually a module. */
303 return LLVMRemoveModule(EE, reinterpret_cast<LLVMModuleRef>(MP), OutMod,
304 OutError);
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000305}
306
Chris Lattnerd686c8e2010-01-09 22:27:07 +0000307LLVMBool LLVMFindFunction(LLVMExecutionEngineRef EE, const char *Name,
308 LLVMValueRef *OutFn) {
Gordon Henriksen2e855e62007-12-23 16:59:28 +0000309 if (Function *F = unwrap(EE)->FindFunctionNamed(Name)) {
310 *OutFn = wrap(F);
311 return 0;
312 }
313 return 1;
314}
Erick Tryzelaar7c1483b2008-03-27 00:27:14 +0000315
Filip Pizlo0e1327e2013-05-01 22:58:00 +0000316void *LLVMRecompileAndRelinkFunction(LLVMExecutionEngineRef EE,
317 LLVMValueRef Fn) {
Duncan Sandse117b632010-07-19 09:36:45 +0000318 return unwrap(EE)->recompileAndRelinkFunction(unwrap<Function>(Fn));
Duncan Sandsd90fee92010-07-19 09:33:13 +0000319}
320
Erick Tryzelaar7c1483b2008-03-27 00:27:14 +0000321LLVMTargetDataRef LLVMGetExecutionEngineTargetData(LLVMExecutionEngineRef EE) {
Micah Villmow3574eca2012-10-08 16:38:25 +0000322 return wrap(unwrap(EE)->getDataLayout());
Erick Tryzelaar7c1483b2008-03-27 00:27:14 +0000323}
Gordon Henriksen54227f62008-06-20 02:16:11 +0000324
325void LLVMAddGlobalMapping(LLVMExecutionEngineRef EE, LLVMValueRef Global,
326 void* Addr) {
327 unwrap(EE)->addGlobalMapping(unwrap<GlobalValue>(Global), Addr);
328}
Chris Lattner1e42c5b2009-01-21 18:11:10 +0000329
330void *LLVMGetPointerToGlobal(LLVMExecutionEngineRef EE, LLVMValueRef Global) {
Andrew Kaylord2755af2013-04-29 17:49:40 +0000331 unwrap(EE)->finalizeObject();
332
Chris Lattner1e42c5b2009-01-21 18:11:10 +0000333 return unwrap(EE)->getPointerToGlobal(unwrap<GlobalValue>(Global));
334}