mirror of
https://github.com/yuzu-emu/mbedtls.git
synced 2025-01-20 18:11:00 +00:00
Merge pull request #3724 from AndrzejKurek/transform-cipher-optimization-2
Add hash calculation to the ssl module
This commit is contained in:
commit
2544cd3582
|
@ -138,6 +138,7 @@
|
||||||
|
|
||||||
#define MBEDTLS_OID_C
|
#define MBEDTLS_OID_C
|
||||||
#define MBEDTLS_PLATFORM_C
|
#define MBEDTLS_PLATFORM_C
|
||||||
|
#define MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY
|
||||||
#define MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY
|
#define MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY
|
||||||
|
|
||||||
/* I/O buffer configuration */
|
/* I/O buffer configuration */
|
||||||
|
|
|
@ -677,6 +677,11 @@
|
||||||
#error "MBEDTLS_ARC4_C cannot be defined with MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS on"
|
#error "MBEDTLS_ARC4_C cannot be defined with MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS on"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY) && !defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS) && \
|
||||||
|
defined(MBEDTLS_ARC4_C)
|
||||||
|
#error "MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY requires MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS to be defined."
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(MBEDTLS_SSL_TLS_C) && (defined(MBEDTLS_SSL_PROTO_SSL3) && \
|
#if defined(MBEDTLS_SSL_TLS_C) && (defined(MBEDTLS_SSL_PROTO_SSL3) && \
|
||||||
defined(MBEDTLS_SSL_PROTO_TLS1_1) && !defined(MBEDTLS_SSL_PROTO_TLS1))
|
defined(MBEDTLS_SSL_PROTO_TLS1_1) && !defined(MBEDTLS_SSL_PROTO_TLS1))
|
||||||
#error "Illegal protocol selection"
|
#error "Illegal protocol selection"
|
||||||
|
|
|
@ -2739,6 +2739,18 @@
|
||||||
*/
|
*/
|
||||||
//#define MBEDTLS_CRC_C
|
//#define MBEDTLS_CRC_C
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \def MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY
|
||||||
|
*
|
||||||
|
* Enable validation of ssl keys by checking their hash
|
||||||
|
* during every encryption/decryption.
|
||||||
|
*
|
||||||
|
* Module: library/ssl_tls.c
|
||||||
|
*
|
||||||
|
* Requires: MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS
|
||||||
|
*/
|
||||||
|
//#define MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \def MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY
|
* \def MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY
|
||||||
*
|
*
|
||||||
|
|
|
@ -340,6 +340,18 @@ struct tm *mbedtls_platform_gmtime_r( const mbedtls_time_t *tt,
|
||||||
struct tm *tm_buf );
|
struct tm *tm_buf );
|
||||||
#endif /* MBEDTLS_HAVE_TIME_DATE */
|
#endif /* MBEDTLS_HAVE_TIME_DATE */
|
||||||
|
|
||||||
|
#if defined(MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY) || defined(MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY)
|
||||||
|
/**
|
||||||
|
* \brief Calculate a hash from the given data.
|
||||||
|
*
|
||||||
|
* \param data Data from which the hash is calculated.
|
||||||
|
* \param data_len_bytes Length of the data in bytes.
|
||||||
|
*
|
||||||
|
* \return A hash calculated from the provided data.
|
||||||
|
*/
|
||||||
|
uint32_t mbedtls_hash( const void *data, size_t data_len_bytes );
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Convert a 32-bit number to the big endian format and write it to
|
* \brief Convert a 32-bit number to the big endian format and write it to
|
||||||
* the given buffer.
|
* the given buffer.
|
||||||
|
|
|
@ -760,7 +760,11 @@ struct mbedtls_ssl_transform
|
||||||
unsigned char *key_enc;
|
unsigned char *key_enc;
|
||||||
unsigned char *key_dec;
|
unsigned char *key_dec;
|
||||||
unsigned int key_bitlen;
|
unsigned int key_bitlen;
|
||||||
mbedtls_cipher_context_t cipher_ctx; /*!< encryption/decryption context */
|
mbedtls_cipher_context_t cipher_ctx; /*!< encryption/decryption context */
|
||||||
|
#if defined(MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY)
|
||||||
|
uint32_t key_enc_hash; /*!< hash of the encryption key */
|
||||||
|
uint32_t key_dec_hash; /*!< hash of the decryption key */
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
mbedtls_cipher_context_t cipher_ctx_enc; /*!< encryption context */
|
mbedtls_cipher_context_t cipher_ctx_enc; /*!< encryption context */
|
||||||
mbedtls_cipher_context_t cipher_ctx_dec; /*!< decryption context */
|
mbedtls_cipher_context_t cipher_ctx_dec; /*!< decryption context */
|
||||||
|
|
|
@ -85,19 +85,6 @@
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY)
|
|
||||||
static uint32_t mbedtls_hash( const void *data, size_t data_len_bytes )
|
|
||||||
{
|
|
||||||
uint32_t result = 0;
|
|
||||||
size_t i;
|
|
||||||
/* data_len_bytes - only multiples of 4 are considered, rest is truncated */
|
|
||||||
for( i = 0; i < data_len_bytes >> 2; i++ )
|
|
||||||
{
|
|
||||||
result ^= ( (uint32_t*) data )[i];
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
/*
|
/*
|
||||||
* Data structure for AES round data
|
* Data structure for AES round data
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -186,6 +186,7 @@ int mbedtls_cipher_setup( mbedtls_cipher_context_t *ctx, const mbedtls_cipher_in
|
||||||
return( MBEDTLS_ERR_CIPHER_BAD_INPUT_DATA );
|
return( MBEDTLS_ERR_CIPHER_BAD_INPUT_DATA );
|
||||||
|
|
||||||
mbedtls_platform_memset( ctx, 0, sizeof( mbedtls_cipher_context_t ) );
|
mbedtls_platform_memset( ctx, 0, sizeof( mbedtls_cipher_context_t ) );
|
||||||
|
ctx->operation = MBEDTLS_OPERATION_NONE;
|
||||||
|
|
||||||
if( NULL == ( ctx->cipher_ctx = cipher_info->base->ctx_alloc_func() ) )
|
if( NULL == ( ctx->cipher_ctx = cipher_info->base->ctx_alloc_func() ) )
|
||||||
return( MBEDTLS_ERR_CIPHER_ALLOC_FAILED );
|
return( MBEDTLS_ERR_CIPHER_ALLOC_FAILED );
|
||||||
|
|
|
@ -442,6 +442,20 @@ struct tm *mbedtls_platform_gmtime_r( const mbedtls_time_t *tt,
|
||||||
}
|
}
|
||||||
#endif /* MBEDTLS_HAVE_TIME_DATE && MBEDTLS_PLATFORM_GMTIME_R_ALT */
|
#endif /* MBEDTLS_HAVE_TIME_DATE && MBEDTLS_PLATFORM_GMTIME_R_ALT */
|
||||||
|
|
||||||
|
#if defined(MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY) || defined(MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY)
|
||||||
|
uint32_t mbedtls_hash( const void *data, size_t data_len_bytes )
|
||||||
|
{
|
||||||
|
uint32_t result = 0;
|
||||||
|
size_t i;
|
||||||
|
/* data_len_bytes - only multiples of 4 are considered, rest is truncated */
|
||||||
|
for( i = 0; i < data_len_bytes >> 2; i++ )
|
||||||
|
{
|
||||||
|
result ^= ( (uint32_t*) data )[i];
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
unsigned char* mbedtls_platform_put_uint32_be( unsigned char *buf,
|
unsigned char* mbedtls_platform_put_uint32_be( unsigned char *buf,
|
||||||
size_t num )
|
size_t num )
|
||||||
{
|
{
|
||||||
|
|
|
@ -56,7 +56,68 @@
|
||||||
#include "mbedtls/oid.h"
|
#include "mbedtls/oid.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define PROPER_HS_FRAGMENT 0x75555555
|
#define PROPER_HS_FRAGMENT 0x75
|
||||||
|
|
||||||
|
#if defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS)
|
||||||
|
static int mbedtls_ssl_switch_key( mbedtls_ssl_transform *transform,
|
||||||
|
const mbedtls_operation_t operation )
|
||||||
|
{
|
||||||
|
unsigned char * key;
|
||||||
|
int ret = MBEDTLS_ERR_PLATFORM_FAULT_DETECTED;
|
||||||
|
int flow_ctrl = 0;
|
||||||
|
#if defined(MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY)
|
||||||
|
uint32_t hash;
|
||||||
|
#endif
|
||||||
|
if( operation == MBEDTLS_ENCRYPT )
|
||||||
|
{
|
||||||
|
flow_ctrl++;
|
||||||
|
key = transform->key_enc;
|
||||||
|
#if defined(MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY)
|
||||||
|
hash = transform->key_enc_hash;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
else if ( operation == MBEDTLS_DECRYPT )
|
||||||
|
{
|
||||||
|
flow_ctrl++;
|
||||||
|
key = transform->key_dec;
|
||||||
|
#if defined(MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY)
|
||||||
|
hash = transform->key_dec_hash;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return ( MBEDTLS_ERR_SSL_INTERNAL_ERROR );
|
||||||
|
}
|
||||||
|
#if defined(MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY)
|
||||||
|
/* Check hash */
|
||||||
|
if( hash != mbedtls_hash( key, transform->key_bitlen >> 3 ) )
|
||||||
|
{
|
||||||
|
return( MBEDTLS_ERR_PLATFORM_FAULT_DETECTED );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
flow_ctrl++;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
flow_ctrl++;
|
||||||
|
#endif
|
||||||
|
if( operation != transform->cipher_ctx.operation )
|
||||||
|
{
|
||||||
|
if( ( ret = mbedtls_cipher_setkey( &transform->cipher_ctx,
|
||||||
|
key,
|
||||||
|
transform->key_bitlen,
|
||||||
|
operation ) ) != 0 )
|
||||||
|
{
|
||||||
|
return( ret );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if( flow_ctrl == 2 )
|
||||||
|
{
|
||||||
|
return( 0 );
|
||||||
|
}
|
||||||
|
return( MBEDTLS_ERR_PLATFORM_FAULT_DETECTED );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(MBEDTLS_USE_TINYCRYPT)
|
#if defined(MBEDTLS_USE_TINYCRYPT)
|
||||||
static int uecc_rng_wrapper( uint8_t *dest, unsigned int size )
|
static int uecc_rng_wrapper( uint8_t *dest, unsigned int size )
|
||||||
|
@ -1577,6 +1638,11 @@ int ssl_populate_transform( mbedtls_ssl_transform *transform,
|
||||||
memcpy( transform->key_dec, key2, cipher_info->key_bitlen >> 3 );
|
memcpy( transform->key_dec, key2, cipher_info->key_bitlen >> 3 );
|
||||||
|
|
||||||
transform->key_bitlen = cipher_info->key_bitlen;
|
transform->key_bitlen = cipher_info->key_bitlen;
|
||||||
|
#if defined(MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY)
|
||||||
|
transform->key_enc_hash = mbedtls_hash( transform->key_enc, transform->key_bitlen >> 3 );
|
||||||
|
transform->key_dec_hash = mbedtls_hash( transform->key_dec, transform->key_bitlen >> 3 );
|
||||||
|
#endif
|
||||||
|
|
||||||
#else
|
#else
|
||||||
if( ( ret = mbedtls_cipher_setup( &transform->cipher_ctx_enc,
|
if( ( ret = mbedtls_cipher_setup( &transform->cipher_ctx_enc,
|
||||||
cipher_info ) ) != 0 )
|
cipher_info ) ) != 0 )
|
||||||
|
@ -2697,12 +2763,10 @@ int mbedtls_ssl_encrypt_buf( mbedtls_ssl_context *ssl,
|
||||||
"including %d bytes of padding",
|
"including %d bytes of padding",
|
||||||
rec->data_len, 0 ) );
|
rec->data_len, 0 ) );
|
||||||
#if defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS)
|
#if defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS)
|
||||||
if( ( ret = mbedtls_cipher_setkey( &transform->cipher_ctx,
|
if( ( ret = mbedtls_ssl_switch_key( transform, MBEDTLS_ENCRYPT ) )
|
||||||
transform->key_enc,
|
!= 0 )
|
||||||
transform->key_bitlen,
|
|
||||||
MBEDTLS_ENCRYPT ) ) != 0 )
|
|
||||||
{
|
{
|
||||||
MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_cipher_setkey", ret );
|
MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_ssl_switch_key", ret );
|
||||||
return( ret );
|
return( ret );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2798,12 +2862,10 @@ int mbedtls_ssl_encrypt_buf( mbedtls_ssl_context *ssl,
|
||||||
* Encrypt and authenticate
|
* Encrypt and authenticate
|
||||||
*/
|
*/
|
||||||
#if defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS)
|
#if defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS)
|
||||||
if( ( ret = mbedtls_cipher_setkey( &transform->cipher_ctx,
|
if( ( ret = mbedtls_ssl_switch_key( transform, MBEDTLS_ENCRYPT ) )
|
||||||
transform->key_enc,
|
!= 0 )
|
||||||
transform->key_bitlen,
|
|
||||||
MBEDTLS_ENCRYPT ) ) != 0 )
|
|
||||||
{
|
{
|
||||||
MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_cipher_setkey", ret );
|
MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_ssl_switch_key", ret );
|
||||||
return( ret );
|
return( ret );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2905,12 +2967,10 @@ int mbedtls_ssl_encrypt_buf( mbedtls_ssl_context *ssl,
|
||||||
rec->data_len, transform->ivlen,
|
rec->data_len, transform->ivlen,
|
||||||
padlen + 1 ) );
|
padlen + 1 ) );
|
||||||
#if defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS)
|
#if defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS)
|
||||||
if( ( ret = mbedtls_cipher_setkey( &transform->cipher_ctx,
|
if( ( ret = mbedtls_ssl_switch_key( transform, MBEDTLS_ENCRYPT ) )
|
||||||
transform->key_enc,
|
!= 0 )
|
||||||
transform->key_bitlen,
|
|
||||||
MBEDTLS_ENCRYPT ) ) != 0 )
|
|
||||||
{
|
{
|
||||||
MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_cipher_setkey", ret );
|
MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_ssl_switch_key", ret );
|
||||||
return( ret );
|
return( ret );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3076,12 +3136,10 @@ int mbedtls_ssl_decrypt_buf( mbedtls_ssl_context const *ssl,
|
||||||
{
|
{
|
||||||
padlen = 0;
|
padlen = 0;
|
||||||
#if defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS)
|
#if defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS)
|
||||||
if( ( ret = mbedtls_cipher_setkey( &transform->cipher_ctx,
|
if( ( ret = mbedtls_ssl_switch_key( transform, MBEDTLS_DECRYPT ) )
|
||||||
transform->key_dec,
|
!= 0 )
|
||||||
transform->key_bitlen,
|
|
||||||
MBEDTLS_DECRYPT ) ) != 0 )
|
|
||||||
{
|
{
|
||||||
MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_cipher_setkey", ret );
|
MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_ssl_switch_key", ret );
|
||||||
return( ret );
|
return( ret );
|
||||||
}
|
}
|
||||||
if( ( ret = mbedtls_cipher_crypt( &transform->cipher_ctx,
|
if( ( ret = mbedtls_cipher_crypt( &transform->cipher_ctx,
|
||||||
|
@ -3192,12 +3250,10 @@ int mbedtls_ssl_decrypt_buf( mbedtls_ssl_context const *ssl,
|
||||||
* Decrypt and authenticate
|
* Decrypt and authenticate
|
||||||
*/
|
*/
|
||||||
#if defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS)
|
#if defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS)
|
||||||
if( ( ret = mbedtls_cipher_setkey( &transform->cipher_ctx,
|
if( ( ret = mbedtls_ssl_switch_key( transform, MBEDTLS_DECRYPT ) )
|
||||||
transform->key_dec,
|
!= 0 )
|
||||||
transform->key_bitlen,
|
|
||||||
MBEDTLS_DECRYPT ) ) != 0 )
|
|
||||||
{
|
{
|
||||||
MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_cipher_setkey", ret );
|
MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_ssl_switch_key", ret );
|
||||||
return( ret );
|
return( ret );
|
||||||
}
|
}
|
||||||
if( ( ret = mbedtls_cipher_auth_decrypt( &transform->cipher_ctx,
|
if( ( ret = mbedtls_cipher_auth_decrypt( &transform->cipher_ctx,
|
||||||
|
@ -3376,14 +3432,13 @@ int mbedtls_ssl_decrypt_buf( mbedtls_ssl_context const *ssl,
|
||||||
|
|
||||||
/* We still have data_len % ivlen == 0 and data_len >= ivlen here. */
|
/* We still have data_len % ivlen == 0 and data_len >= ivlen here. */
|
||||||
#if defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS)
|
#if defined(MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS)
|
||||||
if( ( ret = mbedtls_cipher_setkey( &transform->cipher_ctx,
|
if( ( ret = mbedtls_ssl_switch_key( transform, MBEDTLS_DECRYPT ) )
|
||||||
transform->key_dec,
|
!= 0 )
|
||||||
transform->key_bitlen,
|
|
||||||
MBEDTLS_DECRYPT ) ) != 0 )
|
|
||||||
{
|
{
|
||||||
MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_cipher_setkey", ret );
|
MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_ssl_switch_key", ret );
|
||||||
return( ret );
|
return( ret );
|
||||||
}
|
}
|
||||||
|
|
||||||
if( ( ret = mbedtls_cipher_crypt( &transform->cipher_ctx,
|
if( ( ret = mbedtls_cipher_crypt( &transform->cipher_ctx,
|
||||||
transform->iv_dec, transform->ivlen,
|
transform->iv_dec, transform->ivlen,
|
||||||
data, rec->data_len, data, &olen ) ) != 0 )
|
data, rec->data_len, data, &olen ) ) != 0 )
|
||||||
|
|
|
@ -687,6 +687,9 @@ static const char *features[] = {
|
||||||
#if defined(MBEDTLS_CRC_C)
|
#if defined(MBEDTLS_CRC_C)
|
||||||
"MBEDTLS_CRC_C",
|
"MBEDTLS_CRC_C",
|
||||||
#endif /* MBEDTLS_CRC_C */
|
#endif /* MBEDTLS_CRC_C */
|
||||||
|
#if defined(MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY)
|
||||||
|
"MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY",
|
||||||
|
#endif /* MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY */
|
||||||
#if defined(MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY)
|
#if defined(MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY)
|
||||||
"MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY",
|
"MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY",
|
||||||
#endif /* MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY */
|
#endif /* MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY */
|
||||||
|
|
|
@ -1874,6 +1874,14 @@ int query_config( const char *config )
|
||||||
}
|
}
|
||||||
#endif /* MBEDTLS_CRC_C */
|
#endif /* MBEDTLS_CRC_C */
|
||||||
|
|
||||||
|
#if defined(MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY)
|
||||||
|
if( strcmp( "MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY", config ) == 0 )
|
||||||
|
{
|
||||||
|
MACRO_EXPANSION_TO_STR( MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY );
|
||||||
|
return( 0 );
|
||||||
|
}
|
||||||
|
#endif /* MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY */
|
||||||
|
|
||||||
#if defined(MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY)
|
#if defined(MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY)
|
||||||
if( strcmp( "MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY", config ) == 0 )
|
if( strcmp( "MBEDTLS_VALIDATE_AES_KEYS_INTEGRITY", config ) == 0 )
|
||||||
{
|
{
|
||||||
|
|
|
@ -58,6 +58,7 @@
|
||||||
# MBEDTLS_AES_SCA_COUNTERMEASURES
|
# MBEDTLS_AES_SCA_COUNTERMEASURES
|
||||||
# MBEDTLS_CTR_DRBG_USE_128_BIT_KEY
|
# MBEDTLS_CTR_DRBG_USE_128_BIT_KEY
|
||||||
# MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS
|
# MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS
|
||||||
|
# MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY
|
||||||
# and any symbol beginning _ALT
|
# and any symbol beginning _ALT
|
||||||
#
|
#
|
||||||
# The baremetal configuration excludes options that require a library or
|
# The baremetal configuration excludes options that require a library or
|
||||||
|
@ -142,6 +143,7 @@ MBEDTLS_AES_ONLY_ENCRYPT
|
||||||
MBEDTLS_AES_SCA_COUNTERMEASURES
|
MBEDTLS_AES_SCA_COUNTERMEASURES
|
||||||
MBEDTLS_CTR_DRBG_USE_128_BIT_KEY
|
MBEDTLS_CTR_DRBG_USE_128_BIT_KEY
|
||||||
MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS
|
MBEDTLS_SSL_TRANSFORM_OPTIMIZE_CIPHERS
|
||||||
|
MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY
|
||||||
_ALT\s*$
|
_ALT\s*$
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
|
@ -83,6 +83,14 @@ static int build_transforms( mbedtls_ssl_transform *t_in,
|
||||||
memcpy( t_out->key_dec, key0, keylen);
|
memcpy( t_out->key_dec, key0, keylen);
|
||||||
t_out->key_bitlen = cipher_info->key_bitlen;
|
t_out->key_bitlen = cipher_info->key_bitlen;
|
||||||
|
|
||||||
|
#if defined(MBEDTLS_VALIDATE_SSL_KEYS_INTEGRITY)
|
||||||
|
t_in->key_enc_hash = mbedtls_hash( t_in->key_enc, t_in->key_bitlen >> 3 );
|
||||||
|
t_in->key_dec_hash = mbedtls_hash( t_in->key_dec, t_in->key_bitlen >> 3 );
|
||||||
|
|
||||||
|
t_out->key_enc_hash = mbedtls_hash( t_out->key_enc, t_out->key_bitlen >> 3 );
|
||||||
|
t_out->key_dec_hash = mbedtls_hash( t_out->key_dec, t_out->key_bitlen >> 3 );
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Setup cipher contexts */
|
/* Setup cipher contexts */
|
||||||
CHK( mbedtls_cipher_setup( &t_in->cipher_ctx, cipher_info ) == 0 );
|
CHK( mbedtls_cipher_setup( &t_in->cipher_ctx, cipher_info ) == 0 );
|
||||||
CHK( mbedtls_cipher_setup( &t_out->cipher_ctx, cipher_info ) == 0 );
|
CHK( mbedtls_cipher_setup( &t_out->cipher_ctx, cipher_info ) == 0 );
|
||||||
|
|
Loading…
Reference in a new issue