xref: /openbsd-src/gnu/llvm/llvm/lib/ExecutionEngine/Orc/EPCDynamicLibrarySearchGenerator.cpp (revision d415bd752c734aee168c4ee86ff32e8cc249eb16)
173471bf0Spatrick //===---------------- EPCDynamicLibrarySearchGenerator.cpp ----------------===//
273471bf0Spatrick //
373471bf0Spatrick // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
473471bf0Spatrick // See https://llvm.org/LICENSE.txt for license information.
573471bf0Spatrick // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
673471bf0Spatrick //
773471bf0Spatrick //===----------------------------------------------------------------------===//
873471bf0Spatrick 
973471bf0Spatrick #include "llvm/ExecutionEngine/Orc/EPCDynamicLibrarySearchGenerator.h"
1073471bf0Spatrick 
1173471bf0Spatrick namespace llvm {
1273471bf0Spatrick namespace orc {
1373471bf0Spatrick 
1473471bf0Spatrick Expected<std::unique_ptr<EPCDynamicLibrarySearchGenerator>>
Load(ExecutionSession & ES,const char * LibraryPath,SymbolPredicate Allow)1573471bf0Spatrick EPCDynamicLibrarySearchGenerator::Load(ExecutionSession &ES,
1673471bf0Spatrick                                        const char *LibraryPath,
1773471bf0Spatrick                                        SymbolPredicate Allow) {
1873471bf0Spatrick   auto Handle = ES.getExecutorProcessControl().loadDylib(LibraryPath);
1973471bf0Spatrick   if (!Handle)
2073471bf0Spatrick     return Handle.takeError();
2173471bf0Spatrick 
2273471bf0Spatrick   return std::make_unique<EPCDynamicLibrarySearchGenerator>(ES, *Handle,
2373471bf0Spatrick                                                             std::move(Allow));
2473471bf0Spatrick }
2573471bf0Spatrick 
tryToGenerate(LookupState & LS,LookupKind K,JITDylib & JD,JITDylibLookupFlags JDLookupFlags,const SymbolLookupSet & Symbols)2673471bf0Spatrick Error EPCDynamicLibrarySearchGenerator::tryToGenerate(
2773471bf0Spatrick     LookupState &LS, LookupKind K, JITDylib &JD,
2873471bf0Spatrick     JITDylibLookupFlags JDLookupFlags, const SymbolLookupSet &Symbols) {
2973471bf0Spatrick 
3073471bf0Spatrick   if (Symbols.empty())
3173471bf0Spatrick     return Error::success();
3273471bf0Spatrick 
3373471bf0Spatrick   SymbolLookupSet LookupSymbols;
3473471bf0Spatrick 
3573471bf0Spatrick   for (auto &KV : Symbols) {
3673471bf0Spatrick     // Skip symbols that don't match the filter.
3773471bf0Spatrick     if (Allow && !Allow(KV.first))
3873471bf0Spatrick       continue;
3973471bf0Spatrick     LookupSymbols.add(KV.first, SymbolLookupFlags::WeaklyReferencedSymbol);
4073471bf0Spatrick   }
4173471bf0Spatrick 
4273471bf0Spatrick   SymbolMap NewSymbols;
4373471bf0Spatrick 
4473471bf0Spatrick   ExecutorProcessControl::LookupRequest Request(H, LookupSymbols);
4573471bf0Spatrick   auto Result = EPC.lookupSymbols(Request);
4673471bf0Spatrick   if (!Result)
4773471bf0Spatrick     return Result.takeError();
4873471bf0Spatrick 
4973471bf0Spatrick   assert(Result->size() == 1 && "Results for more than one library returned");
5073471bf0Spatrick   assert(Result->front().size() == LookupSymbols.size() &&
5173471bf0Spatrick          "Result has incorrect number of elements");
5273471bf0Spatrick 
5373471bf0Spatrick   auto ResultI = Result->front().begin();
5473471bf0Spatrick   for (auto &KV : LookupSymbols) {
5573471bf0Spatrick     if (*ResultI)
5673471bf0Spatrick       NewSymbols[KV.first] =
57*d415bd75Srobert           JITEvaluatedSymbol(ResultI->getValue(), JITSymbolFlags::Exported);
5873471bf0Spatrick     ++ResultI;
5973471bf0Spatrick   }
6073471bf0Spatrick 
6173471bf0Spatrick   // If there were no resolved symbols bail out.
6273471bf0Spatrick   if (NewSymbols.empty())
6373471bf0Spatrick     return Error::success();
6473471bf0Spatrick 
6573471bf0Spatrick   // Define resolved symbols.
6673471bf0Spatrick   return JD.define(absoluteSymbols(std::move(NewSymbols)));
6773471bf0Spatrick }
6873471bf0Spatrick 
6973471bf0Spatrick } // end namespace orc
7073471bf0Spatrick } // end namespace llvm
71