Use PSA_AEAD_NONCE_LENGTH when exercising AEAD keys

Don't re-code the logic to determine a valid nonce length.

This fixes exercise_key() for PSA_ALG_CHACHA20_POLY1305, which was trying to
use a 16-byte nonce.

Signed-off-by: Gilles Peskine <Gilles.Peskine@arm.com>
This commit is contained in:
Gilles Peskine 2022-03-19 11:03:32 +01:00
parent 6d187afd8d
commit 7acb1980ee

View file

@ -243,7 +243,9 @@ static int exercise_aead_key( mbedtls_svc_key_id_t key,
psa_algorithm_t alg ) psa_algorithm_t alg )
{ {
unsigned char nonce[16] = {0}; unsigned char nonce[16] = {0};
size_t nonce_length = sizeof( nonce ); size_t nonce_length;
psa_key_attributes_t attributes = PSA_KEY_ATTRIBUTES_INIT;
psa_key_type_t key_type;
unsigned char plaintext[16] = "Hello, world..."; unsigned char plaintext[16] = "Hello, world...";
unsigned char ciphertext[48] = "(wabblewebblewibblewobblewubble)"; unsigned char ciphertext[48] = "(wabblewebblewibblewobblewubble)";
size_t ciphertext_length = sizeof( ciphertext ); size_t ciphertext_length = sizeof( ciphertext );
@ -255,19 +257,9 @@ static int exercise_aead_key( mbedtls_svc_key_id_t key,
alg = PSA_ALG_AEAD_WITH_SHORTENED_TAG( alg, PSA_ALG_AEAD_GET_TAG_LENGTH( alg ) ); alg = PSA_ALG_AEAD_WITH_SHORTENED_TAG( alg, PSA_ALG_AEAD_GET_TAG_LENGTH( alg ) );
} }
/* Default IV length for AES-GCM is 12 bytes */ PSA_ASSERT( psa_get_key_attributes( key, &attributes ) );
if( PSA_ALG_AEAD_WITH_SHORTENED_TAG( alg, 0 ) == key_type = psa_get_key_type( &attributes );
PSA_ALG_AEAD_WITH_SHORTENED_TAG( PSA_ALG_GCM, 0 ) ) nonce_length = PSA_AEAD_NONCE_LENGTH( key_type, alg );
{
nonce_length = 12;
}
/* IV length for CCM needs to be between 7 and 13 bytes */
if( PSA_ALG_AEAD_WITH_SHORTENED_TAG( alg, 0 ) ==
PSA_ALG_AEAD_WITH_SHORTENED_TAG( PSA_ALG_CCM, 0 ) )
{
nonce_length = 12;
}
if( usage & PSA_KEY_USAGE_ENCRYPT ) if( usage & PSA_KEY_USAGE_ENCRYPT )
{ {
@ -297,6 +289,7 @@ static int exercise_aead_key( mbedtls_svc_key_id_t key,
return( 1 ); return( 1 );
exit: exit:
psa_reset_key_attributes( &attributes );
return( 0 ); return( 0 );
} }