1 //===--------- LLJIT.cpp - An ORC-based JIT for compiling LLVM IR ---------===// 2 // 3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4 // See https://llvm.org/LICENSE.txt for license information. 5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6 // 7 //===----------------------------------------------------------------------===// 8 9 #include "llvm/ExecutionEngine/Orc/LLJIT.h" 10 #include "llvm/ExecutionEngine/JITLink/EHFrameSupport.h" 11 #include "llvm/ExecutionEngine/JITLink/JITLinkMemoryManager.h" 12 #include "llvm/ExecutionEngine/Orc/MachOPlatform.h" 13 #include "llvm/ExecutionEngine/Orc/ObjectLinkingLayer.h" 14 #include "llvm/ExecutionEngine/Orc/OrcError.h" 15 #include "llvm/ExecutionEngine/Orc/RTDyldObjectLinkingLayer.h" 16 #include "llvm/ExecutionEngine/SectionMemoryManager.h" 17 #include "llvm/IR/GlobalVariable.h" 18 #include "llvm/IR/IRBuilder.h" 19 #include "llvm/IR/Mangler.h" 20 #include "llvm/IR/Module.h" 21 #include "llvm/Support/DynamicLibrary.h" 22 23 #include <map> 24 25 #define DEBUG_TYPE "orc" 26 27 using namespace llvm; 28 using namespace llvm::orc; 29 30 namespace { 31 32 /// Add a reference to the __dso_handle global to the given module. 33 /// Returns a reference to the __dso_handle IR decl. 34 GlobalVariable *addDSOHandleDecl(Module &M) { 35 auto DSOHandleTy = StructType::create(M.getContext(), "lljit.dso_handle"); 36 return new GlobalVariable(M, DSOHandleTy, true, GlobalValue::ExternalLinkage, 37 nullptr, "__dso_handle"); 38 } 39 40 /// Adds helper function decls and wrapper functions that call the helper with 41 /// some additional prefix arguments. 42 /// 43 /// E.g. For wrapper "foo" with type i8(i8, i64), helper "bar", and prefix 44 /// args i32 4 and i16 12345, this function will add: 45 /// 46 /// declare i8 @bar(i32, i16, i8, i64) 47 /// 48 /// define i8 @foo(i8, i64) { 49 /// entry: 50 /// %2 = call i8 @bar(i32 4, i16 12345, i8 %0, i64 %1) 51 /// ret i8 %2 52 /// } 53 /// 54 Function *addHelperAndWrapper(Module &M, StringRef WrapperName, 55 FunctionType *WrapperFnType, 56 GlobalValue::VisibilityTypes WrapperVisibility, 57 StringRef HelperName, 58 ArrayRef<Value *> HelperPrefixArgs) { 59 std::vector<Type *> HelperArgTypes; 60 for (auto *Arg : HelperPrefixArgs) 61 HelperArgTypes.push_back(Arg->getType()); 62 for (auto *T : WrapperFnType->params()) 63 HelperArgTypes.push_back(T); 64 auto *HelperFnType = 65 FunctionType::get(WrapperFnType->getReturnType(), HelperArgTypes, false); 66 auto *HelperFn = Function::Create(HelperFnType, GlobalValue::ExternalLinkage, 67 HelperName, M); 68 69 auto *WrapperFn = Function::Create( 70 WrapperFnType, GlobalValue::ExternalLinkage, WrapperName, M); 71 WrapperFn->setVisibility(WrapperVisibility); 72 73 auto *EntryBlock = BasicBlock::Create(M.getContext(), "entry", WrapperFn); 74 IRBuilder<> IB(EntryBlock); 75 76 std::vector<Value *> HelperArgs; 77 for (auto *Arg : HelperPrefixArgs) 78 HelperArgs.push_back(Arg); 79 for (auto &Arg : WrapperFn->args()) 80 HelperArgs.push_back(&Arg); 81 auto *HelperResult = IB.CreateCall(HelperFn, HelperArgs); 82 if (HelperFn->getReturnType()->isVoidTy()) 83 IB.CreateRetVoid(); 84 else 85 IB.CreateRet(HelperResult); 86 87 return WrapperFn; 88 } 89 90 class GenericLLVMIRPlatformSupport; 91 92 /// orc::Platform component of Generic LLVM IR Platform support. 93 /// Just forwards calls to the GenericLLVMIRPlatformSupport class below. 94 class GenericLLVMIRPlatform : public Platform { 95 public: 96 GenericLLVMIRPlatform(GenericLLVMIRPlatformSupport &S) : S(S) {} 97 Error setupJITDylib(JITDylib &JD) override; 98 Error notifyAdding(JITDylib &JD, const MaterializationUnit &MU) override; 99 Error notifyRemoving(JITDylib &JD, VModuleKey K) override { 100 // Noop -- Nothing to do (yet). 101 return Error::success(); 102 } 103 104 private: 105 GenericLLVMIRPlatformSupport &S; 106 }; 107 108 /// This transform parses llvm.global_ctors to produce a single initialization 109 /// function for the module, records the function, then deletes 110 /// llvm.global_ctors. 111 class GlobalCtorDtorScraper { 112 public: 113 114 GlobalCtorDtorScraper(GenericLLVMIRPlatformSupport &PS, 115 StringRef InitFunctionPrefix) 116 : PS(PS), InitFunctionPrefix(InitFunctionPrefix) {} 117 Expected<ThreadSafeModule> operator()(ThreadSafeModule TSM, 118 MaterializationResponsibility &R); 119 120 private: 121 GenericLLVMIRPlatformSupport &PS; 122 StringRef InitFunctionPrefix; 123 }; 124 125 /// Generic IR Platform Support 126 /// 127 /// Scrapes llvm.global_ctors and llvm.global_dtors and replaces them with 128 /// specially named 'init' and 'deinit'. Injects definitions / interposes for 129 /// some runtime API, including __cxa_atexit, dlopen, and dlclose. 130 class GenericLLVMIRPlatformSupport : public LLJIT::PlatformSupport { 131 public: 132 // GenericLLVMIRPlatform &P) : P(P) { 133 GenericLLVMIRPlatformSupport(LLJIT &J) : J(J) { 134 135 MangleAndInterner Mangle(getExecutionSession(), J.getDataLayout()); 136 InitFunctionPrefix = Mangle("__orc_init_func."); 137 138 getExecutionSession().setPlatform( 139 std::make_unique<GenericLLVMIRPlatform>(*this)); 140 141 setInitTransform(J, GlobalCtorDtorScraper(*this, *InitFunctionPrefix)); 142 143 SymbolMap StdInterposes; 144 145 StdInterposes[Mangle("__lljit.platform_support_instance")] = 146 JITEvaluatedSymbol(pointerToJITTargetAddress(this), JITSymbolFlags()); 147 StdInterposes[Mangle("__lljit.cxa_atexit_helper")] = JITEvaluatedSymbol( 148 pointerToJITTargetAddress(registerAtExitHelper), JITSymbolFlags()); 149 StdInterposes[Mangle("__lljit.run_atexits_helper")] = JITEvaluatedSymbol( 150 pointerToJITTargetAddress(runAtExitsHelper), JITSymbolFlags()); 151 152 cantFail( 153 J.getMainJITDylib().define(absoluteSymbols(std::move(StdInterposes)))); 154 cantFail(setupJITDylib(J.getMainJITDylib())); 155 cantFail(J.addIRModule(J.getMainJITDylib(), createPlatformRuntimeModule())); 156 } 157 158 ExecutionSession &getExecutionSession() { return J.getExecutionSession(); } 159 160 /// Adds a module that defines the __dso_handle global. 161 Error setupJITDylib(JITDylib &JD) { 162 auto Ctx = std::make_unique<LLVMContext>(); 163 auto M = std::make_unique<Module>("__standard_lib", *Ctx); 164 M->setDataLayout(J.getDataLayout()); 165 166 auto *Int64Ty = Type::getInt64Ty(*Ctx); 167 auto *DSOHandle = new GlobalVariable( 168 *M, Int64Ty, true, GlobalValue::ExternalLinkage, 169 ConstantInt::get(Int64Ty, reinterpret_cast<uintptr_t>(&JD)), 170 "__dso_handle"); 171 DSOHandle->setVisibility(GlobalValue::HiddenVisibility); 172 DSOHandle->setInitializer( 173 ConstantInt::get(Int64Ty, pointerToJITTargetAddress(&JD))); 174 return J.addIRModule(JD, ThreadSafeModule(std::move(M), std::move(Ctx))); 175 } 176 177 Error notifyAdding(JITDylib &JD, const MaterializationUnit &MU) { 178 if (auto &InitSym = MU.getInitializerSymbol()) 179 InitSymbols[&JD].add(InitSym, SymbolLookupFlags::WeaklyReferencedSymbol); 180 else { 181 // If there's no identified init symbol attached, but there is a symbol 182 // with the GenericIRPlatform::InitFunctionPrefix, then treat that as 183 // an init function. Add the symbol to both the InitSymbols map (which 184 // will trigger a lookup to materialize the module) and the InitFunctions 185 // map (which holds the names of the symbols to execute). 186 for (auto &KV : MU.getSymbols()) 187 if ((*KV.first).startswith(*InitFunctionPrefix)) { 188 InitSymbols[&JD].add(KV.first, 189 SymbolLookupFlags::WeaklyReferencedSymbol); 190 InitFunctions[&JD].add(KV.first); 191 } 192 } 193 return Error::success(); 194 } 195 196 Error initialize(JITDylib &JD) override { 197 LLVM_DEBUG({ 198 dbgs() << "GenericLLVMIRPlatformSupport getting initializers to run\n"; 199 }); 200 if (auto Initializers = getInitializers(JD)) { 201 LLVM_DEBUG( 202 { dbgs() << "GenericLLVMIRPlatformSupport running initializers\n"; }); 203 for (auto InitFnAddr : *Initializers) { 204 LLVM_DEBUG({ 205 dbgs() << " Running init " << formatv("{0:x16}", InitFnAddr) 206 << "...\n"; 207 }); 208 auto *InitFn = jitTargetAddressToFunction<void (*)()>(InitFnAddr); 209 InitFn(); 210 } 211 } else 212 return Initializers.takeError(); 213 return Error::success(); 214 } 215 216 Error deinitialize(JITDylib &JD) override { 217 LLVM_DEBUG({ 218 dbgs() << "GenericLLVMIRPlatformSupport getting deinitializers to run\n"; 219 }); 220 if (auto Deinitializers = getDeinitializers(JD)) { 221 LLVM_DEBUG({ 222 dbgs() << "GenericLLVMIRPlatformSupport running deinitializers\n"; 223 }); 224 for (auto DeinitFnAddr : *Deinitializers) { 225 LLVM_DEBUG({ 226 dbgs() << " Running init " << formatv("{0:x16}", DeinitFnAddr) 227 << "...\n"; 228 }); 229 auto *DeinitFn = jitTargetAddressToFunction<void (*)()>(DeinitFnAddr); 230 DeinitFn(); 231 } 232 } else 233 return Deinitializers.takeError(); 234 235 return Error::success(); 236 } 237 238 void registerInitFunc(JITDylib &JD, SymbolStringPtr InitName) { 239 getExecutionSession().runSessionLocked([&]() { 240 InitFunctions[&JD].add(InitName); 241 }); 242 } 243 244 private: 245 246 Expected<std::vector<JITTargetAddress>> getInitializers(JITDylib &JD) { 247 if (auto Err = issueInitLookups(JD)) 248 return std::move(Err); 249 250 DenseMap<JITDylib *, SymbolLookupSet> LookupSymbols; 251 std::vector<JITDylib *> DFSLinkOrder; 252 253 getExecutionSession().runSessionLocked([&]() { 254 DFSLinkOrder = getDFSLinkOrder(JD); 255 256 for (auto *NextJD : DFSLinkOrder) { 257 auto IFItr = InitFunctions.find(NextJD); 258 if (IFItr != InitFunctions.end()) { 259 LookupSymbols[NextJD] = std::move(IFItr->second); 260 InitFunctions.erase(IFItr); 261 } 262 } 263 }); 264 265 LLVM_DEBUG({ 266 dbgs() << "JITDylib init order is [ "; 267 for (auto *JD : llvm::reverse(DFSLinkOrder)) 268 dbgs() << "\"" << JD->getName() << "\" "; 269 dbgs() << "]\n"; 270 dbgs() << "Looking up init functions:\n"; 271 for (auto &KV : LookupSymbols) 272 dbgs() << " \"" << KV.first->getName() << "\": " << KV.second << "\n"; 273 }); 274 275 auto &ES = getExecutionSession(); 276 auto LookupResult = Platform::lookupInitSymbols(ES, LookupSymbols); 277 278 if (!LookupResult) 279 return LookupResult.takeError(); 280 281 std::vector<JITTargetAddress> Initializers; 282 while (!DFSLinkOrder.empty()) { 283 auto &NextJD = *DFSLinkOrder.back(); 284 DFSLinkOrder.pop_back(); 285 auto InitsItr = LookupResult->find(&NextJD); 286 if (InitsItr == LookupResult->end()) 287 continue; 288 for (auto &KV : InitsItr->second) 289 Initializers.push_back(KV.second.getAddress()); 290 } 291 292 return Initializers; 293 } 294 295 Expected<std::vector<JITTargetAddress>> getDeinitializers(JITDylib &JD) { 296 auto &ES = getExecutionSession(); 297 298 MangleAndInterner Mangle(getExecutionSession(), J.getDataLayout()); 299 auto LLJITRunAtExits = Mangle("__lljit_run_atexits"); 300 301 DenseMap<JITDylib *, SymbolLookupSet> LookupSymbols; 302 std::vector<JITDylib *> DFSLinkOrder; 303 304 ES.runSessionLocked([&]() { 305 DFSLinkOrder = getDFSLinkOrder(JD); 306 307 for (auto *NextJD : DFSLinkOrder) { 308 auto &JDLookupSymbols = LookupSymbols[NextJD]; 309 auto DIFItr = DeInitFunctions.find(NextJD); 310 if (DIFItr != DeInitFunctions.end()) { 311 LookupSymbols[NextJD] = std::move(DIFItr->second); 312 DeInitFunctions.erase(DIFItr); 313 } 314 JDLookupSymbols.add(LLJITRunAtExits, 315 SymbolLookupFlags::WeaklyReferencedSymbol); 316 } 317 }); 318 319 auto LookupResult = Platform::lookupInitSymbols(ES, LookupSymbols); 320 321 if (!LookupResult) 322 return LookupResult.takeError(); 323 324 std::vector<JITTargetAddress> DeInitializers; 325 for (auto *NextJD : DFSLinkOrder) { 326 auto DeInitsItr = LookupResult->find(NextJD); 327 assert(DeInitsItr != LookupResult->end() && 328 "Every JD should have at least __lljit_run_atexits"); 329 330 auto RunAtExitsItr = DeInitsItr->second.find(LLJITRunAtExits); 331 if (RunAtExitsItr != DeInitsItr->second.end()) 332 DeInitializers.push_back(RunAtExitsItr->second.getAddress()); 333 334 for (auto &KV : DeInitsItr->second) 335 if (KV.first != LLJITRunAtExits) 336 DeInitializers.push_back(KV.second.getAddress()); 337 } 338 339 return DeInitializers; 340 } 341 342 // Returns a DFS traversal order of the JITDylibs reachable (via 343 // links-against edges) from JD, starting with JD itself. 344 static std::vector<JITDylib *> getDFSLinkOrder(JITDylib &JD) { 345 std::vector<JITDylib *> DFSLinkOrder; 346 std::vector<JITDylib *> WorkStack({&JD}); 347 DenseSet<JITDylib *> Visited; 348 349 while (!WorkStack.empty()) { 350 auto &NextJD = *WorkStack.back(); 351 WorkStack.pop_back(); 352 if (Visited.count(&NextJD)) 353 continue; 354 Visited.insert(&NextJD); 355 DFSLinkOrder.push_back(&NextJD); 356 NextJD.withSearchOrderDo([&](const JITDylibSearchOrder &SearchOrder) { 357 for (auto &KV : SearchOrder) 358 WorkStack.push_back(KV.first); 359 }); 360 } 361 362 return DFSLinkOrder; 363 } 364 365 /// Issue lookups for all init symbols required to initialize JD (and any 366 /// JITDylibs that it depends on). 367 Error issueInitLookups(JITDylib &JD) { 368 DenseMap<JITDylib *, SymbolLookupSet> RequiredInitSymbols; 369 std::vector<JITDylib *> DFSLinkOrder; 370 371 getExecutionSession().runSessionLocked([&]() { 372 DFSLinkOrder = getDFSLinkOrder(JD); 373 374 for (auto *NextJD : DFSLinkOrder) { 375 auto ISItr = InitSymbols.find(NextJD); 376 if (ISItr != InitSymbols.end()) { 377 RequiredInitSymbols[NextJD] = std::move(ISItr->second); 378 InitSymbols.erase(ISItr); 379 } 380 } 381 }); 382 383 return Platform::lookupInitSymbols(getExecutionSession(), 384 RequiredInitSymbols) 385 .takeError(); 386 } 387 388 static void registerAtExitHelper(void *Self, void (*F)(void *), void *Ctx, 389 void *DSOHandle) { 390 static_cast<GenericLLVMIRPlatformSupport *>(Self)->AtExitMgr.registerAtExit( 391 F, Ctx, DSOHandle); 392 } 393 394 static void runAtExitsHelper(void *Self, void *DSOHandle) { 395 static_cast<GenericLLVMIRPlatformSupport *>(Self)->AtExitMgr.runAtExits( 396 DSOHandle); 397 } 398 399 // Constructs an LLVM IR module containing platform runtime globals, 400 // functions, and interposes. 401 ThreadSafeModule createPlatformRuntimeModule() { 402 auto Ctx = std::make_unique<LLVMContext>(); 403 auto M = std::make_unique<Module>("__standard_lib", *Ctx); 404 M->setDataLayout(J.getDataLayout()); 405 406 auto *GenericIRPlatformSupportTy = 407 StructType::create(*Ctx, "lljit.GenericLLJITIRPlatformSupport"); 408 409 auto *PlatformInstanceDecl = new GlobalVariable( 410 *M, GenericIRPlatformSupportTy, true, GlobalValue::ExternalLinkage, 411 nullptr, "__lljit.platform_support_instance"); 412 413 auto *DSOHandleDecl = addDSOHandleDecl(*M); 414 415 auto *Int8Ty = Type::getInt8Ty(*Ctx); 416 auto *IntTy = Type::getIntNTy(*Ctx, sizeof(int) * CHAR_BIT); 417 auto *VoidTy = Type::getVoidTy(*Ctx); 418 auto *BytePtrTy = PointerType::getUnqual(Int8Ty); 419 auto *AtExitCallbackTy = FunctionType::get(VoidTy, {BytePtrTy}, false); 420 auto *AtExitCallbackPtrTy = PointerType::getUnqual(AtExitCallbackTy); 421 422 addHelperAndWrapper( 423 *M, "__cxa_atexit", 424 FunctionType::get(IntTy, {AtExitCallbackPtrTy, BytePtrTy, BytePtrTy}, 425 false), 426 GlobalValue::HiddenVisibility, "__lljit.cxa_atexit_helper", 427 {PlatformInstanceDecl}); 428 429 addHelperAndWrapper( 430 *M, "__lljit_run_atexits", FunctionType::get(VoidTy, {}, false), 431 GlobalValue::HiddenVisibility, "__lljit.run_atexits_helper", 432 {PlatformInstanceDecl, DSOHandleDecl}); 433 434 return ThreadSafeModule(std::move(M), std::move(Ctx)); 435 } 436 437 LLJIT &J; 438 SymbolStringPtr InitFunctionPrefix; 439 DenseMap<JITDylib *, SymbolLookupSet> InitSymbols; 440 DenseMap<JITDylib *, SymbolLookupSet> InitFunctions; 441 DenseMap<JITDylib *, SymbolLookupSet> DeInitFunctions; 442 ItaniumCXAAtExitSupport AtExitMgr; 443 }; 444 445 Error GenericLLVMIRPlatform::setupJITDylib(JITDylib &JD) { 446 return S.setupJITDylib(JD); 447 } 448 449 Error GenericLLVMIRPlatform::notifyAdding(JITDylib &JD, 450 const MaterializationUnit &MU) { 451 return S.notifyAdding(JD, MU); 452 } 453 454 Expected<ThreadSafeModule> 455 GlobalCtorDtorScraper::operator()(ThreadSafeModule TSM, 456 MaterializationResponsibility &R) { 457 auto Err = TSM.withModuleDo([&](Module &M) -> Error { 458 auto &Ctx = M.getContext(); 459 auto *GlobalCtors = M.getNamedGlobal("llvm.global_ctors"); 460 461 // If there's no llvm.global_ctors or it's just a decl then skip. 462 if (!GlobalCtors || GlobalCtors->isDeclaration()) 463 return Error::success(); 464 465 std::string InitFunctionName; 466 raw_string_ostream(InitFunctionName) 467 << InitFunctionPrefix << M.getModuleIdentifier(); 468 469 MangleAndInterner Mangle(PS.getExecutionSession(), M.getDataLayout()); 470 auto InternedName = Mangle(InitFunctionName); 471 if (auto Err = 472 R.defineMaterializing({{InternedName, JITSymbolFlags::Callable}})) 473 return Err; 474 475 auto *InitFunc = 476 Function::Create(FunctionType::get(Type::getVoidTy(Ctx), {}, false), 477 GlobalValue::ExternalLinkage, InitFunctionName, &M); 478 InitFunc->setVisibility(GlobalValue::HiddenVisibility); 479 std::vector<std::pair<Function *, unsigned>> Inits; 480 for (auto E : getConstructors(M)) 481 Inits.push_back(std::make_pair(E.Func, E.Priority)); 482 llvm::sort(Inits, [](const std::pair<Function *, unsigned> &LHS, 483 const std::pair<Function *, unsigned> &RHS) { 484 return LHS.first < RHS.first; 485 }); 486 auto *EntryBlock = BasicBlock::Create(Ctx, "entry", InitFunc); 487 IRBuilder<> IB(EntryBlock); 488 for (auto &KV : Inits) 489 IB.CreateCall(KV.first); 490 IB.CreateRetVoid(); 491 492 PS.registerInitFunc(R.getTargetJITDylib(), InternedName); 493 GlobalCtors->eraseFromParent(); 494 return Error::success(); 495 }); 496 497 if (Err) 498 return std::move(Err); 499 500 return std::move(TSM); 501 } 502 503 class MachOPlatformSupport : public LLJIT::PlatformSupport { 504 public: 505 using DLOpenType = void *(*)(const char *Name, int Mode); 506 using DLCloseType = int (*)(void *Handle); 507 using DLSymType = void *(*)(void *Handle, const char *Name); 508 using DLErrorType = const char *(*)(); 509 510 struct DlFcnValues { 511 Optional<void *> RTLDDefault; 512 DLOpenType dlopen = nullptr; 513 DLCloseType dlclose = nullptr; 514 DLSymType dlsym = nullptr; 515 DLErrorType dlerror = nullptr; 516 }; 517 518 static Expected<std::unique_ptr<MachOPlatformSupport>> 519 Create(LLJIT &J, JITDylib &PlatformJITDylib) { 520 521 // Make process symbols visible. 522 { 523 std::string ErrMsg; 524 auto Lib = sys::DynamicLibrary::getPermanentLibrary(nullptr, &ErrMsg); 525 if (!Lib.isValid()) 526 return make_error<StringError>(std::move(ErrMsg), 527 inconvertibleErrorCode()); 528 } 529 530 DlFcnValues DlFcn; 531 532 // Add support for RTLDDefault on known platforms. 533 #ifdef __APPLE__ 534 DlFcn.RTLDDefault = reinterpret_cast<void *>(-2); 535 #endif // __APPLE__ 536 537 if (auto Err = hookUpFunction(DlFcn.dlopen, "dlopen")) 538 return std::move(Err); 539 if (auto Err = hookUpFunction(DlFcn.dlclose, "dlclose")) 540 return std::move(Err); 541 if (auto Err = hookUpFunction(DlFcn.dlsym, "dlsym")) 542 return std::move(Err); 543 if (auto Err = hookUpFunction(DlFcn.dlerror, "dlerror")) 544 return std::move(Err); 545 546 std::unique_ptr<MachOPlatformSupport> MP( 547 new MachOPlatformSupport(J, PlatformJITDylib, DlFcn)); 548 return std::move(MP); 549 } 550 551 Error initialize(JITDylib &JD) override { 552 LLVM_DEBUG({ 553 dbgs() << "MachOPlatformSupport initializing \"" << JD.getName() 554 << "\"\n"; 555 }); 556 557 auto InitSeq = MP.getInitializerSequence(JD); 558 if (!InitSeq) 559 return InitSeq.takeError(); 560 561 // If ObjC is not enabled but there are JIT'd ObjC inits then return 562 // an error. 563 if (!objCRegistrationEnabled()) 564 for (auto &KV : *InitSeq) { 565 if (!KV.second.getObjCSelRefsSections().empty() || 566 !KV.second.getObjCClassListSections().empty()) 567 return make_error<StringError>("JITDylib " + KV.first->getName() + 568 " contains objc metadata but objc" 569 " is not enabled", 570 inconvertibleErrorCode()); 571 } 572 573 // Run the initializers. 574 for (auto &KV : *InitSeq) { 575 if (objCRegistrationEnabled()) { 576 KV.second.registerObjCSelectors(); 577 if (auto Err = KV.second.registerObjCClasses()) { 578 // FIXME: Roll back registrations on error? 579 return Err; 580 } 581 } 582 KV.second.runModInits(); 583 } 584 585 return Error::success(); 586 } 587 588 Error deinitialize(JITDylib &JD) override { 589 auto &ES = J.getExecutionSession(); 590 if (auto DeinitSeq = MP.getDeinitializerSequence(JD)) { 591 for (auto &KV : *DeinitSeq) { 592 auto DSOHandleName = ES.intern("___dso_handle"); 593 594 // FIXME: Run DeInits here. 595 auto Result = ES.lookup( 596 {{KV.first, JITDylibLookupFlags::MatchAllSymbols}}, 597 SymbolLookupSet(DSOHandleName, 598 SymbolLookupFlags::WeaklyReferencedSymbol)); 599 if (!Result) 600 return Result.takeError(); 601 if (Result->empty()) 602 continue; 603 assert(Result->count(DSOHandleName) && 604 "Result does not contain __dso_handle"); 605 auto *DSOHandle = jitTargetAddressToPointer<void *>( 606 Result->begin()->second.getAddress()); 607 AtExitMgr.runAtExits(DSOHandle); 608 } 609 } else 610 return DeinitSeq.takeError(); 611 return Error::success(); 612 } 613 614 private: 615 template <typename FunctionPtrTy> 616 static Error hookUpFunction(FunctionPtrTy &Fn, const char *Name) { 617 if (auto *FnAddr = sys::DynamicLibrary::SearchForAddressOfSymbol(Name)) { 618 Fn = reinterpret_cast<FunctionPtrTy>(Fn); 619 return Error::success(); 620 } 621 622 return make_error<StringError>((Twine("Can not enable MachO JIT Platform: " 623 "missing function: ") + 624 Name) 625 .str(), 626 inconvertibleErrorCode()); 627 } 628 629 MachOPlatformSupport(LLJIT &J, JITDylib &PlatformJITDylib, DlFcnValues DlFcn) 630 : J(J), MP(setupPlatform(J)), DlFcn(std::move(DlFcn)) { 631 632 MangleAndInterner Mangle(J.getExecutionSession(), J.getDataLayout()); 633 SymbolMap HelperSymbols; 634 635 // platform and atexit helpers. 636 HelperSymbols[Mangle("__lljit.platform_support_instance")] = 637 JITEvaluatedSymbol(pointerToJITTargetAddress(this), JITSymbolFlags()); 638 HelperSymbols[Mangle("__lljit.cxa_atexit_helper")] = JITEvaluatedSymbol( 639 pointerToJITTargetAddress(registerAtExitHelper), JITSymbolFlags()); 640 HelperSymbols[Mangle("__lljit.run_atexits_helper")] = JITEvaluatedSymbol( 641 pointerToJITTargetAddress(runAtExitsHelper), JITSymbolFlags()); 642 643 // dlfcn helpers. 644 HelperSymbols[Mangle("__lljit.dlopen_helper")] = JITEvaluatedSymbol( 645 pointerToJITTargetAddress(dlopenHelper), JITSymbolFlags()); 646 HelperSymbols[Mangle("__lljit.dlclose_helper")] = JITEvaluatedSymbol( 647 pointerToJITTargetAddress(dlcloseHelper), JITSymbolFlags()); 648 HelperSymbols[Mangle("__lljit.dlsym_helper")] = JITEvaluatedSymbol( 649 pointerToJITTargetAddress(dlsymHelper), JITSymbolFlags()); 650 HelperSymbols[Mangle("__lljit.dlerror_helper")] = JITEvaluatedSymbol( 651 pointerToJITTargetAddress(dlerrorHelper), JITSymbolFlags()); 652 653 cantFail( 654 PlatformJITDylib.define(absoluteSymbols(std::move(HelperSymbols)))); 655 cantFail(MP.setupJITDylib(J.getMainJITDylib())); 656 cantFail(J.addIRModule(PlatformJITDylib, createPlatformRuntimeModule())); 657 } 658 659 static MachOPlatform &setupPlatform(LLJIT &J) { 660 auto Tmp = std::make_unique<MachOPlatform>( 661 J.getExecutionSession(), 662 static_cast<ObjectLinkingLayer &>(J.getObjLinkingLayer()), 663 createStandardSymbolsObject(J)); 664 auto &MP = *Tmp; 665 J.getExecutionSession().setPlatform(std::move(Tmp)); 666 return MP; 667 } 668 669 static std::unique_ptr<MemoryBuffer> createStandardSymbolsObject(LLJIT &J) { 670 LLVMContext Ctx; 671 Module M("__standard_symbols", Ctx); 672 M.setDataLayout(J.getDataLayout()); 673 674 auto *Int64Ty = Type::getInt64Ty(Ctx); 675 676 auto *DSOHandle = 677 new GlobalVariable(M, Int64Ty, true, GlobalValue::ExternalLinkage, 678 ConstantInt::get(Int64Ty, 0), "__dso_handle"); 679 DSOHandle->setVisibility(GlobalValue::HiddenVisibility); 680 681 return cantFail(J.getIRCompileLayer().getCompiler()(M)); 682 } 683 684 ThreadSafeModule createPlatformRuntimeModule() { 685 auto Ctx = std::make_unique<LLVMContext>(); 686 auto M = std::make_unique<Module>("__standard_lib", *Ctx); 687 M->setDataLayout(J.getDataLayout()); 688 689 auto *MachOPlatformSupportTy = 690 StructType::create(*Ctx, "lljit.MachOPlatformSupport"); 691 692 auto *PlatformInstanceDecl = new GlobalVariable( 693 *M, MachOPlatformSupportTy, true, GlobalValue::ExternalLinkage, nullptr, 694 "__lljit.platform_support_instance"); 695 696 auto *Int8Ty = Type::getInt8Ty(*Ctx); 697 auto *IntTy = Type::getIntNTy(*Ctx, sizeof(int) * CHAR_BIT); 698 auto *VoidTy = Type::getVoidTy(*Ctx); 699 auto *BytePtrTy = PointerType::getUnqual(Int8Ty); 700 auto *AtExitCallbackTy = FunctionType::get(VoidTy, {BytePtrTy}, false); 701 auto *AtExitCallbackPtrTy = PointerType::getUnqual(AtExitCallbackTy); 702 703 addHelperAndWrapper( 704 *M, "__cxa_atexit", 705 FunctionType::get(IntTy, {AtExitCallbackPtrTy, BytePtrTy, BytePtrTy}, 706 false), 707 GlobalValue::DefaultVisibility, "__lljit.cxa_atexit_helper", 708 {PlatformInstanceDecl}); 709 710 addHelperAndWrapper(*M, "dlopen", 711 FunctionType::get(BytePtrTy, {BytePtrTy, IntTy}, false), 712 GlobalValue::DefaultVisibility, "__lljit.dlopen_helper", 713 {PlatformInstanceDecl}); 714 715 addHelperAndWrapper(*M, "dlclose", 716 FunctionType::get(IntTy, {BytePtrTy}, false), 717 GlobalValue::DefaultVisibility, 718 "__lljit.dlclose_helper", {PlatformInstanceDecl}); 719 720 addHelperAndWrapper( 721 *M, "dlsym", 722 FunctionType::get(BytePtrTy, {BytePtrTy, BytePtrTy}, false), 723 GlobalValue::DefaultVisibility, "__lljit.dlsym_helper", 724 {PlatformInstanceDecl}); 725 726 addHelperAndWrapper(*M, "dlerror", FunctionType::get(BytePtrTy, {}, false), 727 GlobalValue::DefaultVisibility, 728 "__lljit.dlerror_helper", {PlatformInstanceDecl}); 729 730 return ThreadSafeModule(std::move(M), std::move(Ctx)); 731 } 732 733 static void registerAtExitHelper(void *Self, void (*F)(void *), void *Ctx, 734 void *DSOHandle) { 735 static_cast<MachOPlatformSupport *>(Self)->AtExitMgr.registerAtExit( 736 F, Ctx, DSOHandle); 737 } 738 739 static void runAtExitsHelper(void *Self, void *DSOHandle) { 740 static_cast<MachOPlatformSupport *>(Self)->AtExitMgr.runAtExits(DSOHandle); 741 } 742 743 void *jit_dlopen(const char *Path, int Mode) { 744 JITDylib *JDToOpen = nullptr; 745 // FIXME: Do the right thing with Mode flags. 746 { 747 std::lock_guard<std::mutex> Lock(PlatformSupportMutex); 748 749 // Clear any existing error messages. 750 dlErrorMsgs.erase(std::this_thread::get_id()); 751 752 if (auto *JD = J.getExecutionSession().getJITDylibByName(Path)) { 753 auto I = JDRefCounts.find(JD); 754 if (I != JDRefCounts.end()) { 755 ++I->second; 756 return JD; 757 } 758 759 JDRefCounts[JD] = 1; 760 JDToOpen = JD; 761 } 762 } 763 764 if (JDToOpen) { 765 if (auto Err = initialize(*JDToOpen)) { 766 recordError(std::move(Err)); 767 return 0; 768 } 769 } 770 771 // Fall through to dlopen if no JITDylib found for Path. 772 return DlFcn.dlopen(Path, Mode); 773 } 774 775 static void *dlopenHelper(void *Self, const char *Path, int Mode) { 776 return static_cast<MachOPlatformSupport *>(Self)->jit_dlopen(Path, Mode); 777 } 778 779 int jit_dlclose(void *Handle) { 780 JITDylib *JDToClose = nullptr; 781 782 { 783 std::lock_guard<std::mutex> Lock(PlatformSupportMutex); 784 785 // Clear any existing error messages. 786 dlErrorMsgs.erase(std::this_thread::get_id()); 787 788 auto I = JDRefCounts.find(Handle); 789 if (I != JDRefCounts.end()) { 790 --I->second; 791 if (I->second == 0) { 792 JDRefCounts.erase(I); 793 JDToClose = static_cast<JITDylib *>(Handle); 794 } else 795 return 0; 796 } 797 } 798 799 if (JDToClose) { 800 if (auto Err = deinitialize(*JDToClose)) { 801 recordError(std::move(Err)); 802 return -1; 803 } 804 return 0; 805 } 806 807 // Fall through to dlclose if no JITDylib found for Path. 808 return DlFcn.dlclose(Handle); 809 } 810 811 static int dlcloseHelper(void *Self, void *Handle) { 812 return static_cast<MachOPlatformSupport *>(Self)->jit_dlclose(Handle); 813 } 814 815 void *jit_dlsym(void *Handle, const char *Name) { 816 JITDylibSearchOrder JITSymSearchOrder; 817 818 // FIXME: RTLD_NEXT, RTLD_SELF not supported. 819 { 820 std::lock_guard<std::mutex> Lock(PlatformSupportMutex); 821 822 // Clear any existing error messages. 823 dlErrorMsgs.erase(std::this_thread::get_id()); 824 825 if (JDRefCounts.count(Handle)) { 826 JITSymSearchOrder.push_back( 827 {static_cast<JITDylib *>(Handle), 828 JITDylibLookupFlags::MatchExportedSymbolsOnly}); 829 } else if (Handle == DlFcn.RTLDDefault) { 830 for (auto &KV : JDRefCounts) 831 JITSymSearchOrder.push_back( 832 {static_cast<JITDylib *>(KV.first), 833 JITDylibLookupFlags::MatchExportedSymbolsOnly}); 834 } 835 } 836 837 if (!JITSymSearchOrder.empty()) { 838 MangleAndInterner Mangle(J.getExecutionSession(), J.getDataLayout()); 839 auto MangledName = Mangle(Name); 840 SymbolLookupSet Syms(MangledName, 841 SymbolLookupFlags::WeaklyReferencedSymbol); 842 if (auto Result = J.getExecutionSession().lookup(JITSymSearchOrder, Syms, 843 LookupKind::DLSym)) { 844 auto I = Result->find(MangledName); 845 if (I != Result->end()) 846 return jitTargetAddressToPointer<void *>(I->second.getAddress()); 847 } else { 848 recordError(Result.takeError()); 849 return 0; 850 } 851 } 852 853 // Fall through to dlsym. 854 return DlFcn.dlsym(Handle, Name); 855 } 856 857 static void *dlsymHelper(void *Self, void *Handle, const char *Name) { 858 return static_cast<MachOPlatformSupport *>(Self)->jit_dlsym(Handle, Name); 859 } 860 861 const char *jit_dlerror() { 862 { 863 std::lock_guard<std::mutex> Lock(PlatformSupportMutex); 864 auto I = dlErrorMsgs.find(std::this_thread::get_id()); 865 if (I != dlErrorMsgs.end()) 866 return I->second->c_str(); 867 } 868 return DlFcn.dlerror(); 869 } 870 871 static const char *dlerrorHelper(void *Self) { 872 return static_cast<MachOPlatformSupport *>(Self)->jit_dlerror(); 873 } 874 875 void recordError(Error Err) { 876 std::lock_guard<std::mutex> Lock(PlatformSupportMutex); 877 dlErrorMsgs[std::this_thread::get_id()] = 878 std::make_unique<std::string>(toString(std::move(Err))); 879 } 880 881 std::mutex PlatformSupportMutex; 882 LLJIT &J; 883 MachOPlatform &MP; 884 DlFcnValues DlFcn; 885 ItaniumCXAAtExitSupport AtExitMgr; 886 DenseMap<void *, unsigned> JDRefCounts; 887 std::map<std::thread::id, std::unique_ptr<std::string>> dlErrorMsgs; 888 }; 889 890 } // end anonymous namespace 891 892 namespace llvm { 893 namespace orc { 894 895 void LLJIT::PlatformSupport::setInitTransform( 896 LLJIT &J, IRTransformLayer::TransformFunction T) { 897 J.InitHelperTransformLayer->setTransform(std::move(T)); 898 } 899 900 LLJIT::PlatformSupport::~PlatformSupport() {} 901 902 Error LLJITBuilderState::prepareForConstruction() { 903 904 if (!JTMB) { 905 if (auto JTMBOrErr = JITTargetMachineBuilder::detectHost()) 906 JTMB = std::move(*JTMBOrErr); 907 else 908 return JTMBOrErr.takeError(); 909 } 910 911 // If the client didn't configure any linker options then auto-configure the 912 // JIT linker. 913 if (!CreateObjectLinkingLayer && JTMB->getCodeModel() == None && 914 JTMB->getRelocationModel() == None) { 915 916 auto &TT = JTMB->getTargetTriple(); 917 if (TT.isOSBinFormatMachO() && 918 (TT.getArch() == Triple::aarch64 || TT.getArch() == Triple::x86_64)) { 919 920 JTMB->setRelocationModel(Reloc::PIC_); 921 JTMB->setCodeModel(CodeModel::Small); 922 CreateObjectLinkingLayer = 923 [](ExecutionSession &ES, 924 const Triple &) -> std::unique_ptr<ObjectLayer> { 925 auto ObjLinkingLayer = std::make_unique<ObjectLinkingLayer>( 926 ES, std::make_unique<jitlink::InProcessMemoryManager>()); 927 ObjLinkingLayer->addPlugin(std::make_unique<EHFrameRegistrationPlugin>( 928 jitlink::InProcessEHFrameRegistrar::getInstance())); 929 return std::move(ObjLinkingLayer); 930 }; 931 } 932 } 933 934 return Error::success(); 935 } 936 937 LLJIT::~LLJIT() { 938 if (CompileThreads) 939 CompileThreads->wait(); 940 } 941 942 Error LLJIT::defineAbsolute(StringRef Name, JITEvaluatedSymbol Sym) { 943 auto InternedName = ES->intern(Name); 944 SymbolMap Symbols({{InternedName, Sym}}); 945 return Main->define(absoluteSymbols(std::move(Symbols))); 946 } 947 948 Error LLJIT::addIRModule(JITDylib &JD, ThreadSafeModule TSM) { 949 assert(TSM && "Can not add null module"); 950 951 if (auto Err = 952 TSM.withModuleDo([&](Module &M) { return applyDataLayout(M); })) 953 return Err; 954 955 return InitHelperTransformLayer->add(JD, std::move(TSM), 956 ES->allocateVModule()); 957 } 958 959 Error LLJIT::addObjectFile(JITDylib &JD, std::unique_ptr<MemoryBuffer> Obj) { 960 assert(Obj && "Can not add null object"); 961 962 return ObjTransformLayer.add(JD, std::move(Obj), ES->allocateVModule()); 963 } 964 965 Expected<JITEvaluatedSymbol> LLJIT::lookupLinkerMangled(JITDylib &JD, 966 StringRef Name) { 967 return ES->lookup( 968 makeJITDylibSearchOrder(&JD, JITDylibLookupFlags::MatchAllSymbols), 969 ES->intern(Name)); 970 } 971 972 std::unique_ptr<ObjectLayer> 973 LLJIT::createObjectLinkingLayer(LLJITBuilderState &S, ExecutionSession &ES) { 974 975 // If the config state provided an ObjectLinkingLayer factory then use it. 976 if (S.CreateObjectLinkingLayer) 977 return S.CreateObjectLinkingLayer(ES, S.JTMB->getTargetTriple()); 978 979 // Otherwise default to creating an RTDyldObjectLinkingLayer that constructs 980 // a new SectionMemoryManager for each object. 981 auto GetMemMgr = []() { return std::make_unique<SectionMemoryManager>(); }; 982 auto ObjLinkingLayer = 983 std::make_unique<RTDyldObjectLinkingLayer>(ES, std::move(GetMemMgr)); 984 985 if (S.JTMB->getTargetTriple().isOSBinFormatCOFF()) { 986 ObjLinkingLayer->setOverrideObjectFlagsWithResponsibilityFlags(true); 987 ObjLinkingLayer->setAutoClaimResponsibilityForObjectSymbols(true); 988 } 989 990 // FIXME: Explicit conversion to std::unique_ptr<ObjectLayer> added to silence 991 // errors from some GCC / libstdc++ bots. Remove this conversion (i.e. 992 // just return ObjLinkingLayer) once those bots are upgraded. 993 return std::unique_ptr<ObjectLayer>(std::move(ObjLinkingLayer)); 994 } 995 996 Expected<std::unique_ptr<IRCompileLayer::IRCompiler>> 997 LLJIT::createCompileFunction(LLJITBuilderState &S, 998 JITTargetMachineBuilder JTMB) { 999 1000 /// If there is a custom compile function creator set then use it. 1001 if (S.CreateCompileFunction) 1002 return S.CreateCompileFunction(std::move(JTMB)); 1003 1004 // Otherwise default to creating a SimpleCompiler, or ConcurrentIRCompiler, 1005 // depending on the number of threads requested. 1006 if (S.NumCompileThreads > 0) 1007 return std::make_unique<ConcurrentIRCompiler>(std::move(JTMB)); 1008 1009 auto TM = JTMB.createTargetMachine(); 1010 if (!TM) 1011 return TM.takeError(); 1012 1013 return std::make_unique<TMOwningSimpleCompiler>(std::move(*TM)); 1014 } 1015 1016 LLJIT::LLJIT(LLJITBuilderState &S, Error &Err) 1017 : ES(S.ES ? std::move(S.ES) : std::make_unique<ExecutionSession>()), Main(), 1018 DL(""), TT(S.JTMB->getTargetTriple()), 1019 ObjLinkingLayer(createObjectLinkingLayer(S, *ES)), 1020 ObjTransformLayer(*this->ES, *ObjLinkingLayer) { 1021 1022 ErrorAsOutParameter _(&Err); 1023 1024 if (auto MainOrErr = this->ES->createJITDylib("main")) 1025 Main = &*MainOrErr; 1026 else { 1027 Err = MainOrErr.takeError(); 1028 return; 1029 } 1030 1031 if (S.DL) 1032 DL = std::move(*S.DL); 1033 else if (auto DLOrErr = S.JTMB->getDefaultDataLayoutForTarget()) 1034 DL = std::move(*DLOrErr); 1035 else { 1036 Err = DLOrErr.takeError(); 1037 return; 1038 } 1039 1040 { 1041 auto CompileFunction = createCompileFunction(S, std::move(*S.JTMB)); 1042 if (!CompileFunction) { 1043 Err = CompileFunction.takeError(); 1044 return; 1045 } 1046 CompileLayer = std::make_unique<IRCompileLayer>( 1047 *ES, ObjTransformLayer, std::move(*CompileFunction)); 1048 TransformLayer = std::make_unique<IRTransformLayer>(*ES, *CompileLayer); 1049 InitHelperTransformLayer = 1050 std::make_unique<IRTransformLayer>(*ES, *TransformLayer); 1051 } 1052 1053 if (S.NumCompileThreads > 0) { 1054 InitHelperTransformLayer->setCloneToNewContextOnEmit(true); 1055 CompileThreads = 1056 std::make_unique<ThreadPool>(hardware_concurrency(S.NumCompileThreads)); 1057 ES->setDispatchMaterialization( 1058 [this](JITDylib &JD, std::unique_ptr<MaterializationUnit> MU) { 1059 // FIXME: Switch to move capture once we have c++14. 1060 auto SharedMU = std::shared_ptr<MaterializationUnit>(std::move(MU)); 1061 auto Work = [SharedMU, &JD]() { SharedMU->doMaterialize(JD); }; 1062 CompileThreads->async(std::move(Work)); 1063 }); 1064 } 1065 1066 if (S.SetUpPlatform) 1067 Err = S.SetUpPlatform(*this); 1068 else 1069 setUpGenericLLVMIRPlatform(*this); 1070 } 1071 1072 std::string LLJIT::mangle(StringRef UnmangledName) { 1073 std::string MangledName; 1074 { 1075 raw_string_ostream MangledNameStream(MangledName); 1076 Mangler::getNameWithPrefix(MangledNameStream, UnmangledName, DL); 1077 } 1078 return MangledName; 1079 } 1080 1081 Error LLJIT::applyDataLayout(Module &M) { 1082 if (M.getDataLayout().isDefault()) 1083 M.setDataLayout(DL); 1084 1085 if (M.getDataLayout() != DL) 1086 return make_error<StringError>( 1087 "Added modules have incompatible data layouts: " + 1088 M.getDataLayout().getStringRepresentation() + " (module) vs " + 1089 DL.getStringRepresentation() + " (jit)", 1090 inconvertibleErrorCode()); 1091 1092 return Error::success(); 1093 } 1094 1095 void setUpGenericLLVMIRPlatform(LLJIT &J) { 1096 LLVM_DEBUG( 1097 { dbgs() << "Setting up GenericLLVMIRPlatform support for LLJIT\n"; }); 1098 J.setPlatformSupport(std::make_unique<GenericLLVMIRPlatformSupport>(J)); 1099 } 1100 1101 Error setUpMachOPlatform(LLJIT &J) { 1102 LLVM_DEBUG({ dbgs() << "Setting up MachOPlatform support for LLJIT\n"; }); 1103 auto MP = MachOPlatformSupport::Create(J, J.getMainJITDylib()); 1104 if (!MP) 1105 return MP.takeError(); 1106 J.setPlatformSupport(std::move(*MP)); 1107 return Error::success(); 1108 } 1109 1110 Error LLLazyJITBuilderState::prepareForConstruction() { 1111 if (auto Err = LLJITBuilderState::prepareForConstruction()) 1112 return Err; 1113 TT = JTMB->getTargetTriple(); 1114 return Error::success(); 1115 } 1116 1117 Error LLLazyJIT::addLazyIRModule(JITDylib &JD, ThreadSafeModule TSM) { 1118 assert(TSM && "Can not add null module"); 1119 1120 if (auto Err = TSM.withModuleDo( 1121 [&](Module &M) -> Error { return applyDataLayout(M); })) 1122 return Err; 1123 1124 return CODLayer->add(JD, std::move(TSM), ES->allocateVModule()); 1125 } 1126 1127 LLLazyJIT::LLLazyJIT(LLLazyJITBuilderState &S, Error &Err) : LLJIT(S, Err) { 1128 1129 // If LLJIT construction failed then bail out. 1130 if (Err) 1131 return; 1132 1133 ErrorAsOutParameter _(&Err); 1134 1135 /// Take/Create the lazy-compile callthrough manager. 1136 if (S.LCTMgr) 1137 LCTMgr = std::move(S.LCTMgr); 1138 else { 1139 if (auto LCTMgrOrErr = createLocalLazyCallThroughManager( 1140 S.TT, *ES, S.LazyCompileFailureAddr)) 1141 LCTMgr = std::move(*LCTMgrOrErr); 1142 else { 1143 Err = LCTMgrOrErr.takeError(); 1144 return; 1145 } 1146 } 1147 1148 // Take/Create the indirect stubs manager builder. 1149 auto ISMBuilder = std::move(S.ISMBuilder); 1150 1151 // If none was provided, try to build one. 1152 if (!ISMBuilder) 1153 ISMBuilder = createLocalIndirectStubsManagerBuilder(S.TT); 1154 1155 // No luck. Bail out. 1156 if (!ISMBuilder) { 1157 Err = make_error<StringError>("Could not construct " 1158 "IndirectStubsManagerBuilder for target " + 1159 S.TT.str(), 1160 inconvertibleErrorCode()); 1161 return; 1162 } 1163 1164 // Create the COD layer. 1165 CODLayer = std::make_unique<CompileOnDemandLayer>( 1166 *ES, *InitHelperTransformLayer, *LCTMgr, std::move(ISMBuilder)); 1167 1168 if (S.NumCompileThreads > 0) 1169 CODLayer->setCloneToNewContextOnEmit(true); 1170 } 1171 1172 } // End namespace orc. 1173 } // End namespace llvm. 1174