From 599a75e8a37bd0d9a4cf00331844f1e4360960b0 Mon Sep 17 00:00:00 2001 From: Kris Hung Date: Thu, 14 Dec 2023 16:12:13 -0800 Subject: [PATCH] Fix segfault for decoupled models (#327) (#328) * Set release flags and clean up response factory map before returning error * Address comments * Move the cleanup function to the outside scope * Delete response factory when response sender goes out of scope --- src/ipc_message.h | 2 +- src/pb_stub.cc | 2 +- src/python_be.cc | 18 +++++++++++++----- src/python_be.h | 5 +++-- src/response_sender.cc | 2 +- 5 files changed, 19 insertions(+), 10 deletions(-) diff --git a/src/ipc_message.h b/src/ipc_message.h index ac28238c..866070f6 100644 --- a/src/ipc_message.h +++ b/src/ipc_message.h @@ -55,7 +55,7 @@ typedef enum PYTHONSTUB_commandtype_enum { PYTHONSTUB_AutoCompleteResponse, PYTHONSTUB_LogRequest, PYTHONSTUB_BLSDecoupledInferPayloadCleanup, - PYTHONSTUB_DecoupledResponseFactoryCleanup, + PYTHONSTUB_BLSDecoupledResponseFactoryCleanup, PYTHONSTUB_MetricFamilyRequestNew, PYTHONSTUB_MetricFamilyRequestDelete, PYTHONSTUB_MetricRequestNew, diff --git a/src/pb_stub.cc b/src/pb_stub.cc index d1f8f6fd..53a6c540 100644 --- a/src/pb_stub.cc +++ b/src/pb_stub.cc @@ -997,7 +997,7 @@ Stub::ServiceStubToParentRequests() (utils_msg_payload->command_type == PYTHONSTUB_BLSDecoupledInferPayloadCleanup) || (utils_msg_payload->command_type == - PYTHONSTUB_DecoupledResponseFactoryCleanup)) { + PYTHONSTUB_BLSDecoupledResponseFactoryCleanup)) { SendCleanupId(utils_msg_payload, utils_msg_payload->command_type); } else if ( utils_msg_payload->command_type == PYTHONSTUB_IsRequestCancelled) { diff --git a/src/python_be.cc b/src/python_be.cc index 194e10a8..dc2f8df8 100644 --- a/src/python_be.cc +++ b/src/python_be.cc @@ -830,8 +830,8 @@ ModelInstanceState::StubToParentMQMonitor() break; } case PYTHONSTUB_BLSDecoupledInferPayloadCleanup: - case PYTHONSTUB_DecoupledResponseFactoryCleanup: { - ProcessCleanupRequest(message); + case PYTHONSTUB_BLSDecoupledResponseFactoryCleanup: { + ProcessBLSCleanupRequest(message); break; } case PYTHONSTUB_IsRequestCancelled: { @@ -928,9 +928,17 @@ ModelInstanceState::ProcessCleanupRequest( Stub()->ShmPool()->Load(message->Args()); CleanupMessage* cleanup_message_ptr = reinterpret_cast(cleanup_request_message.data_.get()); - - void* id = cleanup_message_ptr->id; - infer_payload_.erase(reinterpret_cast(id)); + intptr_t id = reinterpret_cast(cleanup_message_ptr->id); + if (message->Command() == PYTHONSTUB_BLSDecoupledInferPayloadCleanup) { + // Remove the InferPayload object from the map. + infer_payload_.erase(id); + } else if ( + message->Command() == PYTHONSTUB_BLSDecoupledResponseFactoryCleanup) { + // Delete response factory + std::unique_ptr< + TRITONBACKEND_ResponseFactory, backend::ResponseFactoryDeleter> + response_factory(reinterpret_cast(id)); + } { bi::scoped_lock lock{*(message->ResponseMutex())}; diff --git a/src/python_be.h b/src/python_be.h index f5620d07..e644e159 100644 --- a/src/python_be.h +++ b/src/python_be.h @@ -400,8 +400,9 @@ class ModelInstanceState : public BackendModelInstance { std::unique_ptr* infer_response, bi::managed_external_buffer::handle_t* response_handle); - // Process the decoupled cleanup request for InferPayload and ResponseFactory - void ProcessCleanupRequest(const std::unique_ptr& message); + // Process the bls decoupled cleanup request for InferPayload and + // ResponseFactory + void ProcessBLSCleanupRequest(const std::unique_ptr& message); // Process request cancellation query void ProcessIsRequestCancelled(const std::unique_ptr& message); diff --git a/src/response_sender.cc b/src/response_sender.cc index 94e3f0c8..fe06e554 100644 --- a/src/response_sender.cc +++ b/src/response_sender.cc @@ -50,7 +50,7 @@ ResponseSender::~ResponseSender() std::unique_ptr& stub = Stub::GetOrCreateInstance(); stub->EnqueueCleanupId( reinterpret_cast(response_factory_address_), - PYTHONSTUB_DecoupledResponseFactoryCleanup); + PYTHONSTUB_BLSDecoupledResponseFactoryCleanup); } void