From a08e2c9f90fad358c3ffe28b2ab537a9ab53aaed Mon Sep 17 00:00:00 2001 From: Azat Khuzhin Date: Mon, 1 Jul 2024 11:32:42 +0200 Subject: [PATCH] Fix calling wait_io_or_timeout() (pass is_read properly for writes) --- libmariadb/secure/gnutls.c | 2 +- libmariadb/secure/openssl.c | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/libmariadb/secure/gnutls.c b/libmariadb/secure/gnutls.c index 0d40746ea..fc16bf1d7 100644 --- a/libmariadb/secure/gnutls.c +++ b/libmariadb/secure/gnutls.c @@ -1332,7 +1332,7 @@ ssize_t ma_tls_write(MARIADB_TLS *ctls, const uchar* buffer, size_t length) { if (rc != GNUTLS_E_AGAIN && rc != GNUTLS_E_INTERRUPTED) break; - if (pvio->methods->wait_io_or_timeout(pvio, TRUE, pvio->mysql->options.write_timeout) < 1) + if (pvio->methods->wait_io_or_timeout(pvio, FALSE, pvio->mysql->options.write_timeout) < 1) break; } if (rc <= 0) { diff --git a/libmariadb/secure/openssl.c b/libmariadb/secure/openssl.c index 828c3121f..bc6b7c34d 100644 --- a/libmariadb/secure/openssl.c +++ b/libmariadb/secure/openssl.c @@ -498,7 +498,7 @@ my_bool ma_tls_connect(MARIADB_TLS *ctls) try_connect= 0; break; case SSL_ERROR_WANT_WRITE: - if (pvio->methods->wait_io_or_timeout(pvio, TRUE, mysql->options.connect_timeout) < 1) + if (pvio->methods->wait_io_or_timeout(pvio, FALSE, mysql->options.connect_timeout) < 1) try_connect= 0; break; default: @@ -656,7 +656,7 @@ ssize_t ma_tls_write(MARIADB_TLS *ctls, const uchar* buffer, size_t length) int error= SSL_get_error((SSL *)ctls->ssl, rc); if (error != SSL_ERROR_WANT_WRITE) break; - if (pvio->methods->wait_io_or_timeout(pvio, TRUE, pvio->mysql->options.write_timeout) < 1) + if (pvio->methods->wait_io_or_timeout(pvio, FALSE, pvio->mysql->options.write_timeout) < 1) break; } if (rc <= 0)