mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-23 06:43:04 +01:00
Fixed unexpected server exits. Slightly better diagnostics for them added.
This commit is contained in:
parent
73759d2d02
commit
627e7f2846
@ -1730,12 +1730,12 @@ static void cleanup_port( rem_port* port)
|
|||||||
delete port->port_queue;
|
delete port->port_queue;
|
||||||
port->port_que_sync->release();
|
port->port_que_sync->release();
|
||||||
#endif
|
#endif
|
||||||
port->port_sync->release();
|
|
||||||
|
|
||||||
#ifdef TRUSTED_AUTH
|
#ifdef TRUSTED_AUTH
|
||||||
delete port->port_trusted_auth;
|
delete port->port_trusted_auth;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
port->port_sync->release();
|
||||||
ALLR_free(port);
|
ALLR_free(port);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -3483,6 +3483,7 @@ static void unhook_disconnected_ports(rem_port* main_port)
|
|||||||
if (port->port_state == state_disconnected) {
|
if (port->port_state == state_disconnected) {
|
||||||
more = true;
|
more = true;
|
||||||
unhook_port(port, port->port_parent);
|
unhook_port(port, port->port_parent);
|
||||||
|
port->port_sync->leave();
|
||||||
cleanup_port(port);
|
cleanup_port(port);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -567,7 +567,10 @@ void SRVR_multi_thread( rem_port* main_port, USHORT flags)
|
|||||||
// gds__log("op=%d ds=%d", request->req_receive.p_operation, dataSize);
|
// gds__log("op=%d ds=%d", request->req_receive.p_operation, dataSize);
|
||||||
|
|
||||||
request->req_port = port;
|
request->req_port = port;
|
||||||
port->port_sync->leave();
|
if (portLocked)
|
||||||
|
{
|
||||||
|
port->port_sync->leave();
|
||||||
|
}
|
||||||
|
|
||||||
if (!link_request(port, request))
|
if (!link_request(port, request))
|
||||||
{
|
{
|
||||||
@ -596,6 +599,10 @@ void SRVR_multi_thread( rem_port* main_port, USHORT flags)
|
|||||||
}
|
}
|
||||||
catch (const Firebird::Exception& e)
|
catch (const Firebird::Exception& e)
|
||||||
{
|
{
|
||||||
|
gds__log("SRVR_multi_thread: shutting down due to unhandled exception");
|
||||||
|
Firebird::stuff_exception(status_vector, e);
|
||||||
|
gds__log_status(0, status_vector);
|
||||||
|
|
||||||
/* If we got as far as having a port allocated before the error, disconnect it
|
/* If we got as far as having a port allocated before the error, disconnect it
|
||||||
* gracefully.
|
* gracefully.
|
||||||
*/
|
*/
|
||||||
@ -610,7 +617,7 @@ void SRVR_multi_thread( rem_port* main_port, USHORT flags)
|
|||||||
|
|
||||||
/* To handle recursion within the error handler */
|
/* To handle recursion within the error handler */
|
||||||
try {
|
try {
|
||||||
Firebird::stuff_exception(status_vector, e);
|
|
||||||
/* If we have a port, request really should be non-null, but just in case ... */
|
/* If we have a port, request really should be non-null, but just in case ... */
|
||||||
if (request != NULL) {
|
if (request != NULL) {
|
||||||
/* Send client a real status indication of why we disconnected them */
|
/* Send client a real status indication of why we disconnected them */
|
||||||
|
Loading…
Reference in New Issue
Block a user