OSDN Git Service

[ORC] Break up OrcJIT library, add Orc-RPC based remote TargetProcessControl
authorLang Hames <lhames@gmail.com>
Wed, 11 Nov 2020 00:55:24 +0000 (11:55 +1100)
committerLang Hames <lhames@gmail.com>
Fri, 13 Nov 2020 06:05:13 +0000 (17:05 +1100)
commit1d0676b54c4e3a517719220def96dfdbc26d8048
treef24b68663907ac176127900f61477c50c8d1030e
parent9606ef03f03904cec213db031b5ea6fd6052dc5d
[ORC] Break up OrcJIT library, add Orc-RPC based remote TargetProcessControl
implementation.

This patch aims to improve support for out-of-process JITing using OrcV2. It
introduces two new class templates, OrcRPCTargetProcessControlBase and
OrcRPCTPCServer, which together implement the TargetProcessControl API by
forwarding operations to an execution process via an Orc-RPC Endpoint. These
utilities are used to implement out-of-process JITing from llvm-jitlink to
a new llvm-jitlink-executor tool.

This patch also breaks the OrcJIT library into three parts:
  -- OrcTargetProcess: Contains code needed by the JIT execution process.
  -- OrcShared: Contains code needed by the JIT execution and compiler
     processes
  -- OrcJIT: Everything else.

This break-up allows JIT executor processes to link against OrcTargetProcess
and OrcShared only, without having to link in all of OrcJIT. Clients executing
JIT'd code in-process should start linking against OrcTargetProcess as well as
OrcJIT.

In the near future these changes will enable:
  -- Removal of the OrcRemoteTargetClient/OrcRemoteTargetServer class templates
     which provided similar functionality in OrcV1.
  -- Restoration of Chapter 5 of the Building-A-JIT tutorial series, which will
     serve as a simple usage example for these APIs.
  -- Implementation of lazy, cross-target compilation in lli's -jit-kind=orc-lazy
     mode.
49 files changed:
llvm/examples/OrcV2Examples/LLJITWithTargetProcessControl/LLJITWithTargetProcessControl.cpp
llvm/include/llvm/ExecutionEngine/JITLink/EHFrameSupport.h
llvm/include/llvm/ExecutionEngine/JITLink/JITLink.h
llvm/include/llvm/ExecutionEngine/Orc/ExecutionUtils.h
llvm/include/llvm/ExecutionEngine/Orc/OrcRPCTargetProcessControl.h [new file with mode: 0644]
llvm/include/llvm/ExecutionEngine/Orc/RPC/FDRawByteChannel.h
llvm/include/llvm/ExecutionEngine/Orc/RPC/RPCSerialization.h
llvm/include/llvm/ExecutionEngine/Orc/Shared/TargetProcessControlTypes.h [new file with mode: 0644]
llvm/include/llvm/ExecutionEngine/Orc/TPCDynamicLibrarySearchGenerator.h
llvm/include/llvm/ExecutionEngine/Orc/TPCEHFrameRegistrar.h [new file with mode: 0644]
llvm/include/llvm/ExecutionEngine/Orc/TargetProcess/OrcRPCTPCServer.h [new file with mode: 0644]
llvm/include/llvm/ExecutionEngine/Orc/TargetProcess/RegisterEHFrames.h [new file with mode: 0644]
llvm/include/llvm/ExecutionEngine/Orc/TargetProcess/TargetExecutionUtils.h [new file with mode: 0644]
llvm/include/llvm/ExecutionEngine/Orc/TargetProcessControl.h
llvm/lib/ExecutionEngine/CMakeLists.txt
llvm/lib/ExecutionEngine/JITLink/CMakeLists.txt
llvm/lib/ExecutionEngine/JITLink/EHFrameSupport.cpp
llvm/lib/ExecutionEngine/JITLink/LLVMBuild.txt
llvm/lib/ExecutionEngine/LLVMBuild.txt
llvm/lib/ExecutionEngine/Orc/CMakeLists.txt
llvm/lib/ExecutionEngine/Orc/ExecutionUtils.cpp
llvm/lib/ExecutionEngine/Orc/LLVMBuild.txt
llvm/lib/ExecutionEngine/Orc/Shared/CMakeLists.txt [moved from llvm/lib/ExecutionEngine/OrcError/CMakeLists.txt with 60% similarity]
llvm/lib/ExecutionEngine/Orc/Shared/LLVMBuild.txt [moved from llvm/lib/ExecutionEngine/OrcError/LLVMBuild.txt with 83% similarity]
llvm/lib/ExecutionEngine/Orc/Shared/LLVMBuild.txt.rej [new file with mode: 0644]
llvm/lib/ExecutionEngine/Orc/Shared/OrcError.cpp [moved from llvm/lib/ExecutionEngine/OrcError/OrcError.cpp with 96% similarity]
llvm/lib/ExecutionEngine/Orc/Shared/RPCError.cpp [moved from llvm/lib/ExecutionEngine/OrcError/RPCError.cpp with 99% similarity]
llvm/lib/ExecutionEngine/Orc/Shared/TargetProcessControlTypes.cpp [new file with mode: 0644]
llvm/lib/ExecutionEngine/Orc/TPCDynamicLibrarySearchGenerator.cpp
llvm/lib/ExecutionEngine/Orc/TPCEHFrameRegistrar.cpp [new file with mode: 0644]
llvm/lib/ExecutionEngine/Orc/TPCIndirectionUtils.cpp
llvm/lib/ExecutionEngine/Orc/TargetProcess/CMakeLists.txt [new file with mode: 0644]
llvm/lib/ExecutionEngine/Orc/TargetProcess/LLVMBuild.txt [new file with mode: 0644]
llvm/lib/ExecutionEngine/Orc/TargetProcess/RegisterEHFrames.cpp [new file with mode: 0644]
llvm/lib/ExecutionEngine/Orc/TargetProcess/TargetExecutionUtils.cpp [new file with mode: 0644]
llvm/lib/ExecutionEngine/Orc/TargetProcessControl.cpp
llvm/tools/lli/CMakeLists.txt
llvm/tools/lli/ChildTarget/CMakeLists.txt
llvm/tools/lli/LLVMBuild.txt
llvm/tools/lli/lli.cpp
llvm/tools/llvm-jitlink/CMakeLists.txt
llvm/tools/llvm-jitlink/LLVMBuild.txt
llvm/tools/llvm-jitlink/llvm-jitlink-executor/CMakeLists.txt [new file with mode: 0644]
llvm/tools/llvm-jitlink/llvm-jitlink-executor/LLVMBuild.txt [new file with mode: 0644]
llvm/tools/llvm-jitlink/llvm-jitlink-executor/llvm-jitlink-executor.cpp [new file with mode: 0644]
llvm/tools/llvm-jitlink/llvm-jitlink.cpp
llvm/tools/llvm-jitlink/llvm-jitlink.h
llvm/unittests/ExecutionEngine/JITLink/CMakeLists.txt
llvm/unittests/ExecutionEngine/Orc/CMakeLists.txt