mirror of
https://github.com/cuberite/polarssl.git
synced 2025-09-15 10:08:30 -04:00
Move ccm error state handling.
Remove error clearing from ccm_starts() and ccm_set_lengths(). Add error check in ccm_update_ad(), ccm_update() and ccm_finish(). Signed-off-by: Mateusz Starzyk <mateusz.starzyk@mobica.com>
This commit is contained in:
parent
5d97601e81
commit
2d5652acee
@ -196,11 +196,6 @@ int mbedtls_ccm_starts( mbedtls_ccm_context *ctx,
|
|||||||
if( iv_len < 7 || iv_len > 13 )
|
if( iv_len < 7 || iv_len > 13 )
|
||||||
return( MBEDTLS_ERR_CCM_BAD_INPUT );
|
return( MBEDTLS_ERR_CCM_BAD_INPUT );
|
||||||
|
|
||||||
if( ctx->state & CCM_STATE__ERROR )
|
|
||||||
{
|
|
||||||
mbedtls_ccm_clear_state(ctx);
|
|
||||||
}
|
|
||||||
|
|
||||||
ctx->mode = mode;
|
ctx->mode = mode;
|
||||||
ctx->q = 16 - 1 - (unsigned char) iv_len;
|
ctx->q = 16 - 1 - (unsigned char) iv_len;
|
||||||
|
|
||||||
@ -247,11 +242,6 @@ int mbedtls_ccm_set_lengths( mbedtls_ccm_context *ctx,
|
|||||||
if( total_ad_len >= 0xFF00 )
|
if( total_ad_len >= 0xFF00 )
|
||||||
return( MBEDTLS_ERR_CCM_BAD_INPUT );
|
return( MBEDTLS_ERR_CCM_BAD_INPUT );
|
||||||
|
|
||||||
if( ctx->state & CCM_STATE__ERROR )
|
|
||||||
{
|
|
||||||
mbedtls_ccm_clear_state(ctx);
|
|
||||||
}
|
|
||||||
|
|
||||||
ctx->plaintext_len = plaintext_len;
|
ctx->plaintext_len = plaintext_len;
|
||||||
ctx->add_len = total_ad_len;
|
ctx->add_len = total_ad_len;
|
||||||
ctx->tag_len = tag_len;
|
ctx->tag_len = tag_len;
|
||||||
@ -269,6 +259,11 @@ int mbedtls_ccm_update_ad( mbedtls_ccm_context *ctx,
|
|||||||
unsigned char i;
|
unsigned char i;
|
||||||
size_t olen, use_len, offset;
|
size_t olen, use_len, offset;
|
||||||
|
|
||||||
|
if( ctx->state & CCM_STATE__ERROR )
|
||||||
|
{
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
if( ctx->add_len > 0 && add_len > 0)
|
if( ctx->add_len > 0 && add_len > 0)
|
||||||
{
|
{
|
||||||
if( ctx->processed == 0 )
|
if( ctx->processed == 0 )
|
||||||
@ -321,6 +316,11 @@ int mbedtls_ccm_update( mbedtls_ccm_context *ctx,
|
|||||||
unsigned char i;
|
unsigned char i;
|
||||||
size_t use_len, offset, olen;
|
size_t use_len, offset, olen;
|
||||||
|
|
||||||
|
if( ctx->state & CCM_STATE__ERROR )
|
||||||
|
{
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
if( output_size < input_len )
|
if( output_size < input_len )
|
||||||
return( MBEDTLS_ERR_CCM_BAD_INPUT );
|
return( MBEDTLS_ERR_CCM_BAD_INPUT );
|
||||||
*output_len = input_len;
|
*output_len = input_len;
|
||||||
@ -397,6 +397,11 @@ int mbedtls_ccm_finish( mbedtls_ccm_context *ctx,
|
|||||||
int ret = MBEDTLS_ERR_ERROR_CORRUPTION_DETECTED;
|
int ret = MBEDTLS_ERR_ERROR_CORRUPTION_DETECTED;
|
||||||
unsigned char i;
|
unsigned char i;
|
||||||
|
|
||||||
|
if( ctx->state & CCM_STATE__ERROR )
|
||||||
|
{
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Authentication: reset counter and crypt/mask internal tag
|
* Authentication: reset counter and crypt/mask internal tag
|
||||||
*/
|
*/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user