From 9e204dc0236f3b1ac0fe19f08be6dd24ec1a73db Mon Sep 17 00:00:00 2001 From: Anthony Hu Date: Thu, 5 Sep 2024 15:09:54 -0400 Subject: [PATCH] Convert MATCH_SUITE_ERROR to OpenSSL error in wolfSSL_get_error() --- src/ssl.c | 4 ++-- tests/api.c | 22 ++++++++++++++++++++-- 2 files changed, 22 insertions(+), 4 deletions(-) diff --git a/src/ssl.c b/src/ssl.c index 12b71c2182..9cea805511 100644 --- a/src/ssl.c +++ b/src/ssl.c @@ -4133,10 +4133,10 @@ int wolfSSL_get_error(WOLFSSL* ssl, int ret) return WOLFSSL_ERROR_WANT_WRITE; /* convert to OpenSSL type */ else if (ssl->error == WC_NO_ERR_TRACE(ZERO_RETURN) || ssl->options.shutdownDone) - { return WOLFSSL_ERROR_ZERO_RETURN; /* convert to OpenSSL type */ - } #ifdef OPENSSL_EXTRA + else if (ssl->error == WC_NO_ERR_TRACE(MATCH_SUITE_ERROR)) + return WOLFSSL_ERROR_SYSCALL; /* convert to OpenSSL type */ else if (ssl->error == WC_NO_ERR_TRACE(SOCKET_PEER_CLOSED_E)) return WOLFSSL_ERROR_SYSCALL; /* convert to OpenSSL type */ #endif diff --git a/tests/api.c b/tests/api.c index b523b8ba93..45fb0ddf95 100644 --- a/tests/api.c +++ b/tests/api.c @@ -61312,11 +61312,23 @@ static int test_wolfSSL_curves_mismatch(void) #endif #ifndef WOLFSSL_NO_TLS12 {wolfTLSv1_2_client_method, wolfTLSv1_2_server_method, "TLS 1.2", - WC_NO_ERR_TRACE(FATAL_ERROR), WC_NO_ERR_TRACE(MATCH_SUITE_ERROR)}, + WC_NO_ERR_TRACE(FATAL_ERROR), +#ifdef OPENSSL_EXTRA + WC_NO_ERR_TRACE(WOLFSSL_ERROR_SYSCALL) +#else + WC_NO_ERR_TRACE(MATCH_SUITE_ERROR) +#endif + }, #endif #ifndef NO_OLD_TLS {wolfTLSv1_1_client_method, wolfTLSv1_1_server_method, "TLS 1.1", - WC_NO_ERR_TRACE(FATAL_ERROR), WC_NO_ERR_TRACE(MATCH_SUITE_ERROR)}, + WC_NO_ERR_TRACE(FATAL_ERROR), +#ifdef OPENSSL_EXTRA + WC_NO_ERR_TRACE(WOLFSSL_ERROR_SYSCALL) +#else + WC_NO_ERR_TRACE(MATCH_SUITE_ERROR) +#endif + }, #endif }; @@ -89952,8 +89964,14 @@ static int test_wrong_cs_downgrade(void) test_ctx.c_len = sizeof(test_wrong_cs_downgrade_sh); ExpectIntNE(wolfSSL_connect(ssl_c), WOLFSSL_SUCCESS); +#ifdef OPENSSL_EXTRA + ExpectIntEQ(wolfSSL_get_error(ssl_c, WC_NO_ERR_TRACE(WOLFSSL_FATAL_ERROR)), + WC_NO_ERR_TRACE(WOLFSSL_ERROR_SYSCALL)); +#else ExpectIntEQ(wolfSSL_get_error(ssl_c, WC_NO_ERR_TRACE(WOLFSSL_FATAL_ERROR)), WC_NO_ERR_TRACE(MATCH_SUITE_ERROR)); +#endif /* OPENSSL_EXTRA */ + wolfSSL_free(ssl_c); wolfSSL_CTX_free(ctx_c);