diff options
author | Lang Hames <lhames@gmail.com> | 2021-06-16 21:58:26 +1000 |
---|---|---|
committer | Lang Hames <lhames@gmail.com> | 2021-06-17 13:27:09 +1000 |
commit | 838490de7ede2a144094fa0f98cd91d8851d7e3d (patch) | |
tree | 7e9e9b73dd50a08a0741da4b066ad6c732ca4bd9 | |
parent | 6a071e535fa43db038ea1a9329ebdeede3db31f9 (diff) | |
download | llvm-838490de7ede2a144094fa0f98cd91d8851d7e3d.zip llvm-838490de7ede2a144094fa0f98cd91d8851d7e3d.tar.gz llvm-838490de7ede2a144094fa0f98cd91d8851d7e3d.tar.bz2 |
[ORC] Switch from uint8_t to char buffers for TargetProcessControl::runWrapper.
This matches WrapperFunctionResult's char buffer, cutting down on the number of
pointer casts needed.
5 files changed, 15 insertions, 16 deletions
diff --git a/llvm/include/llvm/ExecutionEngine/Orc/OrcRPCTargetProcessControl.h b/llvm/include/llvm/ExecutionEngine/Orc/OrcRPCTargetProcessControl.h index 6ccc90e..708612e 100644 --- a/llvm/include/llvm/ExecutionEngine/Orc/OrcRPCTargetProcessControl.h +++ b/llvm/include/llvm/ExecutionEngine/Orc/OrcRPCTargetProcessControl.h @@ -356,7 +356,7 @@ public: Expected<shared::WrapperFunctionResult> runWrapper(JITTargetAddress WrapperFnAddr, - ArrayRef<uint8_t> ArgBuffer) override { + ArrayRef<char> ArgBuffer) override { DEBUG_WITH_TYPE("orc", { dbgs() << "Running as wrapper function " << formatv("{0:x16}", WrapperFnAddr) << " with " diff --git a/llvm/include/llvm/ExecutionEngine/Orc/Shared/Serialization.h b/llvm/include/llvm/ExecutionEngine/Orc/Shared/Serialization.h index 0ea483b..849c947 100644 --- a/llvm/include/llvm/ExecutionEngine/Orc/Shared/Serialization.h +++ b/llvm/include/llvm/ExecutionEngine/Orc/Shared/Serialization.h @@ -58,6 +58,11 @@ public: static const char *getName() { return "void"; } }; +template <> class SerializationTypeName<char> { +public: + static const char *getName() { return "char"; } +}; + template <> class SerializationTypeName<int8_t> { public: static const char *getName() { return "int8_t"; } diff --git a/llvm/include/llvm/ExecutionEngine/Orc/TargetProcess/OrcRPCTPCServer.h b/llvm/include/llvm/ExecutionEngine/Orc/TargetProcess/OrcRPCTPCServer.h index 458947c..9be6093 100644 --- a/llvm/include/llvm/ExecutionEngine/Orc/TargetProcess/OrcRPCTPCServer.h +++ b/llvm/include/llvm/ExecutionEngine/Orc/TargetProcess/OrcRPCTPCServer.h @@ -358,7 +358,7 @@ public: class RunWrapper : public shared::RPCFunction<RunWrapper, shared::WrapperFunctionResult( - JITTargetAddress, std::vector<uint8_t>)> { + JITTargetAddress, std::vector<char>)> { public: static const char *getName() { return "RunWrapper"; } }; @@ -580,14 +580,12 @@ private: ProgramNameOverride); } - shared::WrapperFunctionResult - runWrapper(JITTargetAddress WrapperFnAddr, - const std::vector<uint8_t> &ArgBuffer) { + shared::WrapperFunctionResult runWrapper(JITTargetAddress WrapperFnAddr, + const std::vector<char> &ArgBuffer) { using WrapperFnTy = shared::detail::CWrapperFunctionResult (*)( const char *Data, uint64_t Size); auto *WrapperFn = jitTargetAddressToFunction<WrapperFnTy>(WrapperFnAddr); - return WrapperFn(reinterpret_cast<const char *>(ArgBuffer.data()), - ArgBuffer.size()); + return WrapperFn(ArgBuffer.data(), ArgBuffer.size()); } void closeConnection() { Finished = true; } diff --git a/llvm/include/llvm/ExecutionEngine/Orc/TargetProcessControl.h b/llvm/include/llvm/ExecutionEngine/Orc/TargetProcessControl.h index edc7952..a39495f 100644 --- a/llvm/include/llvm/ExecutionEngine/Orc/TargetProcessControl.h +++ b/llvm/include/llvm/ExecutionEngine/Orc/TargetProcessControl.h @@ -145,7 +145,7 @@ public: /// \endcode{.cpp} /// virtual Expected<shared::WrapperFunctionResult> - runWrapper(JITTargetAddress WrapperFnAddr, ArrayRef<uint8_t> ArgBuffer) = 0; + runWrapper(JITTargetAddress WrapperFnAddr, ArrayRef<char> ArgBuffer) = 0; /// Disconnect from the target process. /// @@ -170,9 +170,7 @@ public: : TPC(TPC), WrapperFnAddr(WrapperFnAddr) {} Expected<shared::WrapperFunctionResult> operator()(const char *ArgData, size_t ArgSize) const { - return TPC.runWrapper( - WrapperFnAddr, - ArrayRef<uint8_t>(reinterpret_cast<const uint8_t *>(ArgData), ArgSize)); + return TPC.runWrapper(WrapperFnAddr, ArrayRef<char>(ArgData, ArgSize)); } private: @@ -204,8 +202,7 @@ public: ArrayRef<std::string> Args) override; Expected<shared::WrapperFunctionResult> - runWrapper(JITTargetAddress WrapperFnAddr, - ArrayRef<uint8_t> ArgBuffer) override; + runWrapper(JITTargetAddress WrapperFnAddr, ArrayRef<char> ArgBuffer) override; Error disconnect() override; diff --git a/llvm/lib/ExecutionEngine/Orc/TargetProcessControl.cpp b/llvm/lib/ExecutionEngine/Orc/TargetProcessControl.cpp index 240adb4..bc5cff4 100644 --- a/llvm/lib/ExecutionEngine/Orc/TargetProcessControl.cpp +++ b/llvm/lib/ExecutionEngine/Orc/TargetProcessControl.cpp @@ -104,12 +104,11 @@ SelfTargetProcessControl::runAsMain(JITTargetAddress MainFnAddr, Expected<shared::WrapperFunctionResult> SelfTargetProcessControl::runWrapper(JITTargetAddress WrapperFnAddr, - ArrayRef<uint8_t> ArgBuffer) { + ArrayRef<char> ArgBuffer) { using WrapperFnTy = shared::detail::CWrapperFunctionResult (*)( const char *Data, uint64_t Size); auto *WrapperFn = jitTargetAddressToFunction<WrapperFnTy>(WrapperFnAddr); - return WrapperFn(reinterpret_cast<const char *>(ArgBuffer.data()), - ArgBuffer.size()); + return WrapperFn(ArgBuffer.data(), ArgBuffer.size()); } Error SelfTargetProcessControl::disconnect() { return Error::success(); } |