llvm::raw_ostream &stderrOS,
boolexitEarly,
booldisableOutput);
62llvm::orc::ThreadSafeContext &TSC)
66std::string ErrorString;
68 constllvm::Target *
Target= llvm::TargetRegistry::lookupTarget(
69PTU.
TheModule->getTargetTriple(), ErrorString);
71 returnllvm::make_error<llvm::StringError>(
"Failed to create Wasm Target: ",
72llvm::inconvertibleErrorCode());
75llvm::TargetOptions TO = llvm::TargetOptions();
76llvm::TargetMachine *TargetMachine =
Target->createTargetMachine(
77PTU.
TheModule->getTargetTriple(),
"",
"", TO, llvm::Reloc::Model::PIC_);
78PTU.
TheModule->setDataLayout(TargetMachine->createDataLayout());
79std::string ObjectFileName = PTU.
TheModule->getName().str() +
".o";
80std::string BinaryFileName = PTU.
TheModule->getName().str() +
".wasm";
82std::error_code Error;
83llvm::raw_fd_ostream ObjectFileOutput(llvm::StringRef(ObjectFileName), Error);
85llvm::legacy::PassManager PM;
86 if(TargetMachine->addPassesToEmitFile(PM, ObjectFileOutput,
nullptr,
87llvm::CodeGenFileType::ObjectFile)) {
88 returnllvm::make_error<llvm::StringError>(
89 "Wasm backend cannot produce object.", llvm::inconvertibleErrorCode());
94 returnllvm::make_error<llvm::StringError>(
"Failed to emit Wasm object.",
95llvm::inconvertibleErrorCode());
98ObjectFileOutput.close();
100std::vector<const char *> LinkerArgs = {
"wasm-ld",
103 "--experimental-pic",
105 "--allow-undefined",
106ObjectFileName.c_str(),
108BinaryFileName.c_str()};
111std::vector<lld::DriverDef> WasmDriverArgs;
112WasmDriverArgs.push_back(WasmDriver);
114 lld::lldMain(LinkerArgs, llvm::outs(), llvm::errs(), WasmDriverArgs);
117 returnllvm::make_error<llvm::StringError>(
118 "Failed to link incremental module", llvm::inconvertibleErrorCode());
120 void*LoadedLibModule =
121dlopen(BinaryFileName.c_str(), RTLD_NOW | RTLD_GLOBAL);
122 if(LoadedLibModule ==
nullptr) {
123llvm::errs() << dlerror() <<
'\n';
124 returnllvm::make_error<llvm::StringError>(
125 "Failed to load incremental module", llvm::inconvertibleErrorCode());
128 returnllvm::Error::success();
132 returnllvm::make_error<llvm::StringError>(
"Not implemented yet",
133llvm::inconvertibleErrorCode());
138 returnllvm::Error::success();
144 returnllvm::Error::success();
llvm::MachO::Target Target
llvm::Error addModule(PartialTranslationUnit &PTU) override
llvm::Error runCtors() const override
~WasmIncrementalExecutor() override
llvm::Error removeModule(PartialTranslationUnit &PTU) override
llvm::Error cleanUp() override
WasmIncrementalExecutor(llvm::orc::ThreadSafeContext &TSC)
The JSON file list parser is used to communicate input to InstallAPI.
@ Result
The result type of a method or function.
bool link(llvm::ArrayRef< const char * > args, llvm::raw_ostream &stdoutOS, llvm::raw_ostream &stderrOS, bool exitEarly, bool disableOutput)
Result lldMain(llvm::ArrayRef< const char * > args, llvm::raw_ostream &stdoutOS, llvm::raw_ostream &stderrOS, llvm::ArrayRef< DriverDef > drivers)
bool(*)(llvm::ArrayRef< const char * >, llvm::raw_ostream &, llvm::raw_ostream &, bool, bool) Driver
The class keeps track of various objects created as part of processing incremental inputs.
std::unique_ptr< llvm::Module > TheModule
The llvm IR produced for the input.
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4