2015-10-28 10:40:04 +08:00
|
|
|
/*===----------- llvm-c/OrcBindings.h - Orc Lib C Iface ---------*- C++ -*-===*\
|
|
|
|
|* *|
|
|
|
|
|* The LLVM Compiler Infrastructure *|
|
|
|
|
|* *|
|
|
|
|
|* This file is distributed under the University of Illinois Open Source *|
|
|
|
|
|* License. See LICENSE.TXT for details. *|
|
|
|
|
|* *|
|
|
|
|
|*===----------------------------------------------------------------------===*|
|
|
|
|
|* *|
|
|
|
|
|* This header declares the C interface to libLLVMOrcJIT.a, which implements *|
|
|
|
|
|* JIT compilation of LLVM IR. *|
|
|
|
|
|* *|
|
|
|
|
|* Many exotic languages can interoperate with C code but have a harder time *|
|
|
|
|
|* with C++ due to name mangling. So in addition to C, this interface enables *|
|
|
|
|
|* tools written in such languages. *|
|
|
|
|
|* *|
|
|
|
|
|* Note: This interface is experimental. It is *NOT* stable, and may be *|
|
|
|
|
|* changed without warning. *|
|
|
|
|
|* *|
|
|
|
|
\*===----------------------------------------------------------------------===*/
|
|
|
|
|
|
|
|
#ifndef LLVM_C_ORCBINDINGS_H
|
|
|
|
#define LLVM_C_ORCBINDINGS_H
|
|
|
|
|
|
|
|
#include "llvm-c/Object.h"
|
|
|
|
#include "llvm-c/TargetMachine.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2017-06-24 07:25:28 +08:00
|
|
|
typedef struct LLVMOpaqueSharedModule *LLVMSharedModuleRef;
|
|
|
|
typedef struct LLVMOpaqueSharedObjectBuffer *LLVMSharedObjectBufferRef;
|
2015-10-28 10:40:04 +08:00
|
|
|
typedef struct LLVMOrcOpaqueJITStack *LLVMOrcJITStackRef;
|
|
|
|
typedef uint32_t LLVMOrcModuleHandle;
|
|
|
|
typedef uint64_t LLVMOrcTargetAddress;
|
2016-04-26 05:21:20 +08:00
|
|
|
typedef uint64_t (*LLVMOrcSymbolResolverFn)(const char *Name, void *LookupCtx);
|
2015-10-30 11:20:21 +08:00
|
|
|
typedef uint64_t (*LLVMOrcLazyCompileCallbackFn)(LLVMOrcJITStackRef JITStack,
|
|
|
|
void *CallbackCtx);
|
2015-10-28 10:40:04 +08:00
|
|
|
|
2016-04-26 05:21:20 +08:00
|
|
|
typedef enum { LLVMOrcErrSuccess = 0, LLVMOrcErrGeneric } LLVMOrcErrorCode;
|
2016-04-26 03:56:45 +08:00
|
|
|
|
2017-06-24 07:25:28 +08:00
|
|
|
/**
|
|
|
|
* Turn an LLVMModuleRef into an LLVMSharedModuleRef.
|
|
|
|
*
|
|
|
|
* The JIT uses shared ownership for LLVM modules, since it is generally
|
|
|
|
* difficult to know when the JIT will be finished with a module (and the JIT
|
|
|
|
* has no way of knowing when a user may be finished with one).
|
|
|
|
*
|
|
|
|
* Calling this method with an LLVMModuleRef creates a shared-pointer to the
|
|
|
|
* module, and returns a reference to this shared pointer.
|
|
|
|
*
|
|
|
|
* The shared module should be disposed when finished with by calling
|
|
|
|
* LLVMOrcDisposeSharedModule (not LLVMDisposeModule). The Module will be
|
|
|
|
* deleted when the last shared pointer owner relinquishes it.
|
|
|
|
*/
|
|
|
|
|
|
|
|
LLVMSharedModuleRef LLVMOrcMakeSharedModule(LLVMModuleRef Mod);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Dispose of a shared module.
|
|
|
|
*
|
|
|
|
* The module should not be accessed after this call. The module will be
|
|
|
|
* deleted once all clients (including the JIT itself) have released their
|
|
|
|
* shared pointers.
|
|
|
|
*/
|
|
|
|
|
|
|
|
void LLVMOrcDisposeSharedModuleRef(LLVMSharedModuleRef SharedMod);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get an LLVMSharedObjectBufferRef from an LLVMMemoryBufferRef.
|
|
|
|
*/
|
|
|
|
LLVMSharedObjectBufferRef
|
|
|
|
LLVMOrcMakeSharedObjectBuffer(LLVMMemoryBufferRef ObjBuffer);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Dispose of a shared object buffer.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
LLVMOrcDisposeSharedObjectBufferRef(LLVMSharedObjectBufferRef SharedObjBuffer);
|
|
|
|
|
2015-10-28 10:40:04 +08:00
|
|
|
/**
|
|
|
|
* Create an ORC JIT stack.
|
|
|
|
*
|
|
|
|
* The client owns the resulting stack, and must call OrcDisposeInstance(...)
|
|
|
|
* to destroy it and free its memory. The JIT stack will take ownership of the
|
|
|
|
* TargetMachine, which will be destroyed when the stack is destroyed. The
|
|
|
|
* client should not attempt to dispose of the Target Machine, or it will result
|
|
|
|
* in a double-free.
|
|
|
|
*/
|
2015-11-04 00:40:37 +08:00
|
|
|
LLVMOrcJITStackRef LLVMOrcCreateInstance(LLVMTargetMachineRef TM);
|
2015-10-28 10:40:04 +08:00
|
|
|
|
2016-04-26 03:56:45 +08:00
|
|
|
/**
|
|
|
|
* Get the error message for the most recent error (if any).
|
|
|
|
*
|
|
|
|
* This message is owned by the ORC JIT Stack and will be freed when the stack
|
|
|
|
* is disposed of by LLVMOrcDisposeInstance.
|
|
|
|
*/
|
|
|
|
const char *LLVMOrcGetErrorMsg(LLVMOrcJITStackRef JITStack);
|
|
|
|
|
2015-10-28 10:40:04 +08:00
|
|
|
/**
|
|
|
|
* Mangle the given symbol.
|
|
|
|
* Memory will be allocated for MangledSymbol to hold the result. The client
|
|
|
|
*/
|
|
|
|
void LLVMOrcGetMangledSymbol(LLVMOrcJITStackRef JITStack, char **MangledSymbol,
|
|
|
|
const char *Symbol);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Dispose of a mangled symbol.
|
|
|
|
*/
|
|
|
|
void LLVMOrcDisposeMangledSymbol(char *MangledSymbol);
|
|
|
|
|
2015-10-30 11:20:21 +08:00
|
|
|
/**
|
|
|
|
* Create a lazy compile callback.
|
|
|
|
*/
|
2017-07-07 10:59:13 +08:00
|
|
|
LLVMOrcErrorCode
|
2015-10-30 11:20:21 +08:00
|
|
|
LLVMOrcCreateLazyCompileCallback(LLVMOrcJITStackRef JITStack,
|
2017-07-07 10:59:13 +08:00
|
|
|
LLVMOrcTargetAddress *RetAddr,
|
2015-10-30 11:20:21 +08:00
|
|
|
LLVMOrcLazyCompileCallbackFn Callback,
|
|
|
|
void *CallbackCtx);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a named indirect call stub.
|
|
|
|
*/
|
2016-04-26 03:56:45 +08:00
|
|
|
LLVMOrcErrorCode LLVMOrcCreateIndirectStub(LLVMOrcJITStackRef JITStack,
|
|
|
|
const char *StubName,
|
|
|
|
LLVMOrcTargetAddress InitAddr);
|
2015-10-30 11:20:21 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the pointer for the given indirect stub.
|
|
|
|
*/
|
2016-04-26 03:56:45 +08:00
|
|
|
LLVMOrcErrorCode LLVMOrcSetIndirectStubPointer(LLVMOrcJITStackRef JITStack,
|
|
|
|
const char *StubName,
|
|
|
|
LLVMOrcTargetAddress NewAddr);
|
2015-10-30 11:20:21 +08:00
|
|
|
|
2015-10-28 10:40:04 +08:00
|
|
|
/**
|
|
|
|
* Add module to be eagerly compiled.
|
|
|
|
*/
|
2017-07-07 10:59:13 +08:00
|
|
|
LLVMOrcErrorCode
|
2017-06-24 07:25:28 +08:00
|
|
|
LLVMOrcAddEagerlyCompiledIR(LLVMOrcJITStackRef JITStack,
|
2017-07-07 10:59:13 +08:00
|
|
|
LLVMOrcModuleHandle *RetHandle,
|
2017-06-24 07:25:28 +08:00
|
|
|
LLVMSharedModuleRef Mod,
|
2015-10-28 10:40:04 +08:00
|
|
|
LLVMOrcSymbolResolverFn SymbolResolver,
|
|
|
|
void *SymbolResolverCtx);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add module to be lazily compiled one function at a time.
|
|
|
|
*/
|
2017-07-07 10:59:13 +08:00
|
|
|
LLVMOrcErrorCode
|
2017-06-24 07:25:28 +08:00
|
|
|
LLVMOrcAddLazilyCompiledIR(LLVMOrcJITStackRef JITStack,
|
2017-07-07 10:59:13 +08:00
|
|
|
LLVMOrcModuleHandle *RetHandle,
|
2017-06-24 07:25:28 +08:00
|
|
|
LLVMSharedModuleRef Mod,
|
2015-10-28 10:40:04 +08:00
|
|
|
LLVMOrcSymbolResolverFn SymbolResolver,
|
|
|
|
void *SymbolResolverCtx);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add an object file.
|
|
|
|
*/
|
2017-07-07 10:59:13 +08:00
|
|
|
LLVMOrcErrorCode LLVMOrcAddObjectFile(LLVMOrcJITStackRef JITStack,
|
|
|
|
LLVMOrcModuleHandle *RetHandle,
|
|
|
|
LLVMSharedObjectBufferRef Obj,
|
|
|
|
LLVMOrcSymbolResolverFn SymbolResolver,
|
|
|
|
void *SymbolResolverCtx);
|
2015-10-28 10:40:04 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove a module set from the JIT.
|
|
|
|
*
|
|
|
|
* This works for all modules that can be added via OrcAdd*, including object
|
|
|
|
* files.
|
|
|
|
*/
|
2017-07-07 10:59:13 +08:00
|
|
|
LLVMOrcErrorCode LLVMOrcRemoveModule(LLVMOrcJITStackRef JITStack,
|
|
|
|
LLVMOrcModuleHandle H);
|
2015-10-28 10:40:04 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get symbol address from JIT instance.
|
|
|
|
*/
|
2017-07-07 10:59:13 +08:00
|
|
|
LLVMOrcErrorCode LLVMOrcGetSymbolAddress(LLVMOrcJITStackRef JITStack,
|
|
|
|
LLVMOrcTargetAddress *RetAddr,
|
|
|
|
const char *SymbolName);
|
2015-10-28 10:40:04 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Dispose of an ORC JIT stack.
|
|
|
|
*/
|
2017-07-07 10:59:13 +08:00
|
|
|
LLVMOrcErrorCode LLVMOrcDisposeInstance(LLVMOrcJITStackRef JITStack);
|
2015-10-28 10:40:04 +08:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif /* extern "C" */
|
|
|
|
|
|
|
|
#endif /* LLVM_C_ORCBINDINGS_H */
|