mirror of
https://github.com/yuzu-emu/mbedtls.git
synced 2025-01-24 14:41:11 +00:00
Dont send alert on invalid DTLS record type
Do not send fatal alerts when receiving a record with an invalid header while running DTLS as this is not compliant behaviour.
This commit is contained in:
parent
1fe5e8ab44
commit
1042d8637c
|
@ -3458,7 +3458,6 @@ static int ssl_handle_possible_reconnect( mbedtls_ssl_context *ssl )
|
||||||
*/
|
*/
|
||||||
static int ssl_parse_record_header( mbedtls_ssl_context *ssl )
|
static int ssl_parse_record_header( mbedtls_ssl_context *ssl )
|
||||||
{
|
{
|
||||||
int ret;
|
|
||||||
int major_ver, minor_ver;
|
int major_ver, minor_ver;
|
||||||
|
|
||||||
MBEDTLS_SSL_DEBUG_BUF( 4, "input record header", ssl->in_hdr, mbedtls_ssl_hdr_len( ssl ) );
|
MBEDTLS_SSL_DEBUG_BUF( 4, "input record header", ssl->in_hdr, mbedtls_ssl_hdr_len( ssl ) );
|
||||||
|
@ -3480,12 +3479,13 @@ static int ssl_parse_record_header( mbedtls_ssl_context *ssl )
|
||||||
{
|
{
|
||||||
MBEDTLS_SSL_DEBUG_MSG( 1, ( "unknown record type" ) );
|
MBEDTLS_SSL_DEBUG_MSG( 1, ( "unknown record type" ) );
|
||||||
|
|
||||||
if( ( ret = mbedtls_ssl_send_alert_message( ssl,
|
#if defined(MBEDTLS_SSL_PROTO_DTLS)
|
||||||
MBEDTLS_SSL_ALERT_LEVEL_FATAL,
|
/* Silently ignore invalid DTLS records as recommended by RFC 6347
|
||||||
MBEDTLS_SSL_ALERT_MSG_UNEXPECTED_MESSAGE ) ) != 0 )
|
* Section 4.1.2.7 */
|
||||||
{
|
if( ssl->conf->transport != MBEDTLS_SSL_TRANSPORT_DATAGRAM )
|
||||||
return( ret );
|
#endif /* MBEDTLS_SSL_PROTO_DTLS */
|
||||||
}
|
mbedtls_ssl_send_alert_message( ssl, MBEDTLS_SSL_ALERT_LEVEL_FATAL,
|
||||||
|
MBEDTLS_SSL_ALERT_MSG_UNEXPECTED_MESSAGE );
|
||||||
|
|
||||||
return( MBEDTLS_ERR_SSL_INVALID_RECORD );
|
return( MBEDTLS_ERR_SSL_INVALID_RECORD );
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue