Add test function for opaque driver (simply returns PSA_ERROR_NOT_SUPPORTED), and address other review comments.

Signed-off-by: Aditya Deshpande <aditya.deshpande@arm.com>
This commit is contained in:
Aditya Deshpande 2022-11-28 14:46:30 +00:00
parent 5e3c70e3be
commit 1ac41dec09
6 changed files with 65 additions and 37 deletions

View file

@ -5738,11 +5738,11 @@ psa_status_t psa_key_agreement_raw_builtin( const psa_key_attributes_t *attribut
#if defined(MBEDTLS_PSA_BUILTIN_ALG_ECDH) #if defined(MBEDTLS_PSA_BUILTIN_ALG_ECDH)
case PSA_ALG_ECDH: case PSA_ALG_ECDH:
return( mbedtls_psa_key_agreement_ecdh( attributes, key_buffer, return( mbedtls_psa_key_agreement_ecdh( attributes, key_buffer,
key_buffer_size, alg, key_buffer_size, alg,
peer_key, peer_key_length, peer_key, peer_key_length,
shared_secret, shared_secret,
shared_secret_size, shared_secret_size,
shared_secret_length ) ); shared_secret_length ) );
#endif /* MBEDTLS_PSA_BUILTIN_ALG_ECDH */ #endif /* MBEDTLS_PSA_BUILTIN_ALG_ECDH */
default: default:
(void) attributes; (void) attributes;
@ -5771,18 +5771,20 @@ static psa_status_t psa_key_agreement_raw_internal( psa_algorithm_t alg,
size_t shared_secret_size, size_t shared_secret_size,
size_t *shared_secret_length ) size_t *shared_secret_length )
{ {
if( !PSA_ALG_IS_RAW_KEY_AGREEMENT(alg) ) if( !PSA_ALG_IS_RAW_KEY_AGREEMENT( alg ) )
return( PSA_ERROR_NOT_SUPPORTED ); return( PSA_ERROR_NOT_SUPPORTED );
psa_key_attributes_t attributes = { psa_key_attributes_t attributes = {
.core = private_key->attr .core = private_key->attr
}; };
return( psa_driver_wrapper_key_agreement( &attributes, private_key->key.data, return( psa_driver_wrapper_key_agreement( &attributes,
private_key->key.bytes, private_key->key.data,
alg, peer_key, peer_key_length, private_key->key.bytes, alg,
shared_secret, shared_secret_size, peer_key, peer_key_length,
shared_secret_length ) ); shared_secret,
shared_secret_size,
shared_secret_length ) );
} }
/* Note that if this function fails, you must call psa_key_derivation_abort() /* Note that if this function fails, you must call psa_key_derivation_abort()

View file

@ -2497,22 +2497,17 @@ psa_status_t psa_driver_wrapper_key_agreement(
case PSA_KEY_LOCATION_LOCAL_STORAGE: case PSA_KEY_LOCATION_LOCAL_STORAGE:
/* Key is stored in the slot in export representation, so /* Key is stored in the slot in export representation, so
* cycle through all known transparent accelerators */ * cycle through all known transparent accelerators */
#if defined(PSA_CRYPTO_ACCELERATOR_DRIVER_PRESENT) #if defined(PSA_CRYPTO_ACCELERATOR_DRIVER_PRESENT)
#if defined(PSA_CRYPTO_DRIVER_TEST) #if defined(PSA_CRYPTO_DRIVER_TEST)
status = status =
mbedtls_test_transparent_key_agreement( attributes, mbedtls_test_transparent_key_agreement( attributes,
key_buffer, key_buffer, key_buffer_size, alg, peer_key,
key_buffer_size, peer_key_length, shared_secret, shared_secret_size,
alg, shared_secret_length );
peer_key,
peer_key_length,
shared_secret,
shared_secret_size,
shared_secret_length );
if( status != PSA_ERROR_NOT_SUPPORTED ) if( status != PSA_ERROR_NOT_SUPPORTED )
return( status ); return( status );
#endif /* PSA_CRYPTO_DRIVER_TEST */ #endif /* PSA_CRYPTO_DRIVER_TEST */
#endif /* PSA_CRYPTO_ACCELERATOR_DRIVER_PRESENT */ #endif /* PSA_CRYPTO_ACCELERATOR_DRIVER_PRESENT */
/* Software Fallback */ /* Software Fallback */
status = psa_key_agreement_raw_builtin( attributes, status = psa_key_agreement_raw_builtin( attributes,
@ -2525,6 +2520,15 @@ psa_status_t psa_driver_wrapper_key_agreement(
shared_secret_size, shared_secret_size,
shared_secret_length ); shared_secret_length );
return( status ); return( status );
#if defined(PSA_CRYPTO_ACCELERATOR_DRIVER_PRESENT)
#if defined(PSA_CRYPTO_DRIVER_TEST)
case PSA_CRYPTO_TEST_DRIVER_LOCATION:
return( mbedtls_test_opaque_key_agreement( attributes,
key_buffer, key_buffer_size, alg, peer_key,
peer_key_length, shared_secret, shared_secret_size,
shared_secret_length ) );
#endif /* PSA_CRYPTO_DRIVER_TEST */
#endif /* PSA_CRYPTO_ACCELERATOR_DRIVER_PRESENT */
default: default:
(void) attributes; (void) attributes;

View file

@ -59,16 +59,16 @@ psa_status_t mbedtls_test_transparent_key_agreement(
size_t shared_secret_size, size_t shared_secret_size,
size_t *shared_secret_length ); size_t *shared_secret_length );
// psa_status_t mbedtls_test_opaque_key_agreement( psa_status_t mbedtls_test_opaque_key_agreement(
// const psa_key_attributes_t *attributes, const psa_key_attributes_t *attributes,
// const uint8_t *key_buffer, const uint8_t *key_buffer,
// size_t key_buffer_size, size_t key_buffer_size,
// psa_algorithm_t alg, psa_algorithm_t alg,
// const uint8_t *peer_key, const uint8_t *peer_key,
// size_t peer_key_length, size_t peer_key_length,
// uint8_t *shared_secret, uint8_t *shared_secret,
// size_t shared_secret_size, size_t shared_secret_size,
// size_t *shared_secret_length ); size_t *shared_secret_length );
#endif /*PSA_CRYPTO_DRIVER_TEST */ #endif /*PSA_CRYPTO_DRIVER_TEST */
#endif /* PSA_CRYPTO_TEST_DRIVERS_KEY_AGREEMENT_H */ #endif /* PSA_CRYPTO_TEST_DRIVERS_KEY_AGREEMENT_H */

View file

@ -69,8 +69,8 @@ psa_status_t mbedtls_test_transparent_key_agreement(
if( PSA_ALG_IS_ECDH(alg) ) if( PSA_ALG_IS_ECDH(alg) )
{ {
#if defined(MBEDTLS_TEST_LIBTESTDRIVER1) && \ #if (defined(MBEDTLS_TEST_LIBTESTDRIVER1) && \
(LIBTESTDRIVER1_MBEDTLS_PSA_BUILTIN_ALG_ECDH) defined(LIBTESTDRIVER1_MBEDTLS_PSA_BUILTIN_ALG_ECDH))
return( libtestdriver1_mbedtls_psa_key_agreement_ecdh( return( libtestdriver1_mbedtls_psa_key_agreement_ecdh(
(const libtestdriver1_psa_key_attributes_t *) attributes, (const libtestdriver1_psa_key_attributes_t *) attributes,
key_buffer, key_buffer_size, key_buffer, key_buffer_size,
@ -103,4 +103,27 @@ psa_status_t mbedtls_test_transparent_key_agreement(
} }
psa_status_t mbedtls_test_opaque_key_agreement(
const psa_key_attributes_t *attributes,
const uint8_t *key_buffer,
size_t key_buffer_size,
psa_algorithm_t alg,
const uint8_t *peer_key,
size_t peer_key_length,
uint8_t *shared_secret,
size_t shared_secret_size,
size_t *shared_secret_length )
{
(void) attributes;
(void) key_buffer;
(void) key_buffer_size;
(void) alg;
(void) peer_key;
(void) peer_key_length;
(void) shared_secret;
(void) shared_secret_size;
(void) shared_secret_length;
return( PSA_ERROR_NOT_SUPPORTED );
}
#endif /* MBEDTLS_PSA_CRYPTO_DRIVERS && PSA_CRYPTO_DRIVER_TEST */ #endif /* MBEDTLS_PSA_CRYPTO_DRIVERS && PSA_CRYPTO_DRIVER_TEST */

View file

@ -308,7 +308,7 @@ depends_on:PSA_WANT_ALG_ECDH:PSA_WANT_KEY_TYPE_ECC_KEY_PAIR:MBEDTLS_PK_PARSE_C:P
key_agreement:PSA_ALG_ECDH:PSA_SUCCESS:PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_SECP_R1):"c88f01f510d9ac3f70a292daa2316de544e9aab8afe84049c62a9c57862d1433":"04d12dfb5289c8d4f81208b70270398c342296970a0bccb74c736fc7554494bf6356fbf3ca366cc23e8157854c13c58d6aac23f046ada30f8353e74f33039872ab":"d6840f6b42f6edafd13116e0e12565202fef8e9ece7dce03812464d04b9442de":"":PSA_SUCCESS key_agreement:PSA_ALG_ECDH:PSA_SUCCESS:PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_SECP_R1):"c88f01f510d9ac3f70a292daa2316de544e9aab8afe84049c62a9c57862d1433":"04d12dfb5289c8d4f81208b70270398c342296970a0bccb74c736fc7554494bf6356fbf3ca366cc23e8157854c13c58d6aac23f046ada30f8353e74f33039872ab":"d6840f6b42f6edafd13116e0e12565202fef8e9ece7dce03812464d04b9442de":"":PSA_SUCCESS
raw key agreement through driver: fallback raw key agreement through driver: fallback
depends_on:PSA_WANT_ALG_ECDH:PSA_WANT_KEY_TYPE_ECC_KEY_PAIR:MBEDTLS_PK_PARSE_C:PSA_WANT_ECC_SECP_R1_256:MBEDLTS_PSA_BUILTIN_ALG_ECDH depends_on:PSA_WANT_ALG_ECDH:PSA_WANT_KEY_TYPE_ECC_KEY_PAIR:MBEDTLS_PK_PARSE_C:PSA_WANT_ECC_SECP_R1_256:MBEDTLS_PSA_BUILTIN_ALG_ECDH
key_agreement:PSA_ALG_ECDH:PSA_ERROR_NOT_SUPPORTED:PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_SECP_R1):"c88f01f510d9ac3f70a292daa2316de544e9aab8afe84049c62a9c57862d1433":"04d12dfb5289c8d4f81208b70270398c342296970a0bccb74c736fc7554494bf6356fbf3ca366cc23e8157854c13c58d6aac23f046ada30f8353e74f33039872ab":"d6840f6b42f6edafd13116e0e12565202fef8e9ece7dce03812464d04b9442de":"":PSA_SUCCESS key_agreement:PSA_ALG_ECDH:PSA_ERROR_NOT_SUPPORTED:PSA_KEY_TYPE_ECC_KEY_PAIR(PSA_ECC_FAMILY_SECP_R1):"c88f01f510d9ac3f70a292daa2316de544e9aab8afe84049c62a9c57862d1433":"04d12dfb5289c8d4f81208b70270398c342296970a0bccb74c736fc7554494bf6356fbf3ca366cc23e8157854c13c58d6aac23f046ada30f8353e74f33039872ab":"d6840f6b42f6edafd13116e0e12565202fef8e9ece7dce03812464d04b9442de":"":PSA_SUCCESS
raw key agreement through driver: error raw key agreement through driver: error

View file

@ -626,7 +626,6 @@ exit:
PSA_DONE( ); PSA_DONE( );
mbedtls_test_driver_key_agreement_hooks = mbedtls_test_driver_key_agreement_hooks =
mbedtls_test_driver_key_agreement_hooks_init(); mbedtls_test_driver_key_agreement_hooks_init();
} }
/* END_CASE */ /* END_CASE */