1662c5544SLang Hames //===---------------- EPCDynamicLibrarySearchGenerator.cpp ----------------===//
2662c5544SLang Hames //
3662c5544SLang Hames // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4662c5544SLang Hames // See https://llvm.org/LICENSE.txt for license information.
5662c5544SLang Hames // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6662c5544SLang Hames //
7662c5544SLang Hames //===----------------------------------------------------------------------===//
8662c5544SLang Hames
9662c5544SLang Hames #include "llvm/ExecutionEngine/Orc/EPCDynamicLibrarySearchGenerator.h"
10662c5544SLang Hames
11662c5544SLang Hames namespace llvm {
12662c5544SLang Hames namespace orc {
13662c5544SLang Hames
14662c5544SLang Hames Expected<std::unique_ptr<EPCDynamicLibrarySearchGenerator>>
Load(ExecutionSession & ES,const char * LibraryPath,SymbolPredicate Allow)15*2487db1fSLang Hames EPCDynamicLibrarySearchGenerator::Load(ExecutionSession &ES,
16662c5544SLang Hames const char *LibraryPath,
17662c5544SLang Hames SymbolPredicate Allow) {
18*2487db1fSLang Hames auto Handle = ES.getExecutorProcessControl().loadDylib(LibraryPath);
19662c5544SLang Hames if (!Handle)
20662c5544SLang Hames return Handle.takeError();
21662c5544SLang Hames
22*2487db1fSLang Hames return std::make_unique<EPCDynamicLibrarySearchGenerator>(ES, *Handle,
23662c5544SLang Hames std::move(Allow));
24662c5544SLang Hames }
25662c5544SLang Hames
tryToGenerate(LookupState & LS,LookupKind K,JITDylib & JD,JITDylibLookupFlags JDLookupFlags,const SymbolLookupSet & Symbols)26662c5544SLang Hames Error EPCDynamicLibrarySearchGenerator::tryToGenerate(
27662c5544SLang Hames LookupState &LS, LookupKind K, JITDylib &JD,
28662c5544SLang Hames JITDylibLookupFlags JDLookupFlags, const SymbolLookupSet &Symbols) {
29662c5544SLang Hames
30662c5544SLang Hames if (Symbols.empty())
31662c5544SLang Hames return Error::success();
32662c5544SLang Hames
33662c5544SLang Hames SymbolLookupSet LookupSymbols;
34662c5544SLang Hames
35662c5544SLang Hames for (auto &KV : Symbols) {
36662c5544SLang Hames // Skip symbols that don't match the filter.
37662c5544SLang Hames if (Allow && !Allow(KV.first))
38662c5544SLang Hames continue;
39662c5544SLang Hames LookupSymbols.add(KV.first, SymbolLookupFlags::WeaklyReferencedSymbol);
40662c5544SLang Hames }
41662c5544SLang Hames
42662c5544SLang Hames SymbolMap NewSymbols;
43662c5544SLang Hames
44662c5544SLang Hames ExecutorProcessControl::LookupRequest Request(H, LookupSymbols);
45662c5544SLang Hames auto Result = EPC.lookupSymbols(Request);
46662c5544SLang Hames if (!Result)
47662c5544SLang Hames return Result.takeError();
48662c5544SLang Hames
49662c5544SLang Hames assert(Result->size() == 1 && "Results for more than one library returned");
50662c5544SLang Hames assert(Result->front().size() == LookupSymbols.size() &&
51662c5544SLang Hames "Result has incorrect number of elements");
52662c5544SLang Hames
53662c5544SLang Hames auto ResultI = Result->front().begin();
54662c5544SLang Hames for (auto &KV : LookupSymbols) {
55662c5544SLang Hames if (*ResultI)
56662c5544SLang Hames NewSymbols[KV.first] =
57662c5544SLang Hames JITEvaluatedSymbol(*ResultI, JITSymbolFlags::Exported);
58662c5544SLang Hames ++ResultI;
59662c5544SLang Hames }
60662c5544SLang Hames
61662c5544SLang Hames // If there were no resolved symbols bail out.
62662c5544SLang Hames if (NewSymbols.empty())
63662c5544SLang Hames return Error::success();
64662c5544SLang Hames
65662c5544SLang Hames // Define resolved symbols.
66662c5544SLang Hames return JD.define(absoluteSymbols(std::move(NewSymbols)));
67662c5544SLang Hames }
68662c5544SLang Hames
69662c5544SLang Hames } // end namespace orc
70662c5544SLang Hames } // end namespace llvm
71