1 //===-- ExecutionEngineBindings.cpp - C bindings for EEs ------------------===//
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 // This file defines the C bindings for the ExecutionEngine library.
11 //
12 //===----------------------------------------------------------------------===//
13
14 #define DEBUG_TYPE "jit"
15 #include "llvm-c/ExecutionEngine.h"
16 #include "llvm/ExecutionEngine/GenericValue.h"
17 #include "llvm/ExecutionEngine/ExecutionEngine.h"
18 #include "llvm/Support/ErrorHandling.h"
19 #include <cstring>
20
21 using namespace llvm;
22
23 /*===-- Operations on generic values --------------------------------------===*/
24
LLVMCreateGenericValueOfInt(LLVMTypeRef Ty,unsigned long long N,LLVMBool IsSigned)25 LLVMGenericValueRef LLVMCreateGenericValueOfInt(LLVMTypeRef Ty,
26 unsigned long long N,
27 LLVMBool IsSigned) {
28 GenericValue *GenVal = new GenericValue();
29 GenVal->IntVal = APInt(unwrap<IntegerType>(Ty)->getBitWidth(), N, IsSigned);
30 return wrap(GenVal);
31 }
32
LLVMCreateGenericValueOfPointer(void * P)33 LLVMGenericValueRef LLVMCreateGenericValueOfPointer(void *P) {
34 GenericValue *GenVal = new GenericValue();
35 GenVal->PointerVal = P;
36 return wrap(GenVal);
37 }
38
LLVMCreateGenericValueOfFloat(LLVMTypeRef TyRef,double N)39 LLVMGenericValueRef LLVMCreateGenericValueOfFloat(LLVMTypeRef TyRef, double N) {
40 GenericValue *GenVal = new GenericValue();
41 switch (unwrap(TyRef)->getTypeID()) {
42 case Type::FloatTyID:
43 GenVal->FloatVal = N;
44 break;
45 case Type::DoubleTyID:
46 GenVal->DoubleVal = N;
47 break;
48 default:
49 llvm_unreachable("LLVMGenericValueToFloat supports only float and double.");
50 }
51 return wrap(GenVal);
52 }
53
LLVMGenericValueIntWidth(LLVMGenericValueRef GenValRef)54 unsigned LLVMGenericValueIntWidth(LLVMGenericValueRef GenValRef) {
55 return unwrap(GenValRef)->IntVal.getBitWidth();
56 }
57
LLVMGenericValueToInt(LLVMGenericValueRef GenValRef,LLVMBool IsSigned)58 unsigned long long LLVMGenericValueToInt(LLVMGenericValueRef GenValRef,
59 LLVMBool IsSigned) {
60 GenericValue *GenVal = unwrap(GenValRef);
61 if (IsSigned)
62 return GenVal->IntVal.getSExtValue();
63 else
64 return GenVal->IntVal.getZExtValue();
65 }
66
LLVMGenericValueToPointer(LLVMGenericValueRef GenVal)67 void *LLVMGenericValueToPointer(LLVMGenericValueRef GenVal) {
68 return unwrap(GenVal)->PointerVal;
69 }
70
LLVMGenericValueToFloat(LLVMTypeRef TyRef,LLVMGenericValueRef GenVal)71 double LLVMGenericValueToFloat(LLVMTypeRef TyRef, LLVMGenericValueRef GenVal) {
72 switch (unwrap(TyRef)->getTypeID()) {
73 case Type::FloatTyID:
74 return unwrap(GenVal)->FloatVal;
75 case Type::DoubleTyID:
76 return unwrap(GenVal)->DoubleVal;
77 default:
78 llvm_unreachable("LLVMGenericValueToFloat supports only float and double.");
79 break;
80 }
81 return 0; // Not reached
82 }
83
LLVMDisposeGenericValue(LLVMGenericValueRef GenVal)84 void LLVMDisposeGenericValue(LLVMGenericValueRef GenVal) {
85 delete unwrap(GenVal);
86 }
87
88 /*===-- Operations on execution engines -----------------------------------===*/
89
LLVMCreateExecutionEngineForModule(LLVMExecutionEngineRef * OutEE,LLVMModuleRef M,char ** OutError)90 LLVMBool LLVMCreateExecutionEngineForModule(LLVMExecutionEngineRef *OutEE,
91 LLVMModuleRef M,
92 char **OutError) {
93 std::string Error;
94 EngineBuilder builder(unwrap(M));
95 builder.setEngineKind(EngineKind::Either)
96 .setErrorStr(&Error);
97 if (ExecutionEngine *EE = builder.create()){
98 *OutEE = wrap(EE);
99 return 0;
100 }
101 *OutError = strdup(Error.c_str());
102 return 1;
103 }
104
LLVMCreateInterpreterForModule(LLVMExecutionEngineRef * OutInterp,LLVMModuleRef M,char ** OutError)105 LLVMBool LLVMCreateInterpreterForModule(LLVMExecutionEngineRef *OutInterp,
106 LLVMModuleRef M,
107 char **OutError) {
108 std::string Error;
109 EngineBuilder builder(unwrap(M));
110 builder.setEngineKind(EngineKind::Interpreter)
111 .setErrorStr(&Error);
112 if (ExecutionEngine *Interp = builder.create()) {
113 *OutInterp = wrap(Interp);
114 return 0;
115 }
116 *OutError = strdup(Error.c_str());
117 return 1;
118 }
119
LLVMCreateJITCompilerForModule(LLVMExecutionEngineRef * OutJIT,LLVMModuleRef M,unsigned OptLevel,char ** OutError)120 LLVMBool LLVMCreateJITCompilerForModule(LLVMExecutionEngineRef *OutJIT,
121 LLVMModuleRef M,
122 unsigned OptLevel,
123 char **OutError) {
124 std::string Error;
125 EngineBuilder builder(unwrap(M));
126 builder.setEngineKind(EngineKind::JIT)
127 .setErrorStr(&Error)
128 .setOptLevel((CodeGenOpt::Level)OptLevel);
129 if (ExecutionEngine *JIT = builder.create()) {
130 *OutJIT = wrap(JIT);
131 return 0;
132 }
133 *OutError = strdup(Error.c_str());
134 return 1;
135 }
136
LLVMCreateExecutionEngine(LLVMExecutionEngineRef * OutEE,LLVMModuleProviderRef MP,char ** OutError)137 LLVMBool LLVMCreateExecutionEngine(LLVMExecutionEngineRef *OutEE,
138 LLVMModuleProviderRef MP,
139 char **OutError) {
140 /* The module provider is now actually a module. */
141 return LLVMCreateExecutionEngineForModule(OutEE,
142 reinterpret_cast<LLVMModuleRef>(MP),
143 OutError);
144 }
145
LLVMCreateInterpreter(LLVMExecutionEngineRef * OutInterp,LLVMModuleProviderRef MP,char ** OutError)146 LLVMBool LLVMCreateInterpreter(LLVMExecutionEngineRef *OutInterp,
147 LLVMModuleProviderRef MP,
148 char **OutError) {
149 /* The module provider is now actually a module. */
150 return LLVMCreateInterpreterForModule(OutInterp,
151 reinterpret_cast<LLVMModuleRef>(MP),
152 OutError);
153 }
154
LLVMCreateJITCompiler(LLVMExecutionEngineRef * OutJIT,LLVMModuleProviderRef MP,unsigned OptLevel,char ** OutError)155 LLVMBool LLVMCreateJITCompiler(LLVMExecutionEngineRef *OutJIT,
156 LLVMModuleProviderRef MP,
157 unsigned OptLevel,
158 char **OutError) {
159 /* The module provider is now actually a module. */
160 return LLVMCreateJITCompilerForModule(OutJIT,
161 reinterpret_cast<LLVMModuleRef>(MP),
162 OptLevel, OutError);
163 }
164
165
LLVMDisposeExecutionEngine(LLVMExecutionEngineRef EE)166 void LLVMDisposeExecutionEngine(LLVMExecutionEngineRef EE) {
167 delete unwrap(EE);
168 }
169
LLVMRunStaticConstructors(LLVMExecutionEngineRef EE)170 void LLVMRunStaticConstructors(LLVMExecutionEngineRef EE) {
171 unwrap(EE)->runStaticConstructorsDestructors(false);
172 }
173
LLVMRunStaticDestructors(LLVMExecutionEngineRef EE)174 void LLVMRunStaticDestructors(LLVMExecutionEngineRef EE) {
175 unwrap(EE)->runStaticConstructorsDestructors(true);
176 }
177
LLVMRunFunctionAsMain(LLVMExecutionEngineRef EE,LLVMValueRef F,unsigned ArgC,const char * const * ArgV,const char * const * EnvP)178 int LLVMRunFunctionAsMain(LLVMExecutionEngineRef EE, LLVMValueRef F,
179 unsigned ArgC, const char * const *ArgV,
180 const char * const *EnvP) {
181 std::vector<std::string> ArgVec;
182 for (unsigned I = 0; I != ArgC; ++I)
183 ArgVec.push_back(ArgV[I]);
184
185 return unwrap(EE)->runFunctionAsMain(unwrap<Function>(F), ArgVec, EnvP);
186 }
187
LLVMRunFunction(LLVMExecutionEngineRef EE,LLVMValueRef F,unsigned NumArgs,LLVMGenericValueRef * Args)188 LLVMGenericValueRef LLVMRunFunction(LLVMExecutionEngineRef EE, LLVMValueRef F,
189 unsigned NumArgs,
190 LLVMGenericValueRef *Args) {
191 std::vector<GenericValue> ArgVec;
192 ArgVec.reserve(NumArgs);
193 for (unsigned I = 0; I != NumArgs; ++I)
194 ArgVec.push_back(*unwrap(Args[I]));
195
196 GenericValue *Result = new GenericValue();
197 *Result = unwrap(EE)->runFunction(unwrap<Function>(F), ArgVec);
198 return wrap(Result);
199 }
200
LLVMFreeMachineCodeForFunction(LLVMExecutionEngineRef EE,LLVMValueRef F)201 void LLVMFreeMachineCodeForFunction(LLVMExecutionEngineRef EE, LLVMValueRef F) {
202 unwrap(EE)->freeMachineCodeForFunction(unwrap<Function>(F));
203 }
204
LLVMAddModule(LLVMExecutionEngineRef EE,LLVMModuleRef M)205 void LLVMAddModule(LLVMExecutionEngineRef EE, LLVMModuleRef M){
206 unwrap(EE)->addModule(unwrap(M));
207 }
208
LLVMAddModuleProvider(LLVMExecutionEngineRef EE,LLVMModuleProviderRef MP)209 void LLVMAddModuleProvider(LLVMExecutionEngineRef EE, LLVMModuleProviderRef MP){
210 /* The module provider is now actually a module. */
211 LLVMAddModule(EE, reinterpret_cast<LLVMModuleRef>(MP));
212 }
213
LLVMRemoveModule(LLVMExecutionEngineRef EE,LLVMModuleRef M,LLVMModuleRef * OutMod,char ** OutError)214 LLVMBool LLVMRemoveModule(LLVMExecutionEngineRef EE, LLVMModuleRef M,
215 LLVMModuleRef *OutMod, char **OutError) {
216 Module *Mod = unwrap(M);
217 unwrap(EE)->removeModule(Mod);
218 *OutMod = wrap(Mod);
219 return 0;
220 }
221
LLVMRemoveModuleProvider(LLVMExecutionEngineRef EE,LLVMModuleProviderRef MP,LLVMModuleRef * OutMod,char ** OutError)222 LLVMBool LLVMRemoveModuleProvider(LLVMExecutionEngineRef EE,
223 LLVMModuleProviderRef MP,
224 LLVMModuleRef *OutMod, char **OutError) {
225 /* The module provider is now actually a module. */
226 return LLVMRemoveModule(EE, reinterpret_cast<LLVMModuleRef>(MP), OutMod,
227 OutError);
228 }
229
LLVMFindFunction(LLVMExecutionEngineRef EE,const char * Name,LLVMValueRef * OutFn)230 LLVMBool LLVMFindFunction(LLVMExecutionEngineRef EE, const char *Name,
231 LLVMValueRef *OutFn) {
232 if (Function *F = unwrap(EE)->FindFunctionNamed(Name)) {
233 *OutFn = wrap(F);
234 return 0;
235 }
236 return 1;
237 }
238
LLVMRecompileAndRelinkFunction(LLVMExecutionEngineRef EE,LLVMValueRef Fn)239 void *LLVMRecompileAndRelinkFunction(LLVMExecutionEngineRef EE, LLVMValueRef Fn) {
240 return unwrap(EE)->recompileAndRelinkFunction(unwrap<Function>(Fn));
241 }
242
LLVMGetExecutionEngineTargetData(LLVMExecutionEngineRef EE)243 LLVMTargetDataRef LLVMGetExecutionEngineTargetData(LLVMExecutionEngineRef EE) {
244 return wrap(unwrap(EE)->getTargetData());
245 }
246
LLVMAddGlobalMapping(LLVMExecutionEngineRef EE,LLVMValueRef Global,void * Addr)247 void LLVMAddGlobalMapping(LLVMExecutionEngineRef EE, LLVMValueRef Global,
248 void* Addr) {
249 unwrap(EE)->addGlobalMapping(unwrap<GlobalValue>(Global), Addr);
250 }
251
LLVMGetPointerToGlobal(LLVMExecutionEngineRef EE,LLVMValueRef Global)252 void *LLVMGetPointerToGlobal(LLVMExecutionEngineRef EE, LLVMValueRef Global) {
253 return unwrap(EE)->getPointerToGlobal(unwrap<GlobalValue>(Global));
254 }
255