Skip to content

Commit

Permalink
Fix compile errors without 0-RTT, MPS and compatible mode
Browse files Browse the repository at this point in the history
When unset 0-RTT,MPS and TLS13_COMPATIBLE, it report
compile fail

Change-Id: If17515992b773b1b7faa1c3f9134f489c817c02a
Signed-off-by: Jerry Yu <jerry.h.yu@arm.com>
  • Loading branch information
yuhaoth committed Aug 13, 2021
1 parent 0e230ea commit e6d7861
Show file tree
Hide file tree
Showing 4 changed files with 34 additions and 17 deletions.
5 changes: 3 additions & 2 deletions include/mbedtls/ssl.h
Original file line number Diff line number Diff line change
Expand Up @@ -648,8 +648,10 @@ typedef enum
MBEDTLS_SSL_HELLO_RETRY_REQUEST,
MBEDTLS_SSL_SECOND_CLIENT_HELLO,
MBEDTLS_SSL_SECOND_SERVER_HELLO,
MBEDTLS_SSL_EARLY_DATA,
#if defined(MBEDTLS_ZERO_RTT)
MBEDTLS_SSL_EARLY_APP_DATA,
MBEDTLS_SSL_END_OF_EARLY_DATA,
#endif
MBEDTLS_SSL_CLIENT_CERTIFICATE_VERIFY,
MBEDTLS_SSL_ENCRYPTED_EXTENSIONS,
MBEDTLS_SSL_HANDSHAKE_FINISH_ACK,
Expand All @@ -661,7 +663,6 @@ typedef enum
MBEDTLS_SSL_SERVER_CCS_AFTER_SERVER_HELLO,
MBEDTLS_SSL_SERVER_CCS_AFTER_HRR,
#endif /* MBEDTLS_SSL_TLS13_COMPATIBILITY_MODE */
MBEDTLS_SSL_EARLY_APP_DATA
#endif
}
mbedtls_ssl_states;
Expand Down
12 changes: 10 additions & 2 deletions library/ssl_tls13_client.c
Original file line number Diff line number Diff line change
Expand Up @@ -176,10 +176,13 @@ int ssl_write_early_data_process( mbedtls_ssl_context* ssl )
#endif /* MBEDTLS_SSL_USE_MPS */

#else /* MBEDTLS_ZERO_RTT */

#if defined(MBEDTLS_SSL_USE_MPS)
((void) buf);
((void) buf_len);
((void) msg);
((void) msg_len);
#endif
/* Should never happen */
return( MBEDTLS_ERR_SSL_INTERNAL_ERROR );

Expand Down Expand Up @@ -1404,8 +1407,10 @@ static int ssl_client_hello_postprocess( mbedtls_ssl_context* ssl )
{
#if defined(MBEDTLS_SSL_TLS13_COMPATIBILITY_MODE)
mbedtls_ssl_handshake_set_state( ssl, MBEDTLS_SSL_CLIENT_CCS_AFTER_CLIENT_HELLO );
#else
#elif defined(MBEDTLS_ZERO_RTT)
mbedtls_ssl_handshake_set_state( ssl, MBEDTLS_SSL_EARLY_APP_DATA );
#else /* MBEDTLS_ZERO_RTT */
mbedtls_ssl_handshake_set_state( ssl, MBEDTLS_SSL_SERVER_HELLO );
#endif /* MBEDTLS_SSL_TLS13_COMPATIBILITY_MODE */

return( 0 );
Expand Down Expand Up @@ -3943,9 +3948,11 @@ int mbedtls_ssl_handshake_client_step_tls1_3( mbedtls_ssl_context *ssl )
ret = ssl_client_hello_process( ssl );
break;

#if defined(MBEDTLS_ZERO_RTT)
case MBEDTLS_SSL_EARLY_APP_DATA:
ret = ssl_write_early_data_process( ssl );
break;
#endif

/*
* <== ServerHello / HelloRetryRequest
Expand Down Expand Up @@ -3985,10 +3992,11 @@ int mbedtls_ssl_handshake_client_step_tls1_3( mbedtls_ssl_context *ssl )
* (CertificateVerify)
* (Finished)
*/
#if defined(MBEDTLS_ZERO_RTT)
case MBEDTLS_SSL_END_OF_EARLY_DATA:
ret = ssl_write_end_of_early_data_process( ssl );
break;

#endif
case MBEDTLS_SSL_CLIENT_CERTIFICATE:
ret = mbedtls_ssl_write_certificate_process( ssl );
break;
Expand Down
9 changes: 8 additions & 1 deletion library/ssl_tls13_generic.c
Original file line number Diff line number Diff line change
Expand Up @@ -2267,8 +2267,11 @@ static int ssl_finished_out_postprocess( mbedtls_ssl_context* ssl )
if( ret != 0 )
return( ret );
#endif /* MBEDTLS_SSL_USE_MPS */

#if defined(MBEDTLS_ZERO_RTT)
mbedtls_ssl_handshake_set_state( ssl, MBEDTLS_SSL_EARLY_APP_DATA );
#else
mbedtls_ssl_handshake_set_state( ssl, MBEDTLS_SSL_CLIENT_CERTIFICATE );
#endif
}
else
#endif /* MBEDTLS_SSL_SRV_C */
Expand Down Expand Up @@ -2456,7 +2459,11 @@ static int ssl_finished_in_postprocess_cli( mbedtls_ssl_context *ssl )
return( ret );
#endif /* MBEDTLS_SSL_USE_MPS */

