diff options
author | Lang Hames <lhames@gmail.com> | 2015-10-28 01:03:09 +0000 |
---|---|---|
committer | Lang Hames <lhames@gmail.com> | 2015-10-28 01:03:09 +0000 |
commit | f6bd01097a04635343c97818d157450a8df863b9 (patch) | |
tree | b543a8e52c41cc91fd4ce64b7c2ba2c0f0336937 /llvm/lib/ExecutionEngine/Orc/OrcCBindings.cpp | |
parent | ec6151066f73d1e27a059fc0924e031481903279 (diff) | |
download | bcm5719-llvm-f6bd01097a04635343c97818d157450a8df863b9.tar.gz bcm5719-llvm-f6bd01097a04635343c97818d157450a8df863b9.zip |
[Orc] Revert the C bindngs commit, r251472, while I debug some builder failures.
llvm-svn: 251473
Diffstat (limited to 'llvm/lib/ExecutionEngine/Orc/OrcCBindings.cpp')
-rw-r--r-- | llvm/lib/ExecutionEngine/Orc/OrcCBindings.cpp | 80 |
1 files changed, 0 insertions, 80 deletions
diff --git a/llvm/lib/ExecutionEngine/Orc/OrcCBindings.cpp b/llvm/lib/ExecutionEngine/Orc/OrcCBindings.cpp deleted file mode 100644 index 9643f466360..00000000000 --- a/llvm/lib/ExecutionEngine/Orc/OrcCBindings.cpp +++ /dev/null @@ -1,80 +0,0 @@ -//===----------- OrcCBindings.cpp - C bindings for the Orc APIs -----------===// -// -// The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// - -#include "OrcCBindingsStack.h" -#include "llvm-c/OrcBindings.h" - -using namespace llvm; - -DEFINE_SIMPLE_CONVERSION_FUNCTIONS(OrcCBindingsStack, LLVMOrcJITStackRef); -DEFINE_SIMPLE_CONVERSION_FUNCTIONS(TargetMachine, LLVMTargetMachineRef); - -LLVMOrcJITStackRef LLVMOrcCreateInstance(LLVMTargetMachineRef TM, - LLVMContextRef Context) { - TargetMachine *TM2(unwrap(TM)); - LLVMContext &Ctx = *unwrap(Context); - - Triple T(TM2->getTargetTriple()); - - auto CallbackMgrBuilder = OrcCBindingsStack::createCallbackManagerBuilder(T); - auto IndirectStubsMgrBuilder = - OrcCBindingsStack::createIndirectStubsMgrBuilder(T); - - OrcCBindingsStack *JITStack = - new OrcCBindingsStack(*TM2, Ctx, CallbackMgrBuilder, - IndirectStubsMgrBuilder); - - return wrap(JITStack); -} - -void LLVMOrcGetMangledSymbol(LLVMOrcJITStackRef JITStack, char **MangledName, - const char *SymbolName) { - OrcCBindingsStack &J = *unwrap(JITStack); - std::string Mangled = J.mangle(SymbolName); - *MangledName = new char[Mangled.size() + 1]; - strcpy(*MangledName, Mangled.c_str()); -} - -void LLVMOrcDisposeMangledSymbol(char *MangledName) { - delete[] MangledName; -} - -LLVMOrcModuleHandle -LLVMOrcAddEagerlyCompiledIR(LLVMOrcJITStackRef JITStack, LLVMModuleRef Mod, - LLVMOrcSymbolResolverFn SymbolResolver, - void *SymbolResolverCtx) { - OrcCBindingsStack &J = *unwrap(JITStack); - Module *M(unwrap(Mod)); - return J.addIRModuleEager(M, SymbolResolver, SymbolResolverCtx); -} - -LLVMOrcModuleHandle -LLVMOrcAddLazilyCompiledIR(LLVMOrcJITStackRef JITStack, LLVMModuleRef Mod, - LLVMOrcSymbolResolverFn SymbolResolver, - void *SymbolResolverCtx) { - OrcCBindingsStack &J = *unwrap(JITStack); - Module *M(unwrap(Mod)); - return J.addIRModuleLazy(M, SymbolResolver, SymbolResolverCtx); -} - -void LLVMOrcRemoveModule(LLVMOrcJITStackRef JITStack, LLVMOrcModuleHandle H) { - OrcCBindingsStack &J = *unwrap(JITStack); - J.removeModule(H); -} - -LLVMOrcTargetAddress LLVMOrcGetSymbolAddress(LLVMOrcJITStackRef JITStack, - const char *SymbolName) { - OrcCBindingsStack &J = *unwrap(JITStack); - auto Sym = J.findSymbol(SymbolName, true); - return Sym.getAddress(); -} - -void LLVMOrcDisposeInstance(LLVMOrcJITStackRef JITStack) { - delete unwrap(JITStack); -} |