From b380acc47c443f26d6b77dc0476272df66982feb Mon Sep 17 00:00:00 2001 From: AlexPeshkoff Date: Mon, 31 May 2021 19:40:45 +0300 Subject: [PATCH] Fix for #6836 - fb_shutdown() does not wait for self completion in other thread --- src/yvalve/why.cpp | 13 ++++--------- 1 file changed, 4 insertions(+), 9 deletions(-) diff --git a/src/yvalve/why.cpp b/src/yvalve/why.cpp index e0a096f2a5..1bb191e629 100644 --- a/src/yvalve/why.cpp +++ b/src/yvalve/why.cpp @@ -3673,15 +3673,6 @@ ISC_STATUS API_ROUTINE isc_unwind_request(ISC_STATUS* userStatus, isc_req_handle // Shutdown firebird. int API_ROUTINE fb_shutdown(unsigned int timeout, const int reason) { - if (reason == fb_shutrsn_emergency) - { - shutdownStarted = true; - abortShutdown(); - } - - if (shutdownStarted) - return FB_SUCCESS; - StatusVector status(NULL); CheckStatusWrapper statusWrapper(&status); @@ -6422,6 +6413,10 @@ YService* Dispatcher::attachServiceManager(CheckStatusWrapper* status, const cha void Dispatcher::shutdown(CheckStatusWrapper* userStatus, unsigned int timeout, const int reason) { + // set "process exiting" state + if (reason == fb_shutrsn_emergency) + abortShutdown(); + // can't syncronize with already killed threads, just exit if (MasterInterfacePtr()->getProcessExiting()) return;