#if defined(MBEDTLS_ZERO_RTT)
mbedtls_ssl_handshake_set_state( ssl, MBEDTLS_SSL_END_OF_EARLY_DATA );
#else
mbedtls_ssl_handshake_set_state( ssl, MBEDTLS_SSL_CLIENT_CERTIFICATE );
#endif
return( 0 );
}
#endif /* MBEDTLS_SSL_CLI_C */
Expand Down
25 changes: 13 additions & 12 deletions library/ssl_tls13_server.c
Original file line number Diff line number Diff line change
Expand Up @@ -1802,7 +1802,6 @@ static int ssl_early_data_fetch( mbedtls_ssl_context* ssl,
#endif /* MBEDTLS_SSL_USE_MPS */
#endif /* MBEDTLS_ZERO_RTT */

static int ssl_read_early_data_coordinate( mbedtls_ssl_context* ssl );

#if defined(MBEDTLS_ZERO_RTT)
/* Parse early data send by the peer. */
Expand All @@ -1811,6 +1810,9 @@ static int ssl_read_early_data_parse( mbedtls_ssl_context* ssl,
size_t buflen );
#endif /* MBEDTLS_ZERO_RTT */

#if defined(MBEDTLS_ZERO_RTT)
static int ssl_read_early_data_coordinate( mbedtls_ssl_context* ssl );

/* Update the state after handling the incoming early data message. */
static int ssl_read_early_data_postprocess( mbedtls_ssl_context* ssl );

Expand Down Expand Up @@ -1871,7 +1873,7 @@ int ssl_read_early_data_process( mbedtls_ssl_context* ssl )
MBEDTLS_SSL_DEBUG_MSG( 2, ( "<= parse early data" ) );
return( ret );
}

#endif
#if defined(MBEDTLS_ZERO_RTT)
#if defined(MBEDTLS_SSL_USE_MPS)
static int ssl_early_data_fetch( mbedtls_ssl_context *ssl,
Expand Down Expand Up @@ -1920,13 +1922,7 @@ static int ssl_early_data_fetch( mbedtls_ssl_context *ssl,
#endif /* MBEDTLS_SSL_USE_MPS */
#endif /* MBEDTLS_ZERO_RTT */

#if !defined(MBEDTLS_ZERO_RTT)
static int ssl_read_early_data_coordinate( mbedtls_ssl_context* ssl )
{
((void) ssl);
return( SSL_EARLY_DATA_SKIP );
}
#else /* MBEDTLS_ZERO_RTT */
#if defined(MBEDTLS_ZERO_RTT)
static int ssl_read_early_data_coordinate( mbedtls_ssl_context* ssl )
{
int ret;
Expand Down Expand Up @@ -2000,12 +1996,13 @@ static int ssl_read_early_data_parse( mbedtls_ssl_context* ssl,
}
#endif /* MBEDTLS_ZERO_RTT */

#if defined(MBEDTLS_ZERO_RTT)
static int ssl_read_early_data_postprocess( mbedtls_ssl_context* ssl )
{
mbedtls_ssl_handshake_set_state( ssl, MBEDTLS_SSL_END_OF_EARLY_DATA );
return ( 0 );
}

#endif

/*
*
Expand Down Expand Up @@ -3929,7 +3926,9 @@ int mbedtls_ssl_handshake_server_step_tls1_3( mbedtls_ssl_context *ssl )

break;

/* ----- WRITE EARLY APP DATA ----*/

#if defined(MBEDTLS_ZERO_RTT)
/* ----- WRITE EARLY APP DATA ----*/
case MBEDTLS_SSL_EARLY_APP_DATA:

ret = ssl_read_early_data_process( ssl );
Expand All @@ -3940,7 +3939,7 @@ int mbedtls_ssl_handshake_server_step_tls1_3( mbedtls_ssl_context *ssl )
}

break;

#endif
/* ----- WRITE HELLO RETRY REQUEST ----*/

case MBEDTLS_SSL_HELLO_RETRY_REQUEST:
Expand Down Expand Up @@ -4062,9 +4061,11 @@ int mbedtls_ssl_handshake_server_step_tls1_3( mbedtls_ssl_context *ssl )
ret = mbedtls_ssl_read_certificate_verify_process( ssl );
break;

#if defined(MBEDTLS_ZERO_RTT)
case MBEDTLS_SSL_END_OF_EARLY_DATA:
ret = ssl_read_end_of_early_data_process( ssl );
break;
#endif

/* ----- READ FINISHED ----*/

Expand Down

0 comments on commit e6d7861

Please sign in to comment.