From 29a2b14be261ad9d207c3fba32109269fe92a069 Mon Sep 17 00:00:00 2001 From: Lang Hames Date: Fri, 3 Apr 2020 12:25:32 -0700 Subject: [PATCH] [ORC] Improve documention of memory ownership in the new Orc C bindings. --- llvm/include/llvm-c/Orc.h | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/llvm/include/llvm-c/Orc.h b/llvm/include/llvm-c/Orc.h index 2a060a603774..935e5d123f68 100644 --- a/llvm/include/llvm-c/Orc.h +++ b/llvm/include/llvm-c/Orc.h @@ -36,6 +36,11 @@ typedef uint64_t LLVMOrcJITTargetAddress; /** * Create a ThreadSafeContext containing a new LLVMContext. + * + * Ownership of the underlying ThreadSafeContext data is shared: Clients + * can and should dispose of their ThreadSafeContext as soon as they no longer + * need to refer to it directly. Other references (e.g. from ThreadSafeModules + * will keep the data alive as long as it is needed. */ LLVMOrcThreadSafeContextRef LLVMOrcCreateNewThreadSafeContext(void); @@ -54,6 +59,11 @@ void LLVMOrcDisposeThreadSafeContext(LLVMOrcThreadSafeContextRef TSCtx); * Create a ThreadSafeModule wrapper around the given LLVM module. This takes * ownership of the M argument which should not be disposed of or referenced * after this function returns. + * + * Ownership of the ThreadSafeModule is unique: If it is transferred to the JIT + * (e.g. by LLVMOrcLLJITAddLLVMIRModule), in which case the client is no longer + * responsible for it. If it is not transferred to the JIT then the client + * should call LLVMOrcDisposeThreadSafeModule to dispose of it. */ LLVMOrcThreadSafeModuleRef LLVMOrcCreateNewThreadSafeModule(LLVMModuleRef M, @@ -66,6 +76,12 @@ void LLVMOrcDisposeThreadSafeModule(LLVMOrcThreadSafeModuleRef TSM); /** * Create an LLJIT instance using all default values. + * + * The LLJIT instance is uniquely owned by the client and automatically manages + * the memory of all JIT'd code and all modules that are transferred to it + * (e.g. via LLVMOrcLLJITAddLLVMIRModule). Disposing of the LLJIT instance will + * free all memory managed by the JIT, including JIT'd code and not-yet + * compiled modules. */ LLVMErrorRef LLVMOrcCreateDefaultLLJIT(LLVMOrcLLJITRef *Result);