X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Ftls%2Ftls.c;h=257f48cd9ba1be190ed0f8b8559ac993117f44f7;hb=837826169fd51c1d2bb7703e479447f5d4ffa9a5;hp=8359cca5c0047293f293fc8fc0439aabf3b0ef08;hpb=f4a92f6a1cf6b27318b6819ad3145b4020a27779;p=vpp.git diff --git a/src/vnet/tls/tls.c b/src/vnet/tls/tls.c index 8359cca5c00..257f48cd9ba 100644 --- a/src/vnet/tls/tls.c +++ b/src/vnet/tls/tls.c @@ -252,8 +252,6 @@ tls_notify_app_connected (tls_ctx_t * ctx, u8 is_failed) ctx->app_session_handle = session_handle (app_session); app_session->session_state = SESSION_STATE_READY; - session_lookup_add_connection (&ctx->connection, - session_handle (app_session)); return 0; @@ -360,15 +358,22 @@ tls_session_reset_callback (session_t * s) session_t *app_session; ctx = tls_ctx_get (s->opaque); + ctx->is_passive_close = 1; tc = &ctx->connection; if (tls_ctx_handshake_is_over (ctx)) { session_transport_reset_notify (tc); session_transport_closed_notify (tc); + tls_disconnect_transport (ctx); + } + else + if ((app_session = + session_get_if_valid (ctx->c_s_index, ctx->c_thread_index))) + { + session_free (app_session); + ctx->c_s_index = SESSION_INVALID_INDEX; + tls_disconnect_transport (ctx); } - else if ((app_session = session_get (tc->s_index, tc->thread_index))) - session_free (app_session); - tls_disconnect_transport (ctx); } int