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:
parent
5e3c70e3be
commit
1ac41dec09
6 changed files with 65 additions and 37 deletions
|
@ -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()
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
Loading…
Reference in a new issue