X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fplugins%2Ftlspicotls%2Ftls_picotls.c;h=d475e9cf71d0c04d9c4ae06d1bc615379935fd2c;hb=989c3c8fbd46ca0a8d9f6d6be3008e1285f3155e;hp=7f1979422fe6fdaec8091bccbe8c64cdd3aa425e;hpb=c95eefb393d05167ce6e35e5617179f536de0bda;p=vpp.git diff --git a/src/plugins/tlspicotls/tls_picotls.c b/src/plugins/tlspicotls/tls_picotls.c index 7f1979422fe..d475e9cf71d 100644 --- a/src/plugins/tlspicotls/tls_picotls.c +++ b/src/plugins/tlspicotls/tls_picotls.c @@ -206,7 +206,13 @@ picotls_transport_close (tls_ctx_t * ctx) static int picotls_app_close (tls_ctx_t * ctx) { - picotls_confirm_app_close (ctx); + session_t *app_session; + + app_session = session_get_from_handle (ctx->app_session_handle); + if (!svm_fifo_max_dequeue_cons (app_session->tx_fifo)) + picotls_confirm_app_close (ctx); + else + ctx->app_closed = 1; return 0; } @@ -492,6 +498,9 @@ picotls_ctx_write (tls_ctx_t * ctx, session_t * app_session) tls_add_vpp_q_tx_evt (tls_session); tls_add_vpp_q_builtin_tx_evt (app_session); + if (ctx->app_closed) + picotls_app_close (ctx); + return 0; }