mirror of
https://github.com/Mbed-TLS/mbedtls.git
synced 2025-07-29 11:41:15 +03:00
Refine ssl_get_kex_mode_str() for easy automatic generation
Signed-off-by: Xiaokang Qian <xiaokang.qian@arm.com>
This commit is contained in:
@ -1667,6 +1667,21 @@ cleanup:
|
|||||||
return( ret );
|
return( ret );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *ssl_get_kex_mode_str(int mode)
|
||||||
|
{
|
||||||
|
switch( mode )
|
||||||
|
{
|
||||||
|
case MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK:
|
||||||
|
return "psk";
|
||||||
|
case MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL:
|
||||||
|
return "ephemeral";
|
||||||
|
case MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL:
|
||||||
|
return "psk_ephemeral";
|
||||||
|
default:
|
||||||
|
return "unknown mode";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
MBEDTLS_CHECK_RETURN_CRITICAL
|
MBEDTLS_CHECK_RETURN_CRITICAL
|
||||||
static int ssl_tls13_postprocess_server_hello( mbedtls_ssl_context *ssl )
|
static int ssl_tls13_postprocess_server_hello( mbedtls_ssl_context *ssl )
|
||||||
{
|
{
|
||||||
@ -1706,27 +1721,19 @@ static int ssl_tls13_postprocess_server_hello( mbedtls_ssl_context *ssl )
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
MBEDTLS_SSL_DEBUG_MSG( 3,
|
|
||||||
( "Server selected key exchange mode: %s",
|
|
||||||
handshake->key_exchange_mode ==
|
|
||||||
MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK ? "psk" :
|
|
||||||
(handshake->key_exchange_mode ==
|
|
||||||
MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL ? "ephemeral" :
|
|
||||||
"psk_ephemeral")) );
|
|
||||||
|
|
||||||
if( !mbedtls_ssl_conf_tls13_check_kex_modes( ssl, handshake->key_exchange_mode ) )
|
if( !mbedtls_ssl_conf_tls13_check_kex_modes( ssl, handshake->key_exchange_mode ) )
|
||||||
{
|
{
|
||||||
ret = MBEDTLS_ERR_SSL_HANDSHAKE_FAILURE;
|
ret = MBEDTLS_ERR_SSL_HANDSHAKE_FAILURE;
|
||||||
MBEDTLS_SSL_DEBUG_MSG( 2,
|
MBEDTLS_SSL_DEBUG_MSG( 2,
|
||||||
( "Not supported kex mode in client: %s",
|
( "Key exchange mode(%s) is not configured supported.",
|
||||||
handshake->key_exchange_mode ==
|
ssl_get_kex_mode_str( handshake->key_exchange_mode ) ) );
|
||||||
MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK ? "psk" :
|
|
||||||
(handshake->key_exchange_mode ==
|
|
||||||
MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL ? "ephemeral" :
|
|
||||||
"psk_ephemeral")) );
|
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MBEDTLS_SSL_DEBUG_MSG( 3,
|
||||||
|
( "Server selected key exchange mode: %s",
|
||||||
|
ssl_get_kex_mode_str( handshake->key_exchange_mode ) ) );
|
||||||
|
|
||||||
/* Start the TLS 1.3 key schedule: Set the PSK and derive early secret.
|
/* Start the TLS 1.3 key schedule: Set the PSK and derive early secret.
|
||||||
*
|
*
|
||||||
* TODO: We don't have to do this in case we offered 0-RTT and the
|
* TODO: We don't have to do this in case we offered 0-RTT and the
|
||||||
|
Reference in New Issue
Block a user