From: Sivaprasad Tummala Date: Mon, 22 Mar 2021 15:51:56 +0000 (+0530) Subject: tls: fix tlsopenssl for remaining buffer X-Git-Tag: v21.10-rc0~351 X-Git-Url: https://gerrit.fd.io/r/gitweb?a=commitdiff_plain;h=04161c8f201f95c8354fc583d67e808440d33b9d;p=vpp.git tls: fix tlsopenssl for remaining buffer Type: fix 1. added additional checks for pending data in openssl_ctx_read_tls(). 2. fixed read/write typo issues. Signed-off-by: Sivaprasad Tummala Change-Id: Id018c62bb9e02bf0d5f9abf929b6030b965a5d61 --- diff --git a/src/plugins/tlsopenssl/tls_openssl.c b/src/plugins/tlsopenssl/tls_openssl.c index c906d0e294a..a10372d1c9c 100644 --- a/src/plugins/tlsopenssl/tls_openssl.c +++ b/src/plugins/tlsopenssl/tls_openssl.c @@ -475,7 +475,7 @@ openssl_ctx_read_tls (tls_ctx_t *ctx, session_t *tls_session) { openssl_ctx_t *oc = (openssl_ctx_t *) ctx; session_t *app_session; - int read, wrote = 0; + int read; svm_fifo_t *f; if (PREDICT_FALSE (SSL_in_init (oc->ssl))) @@ -493,10 +493,11 @@ openssl_ctx_read_tls (tls_ctx_t *ctx, session_t *tls_session) if (read && app_session->session_state >= SESSION_STATE_READY) tls_notify_app_enqueue (ctx, app_session); - if (SSL_pending (oc->ssl) > 0) + if ((SSL_pending (oc->ssl) > 0) || + svm_fifo_max_dequeue_cons (tls_session->rx_fifo)) tls_add_vpp_q_builtin_rx_evt (tls_session); - return wrote; + return read; } static inline int