From: Florin Coras Date: Mon, 26 Feb 2024 22:52:34 +0000 (-0800) Subject: session: fix transport closed and disconnect race X-Git-Tag: v24.10-rc0~206 X-Git-Url: https://gerrit.fd.io/r/gitweb?a=commitdiff_plain;h=refs%2Fchanges%2F98%2F40398%2F2;p=vpp.git session: fix transport closed and disconnect race Type: fix Signed-off-by: Florin Coras Change-Id: Ie7ff4bac22e9dbb449610072b52d1ec4e46fe757 --- diff --git a/src/vnet/session/session_input.c b/src/vnet/session/session_input.c index 9153f07070d..b403f7ddc4c 100644 --- a/src/vnet/session/session_input.c +++ b/src/vnet/session/session_input.c @@ -162,8 +162,10 @@ app_worker_flush_events_inline (app_worker_t *app_wrk, u32 thread_index, { if (old_state >= SESSION_STATE_TRANSPORT_CLOSING) { - session_set_state (s, old_state); - app_worker_close_notify (app_wrk, s); + session_set_state (s, + clib_max (old_state, s->session_state)); + if (!(s->flags & SESSION_F_APP_CLOSED)) + app->cb_fns.session_disconnect_callback (s); } } break; @@ -188,8 +190,9 @@ app_worker_flush_events_inline (app_worker_t *app_wrk, u32 thread_index, } if (old_state >= SESSION_STATE_TRANSPORT_CLOSING) { - session_set_state (s, old_state); - app_worker_close_notify (app_wrk, s); + session_set_state (s, clib_max (old_state, s->session_state)); + if (!(s->flags & SESSION_F_APP_CLOSED)) + app->cb_fns.session_disconnect_callback (s); } break; case SESSION_CTRL_EVT_DISCONNECTED: