From 7c2a3357f32ae02bcc20cdad6d87beda39f71d31 Mon Sep 17 00:00:00 2001 From: Florin Coras Date: Tue, 26 Mar 2024 19:47:27 -0700 Subject: [PATCH] tls: init session for accepted ctx Make sure session is marked as invalid. Type: improvement Change-Id: I1c861645de95ef15a24acd4fe6dd5364a55b4fb8 Signed-off-by: Florin Coras --- src/vnet/tls/tls.c | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/vnet/tls/tls.c b/src/vnet/tls/tls.c index 996c20f2829..6129b09207b 100644 --- a/src/vnet/tls/tls.c +++ b/src/vnet/tls/tls.c @@ -486,24 +486,24 @@ tls_session_disconnect_callback (session_t * tls_session) } int -tls_session_accept_callback (session_t * tls_session) +tls_session_accept_callback (session_t *ts) { session_t *tls_listener; tls_ctx_t *lctx, *ctx; u32 ctx_handle; - tls_listener = - listen_session_get_from_handle (tls_session->listener_handle); + tls_listener = listen_session_get_from_handle (ts->listener_handle); lctx = tls_listener_ctx_get (tls_listener->opaque); ctx_handle = tls_ctx_alloc (lctx->tls_ctx_engine); ctx = tls_ctx_get (ctx_handle); clib_memcpy (ctx, lctx, sizeof (*lctx)); - ctx->c_thread_index = vlib_get_thread_index (); + ctx->c_s_index = SESSION_INVALID_INDEX; + ctx->c_thread_index = ts->thread_index; ctx->tls_ctx_handle = ctx_handle; - tls_session->session_state = SESSION_STATE_READY; - tls_session->opaque = ctx_handle; - ctx->tls_session_handle = session_handle (tls_session); + ts->session_state = SESSION_STATE_READY; + ts->opaque = ctx_handle; + ctx->tls_session_handle = session_handle (ts); ctx->listener_ctx_index = tls_listener->opaque; ctx->c_flags |= TRANSPORT_CONNECTION_F_NO_LOOKUP; ctx->ckpair_index = lctx->ckpair_index;