blob: 944881070c7034e2267a802d4ca82bef45a450a7 [file] [log] [blame]
Lang Hamesb20e09c2016-01-11 16:35:55 +00001//===-- RemoteJITUtils.h - Utilities for remote-JITing with LLI -*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// Utilities for remote-JITing with LLI.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_TOOLS_LLI_REMOTEJITUTILS_H
15#define LLVM_TOOLS_LLI_REMOTEJITUTILS_H
16
Lang Hames085827f2016-11-11 21:42:09 +000017#include "llvm/ExecutionEngine/Orc/RawByteChannel.h"
Lang Hamesb20e09c2016-01-11 16:35:55 +000018#include "llvm/ExecutionEngine/RTDyldMemoryManager.h"
Lang Hames6320b782016-04-18 19:55:43 +000019#include <mutex>
Lang Hamesb20e09c2016-01-11 16:35:55 +000020
21#if !defined(_MSC_VER) && !defined(__MINGW32__)
22#include <unistd.h>
23#else
24#include <io.h>
25#endif
26
27/// RPC channel that reads from and writes from file descriptors.
Lang Hames085827f2016-11-11 21:42:09 +000028class FDRawChannel final : public llvm::orc::rpc::RawByteChannel {
Lang Hamesb20e09c2016-01-11 16:35:55 +000029public:
Lang Hames085827f2016-11-11 21:42:09 +000030 FDRawChannel(int InFD, int OutFD) : InFD(InFD), OutFD(OutFD) {}
Lang Hamesb20e09c2016-01-11 16:35:55 +000031
Lang Hames1ddbb0f2016-04-25 19:56:45 +000032 llvm::Error readBytes(char *Dst, unsigned Size) override {
Lang Hamesb20e09c2016-01-11 16:35:55 +000033 assert(Dst && "Attempt to read into null.");
Lang Hames1ddbb0f2016-04-25 19:56:45 +000034 ssize_t Completed = 0;
Lang Hamesb9d01c82016-04-26 01:45:25 +000035 while (Completed < static_cast<ssize_t>(Size)) {
Lang Hames1ddbb0f2016-04-25 19:56:45 +000036 ssize_t Read = ::read(InFD, Dst + Completed, Size - Completed);
37 if (Read <= 0) {
38 auto ErrNo = errno;
39 if (ErrNo == EAGAIN || ErrNo == EINTR)
40 continue;
41 else
42 return llvm::errorCodeToError(
43 std::error_code(errno, std::generic_category()));
44 }
45 Completed += Read;
46 }
47 return llvm::Error::success();
Lang Hamesb20e09c2016-01-11 16:35:55 +000048 }
49
Lang Hames1ddbb0f2016-04-25 19:56:45 +000050 llvm::Error appendBytes(const char *Src, unsigned Size) override {
Lang Hamesb20e09c2016-01-11 16:35:55 +000051 assert(Src && "Attempt to append from null.");
Lang Hames1ddbb0f2016-04-25 19:56:45 +000052 ssize_t Completed = 0;
Lang Hamesb9d01c82016-04-26 01:45:25 +000053 while (Completed < static_cast<ssize_t>(Size)) {
Lang Hames1ddbb0f2016-04-25 19:56:45 +000054 ssize_t Written = ::write(OutFD, Src + Completed, Size - Completed);
55 if (Written < 0) {
56 auto ErrNo = errno;
57 if (ErrNo == EAGAIN || ErrNo == EINTR)
58 continue;
59 else
60 return llvm::errorCodeToError(
61 std::error_code(errno, std::generic_category()));
62 }
63 Completed += Written;
64 }
65 return llvm::Error::success();
Lang Hamesb20e09c2016-01-11 16:35:55 +000066 }
67
Lang Hames1ddbb0f2016-04-25 19:56:45 +000068 llvm::Error send() override { return llvm::Error::success(); }
Lang Hamesb20e09c2016-01-11 16:35:55 +000069
70private:
71 int InFD, OutFD;
72};
73
74// launch the remote process (see lli.cpp) and return a channel to it.
Lang Hames085827f2016-11-11 21:42:09 +000075std::unique_ptr<FDRawChannel> launchRemote();
Lang Hamesb20e09c2016-01-11 16:35:55 +000076
77namespace llvm {
78
Lang Hames085827f2016-11-11 21:42:09 +000079// ForwardingMM - Adapter to connect MCJIT to Orc's Remote8
80// memory manager.
Lang Hamesb20e09c2016-01-11 16:35:55 +000081class ForwardingMemoryManager : public llvm::RTDyldMemoryManager {
82public:
83 void setMemMgr(std::unique_ptr<RuntimeDyld::MemoryManager> MemMgr) {
84 this->MemMgr = std::move(MemMgr);
85 }
86
Lang Hames156b9942018-01-19 22:24:13 +000087 void setResolver(std::shared_ptr<LegacyJITSymbolResolver> Resolver) {
Lang Hamesb20e09c2016-01-11 16:35:55 +000088 this->Resolver = std::move(Resolver);
89 }
90
91 uint8_t *allocateCodeSection(uintptr_t Size, unsigned Alignment,
92 unsigned SectionID,
93 StringRef SectionName) override {
94 return MemMgr->allocateCodeSection(Size, Alignment, SectionID, SectionName);
95 }
96
97 uint8_t *allocateDataSection(uintptr_t Size, unsigned Alignment,
98 unsigned SectionID, StringRef SectionName,
99 bool IsReadOnly) override {
100 return MemMgr->allocateDataSection(Size, Alignment, SectionID, SectionName,
101 IsReadOnly);
102 }
103
104 void reserveAllocationSpace(uintptr_t CodeSize, uint32_t CodeAlign,
105 uintptr_t RODataSize, uint32_t RODataAlign,
106 uintptr_t RWDataSize,
107 uint32_t RWDataAlign) override {
108 MemMgr->reserveAllocationSpace(CodeSize, CodeAlign, RODataSize, RODataAlign,
109 RWDataSize, RWDataAlign);
110 }
111
112 bool needsToReserveAllocationSpace() override {
113 return MemMgr->needsToReserveAllocationSpace();
114 }
115
116 void registerEHFrames(uint8_t *Addr, uint64_t LoadAddr,
117 size_t Size) override {
118 MemMgr->registerEHFrames(Addr, LoadAddr, Size);
119 }
120
Lang Hamesab3dba82017-05-09 21:32:18 +0000121 void deregisterEHFrames() override {
122 MemMgr->deregisterEHFrames();
Lang Hamesb20e09c2016-01-11 16:35:55 +0000123 }
124
125 bool finalizeMemory(std::string *ErrMsg = nullptr) override {
126 return MemMgr->finalizeMemory(ErrMsg);
127 }
128
129 void notifyObjectLoaded(RuntimeDyld &RTDyld,
130 const object::ObjectFile &Obj) override {
131 MemMgr->notifyObjectLoaded(RTDyld, Obj);
132 }
133
134 // Don't hide the sibling notifyObjectLoaded from RTDyldMemoryManager.
135 using RTDyldMemoryManager::notifyObjectLoaded;
136
Lang Hames075c1e22016-08-01 20:49:11 +0000137 JITSymbol findSymbol(const std::string &Name) override {
Lang Hamesb20e09c2016-01-11 16:35:55 +0000138 return Resolver->findSymbol(Name);
139 }
140
Lang Hames075c1e22016-08-01 20:49:11 +0000141 JITSymbol
Lang Hamesb20e09c2016-01-11 16:35:55 +0000142 findSymbolInLogicalDylib(const std::string &Name) override {
143 return Resolver->findSymbolInLogicalDylib(Name);
144 }
145
146private:
147 std::unique_ptr<RuntimeDyld::MemoryManager> MemMgr;
Lang Hames156b9942018-01-19 22:24:13 +0000148 std::shared_ptr<LegacyJITSymbolResolver> Resolver;
Lang Hamesb20e09c2016-01-11 16:35:55 +0000149};
150}
151
152#endif