diff options
author | Jun Zhang <jun@junz.org> | 2022-06-09 23:12:21 +0800 |
---|---|---|
committer | Jun Zhang <jun@junz.org> | 2022-06-09 23:12:21 +0800 |
commit | b8f9459715815fa055b3e1c5f970c616797dfcfb (patch) | |
tree | 938c8aef91feecd03b6c90888a7a9c44015e34a9 /clang/lib/CodeGen/ModuleBuilder.cpp | |
parent | 6555558a80589d1c5a1154b92cc3af9495f8f86c (diff) | |
download | llvm-b8f9459715815fa055b3e1c5f970c616797dfcfb.zip llvm-b8f9459715815fa055b3e1c5f970c616797dfcfb.tar.gz llvm-b8f9459715815fa055b3e1c5f970c616797dfcfb.tar.bz2 |
[CodeGen] Keep track info of lazy-emitted symbols in ModuleBuilder
The intent of this patch is to selectively carry some states over to
the Builder so we won't lose the information of the previous symbols.
This used to be several downstream patches of Cling, it aims to fix
errors in Clang Interpreter when trying to use inline functions.
Before this patch:
clang-repl> inline int foo() { return 42;}
clang-repl> int x = foo();
JIT session error: Symbols not found: [ _Z3foov ]
error: Failed to materialize symbols:
{ (main, { x, $.incr_module_1.__inits.0, __orc_init_func.incr_module_1 }) }
Co-authored-by: Axel Naumann <Axel.Naumann@cern.ch>
Signed-off-by: Jun Zhang <jun@junz.org>
Differential Revision: https://reviews.llvm.org/D126781
Diffstat (limited to 'clang/lib/CodeGen/ModuleBuilder.cpp')
-rw-r--r-- | clang/lib/CodeGen/ModuleBuilder.cpp | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/clang/lib/CodeGen/ModuleBuilder.cpp b/clang/lib/CodeGen/ModuleBuilder.cpp index 50b7fd8..8e97a29 100644 --- a/clang/lib/CodeGen/ModuleBuilder.cpp +++ b/clang/lib/CodeGen/ModuleBuilder.cpp @@ -134,7 +134,14 @@ namespace { llvm::LLVMContext &C) { assert(!M && "Replacing existing Module?"); M.reset(new llvm::Module(ExpandModuleName(ModuleName, CodeGenOpts), C)); + + std::unique_ptr<CodeGenModule> OldBuilder = std::move(Builder); + Initialize(*Ctx); + + if (OldBuilder) + OldBuilder->moveLazyEmissionStates(Builder.get()); + return M.get(); } |