mirror of
https://github.com/Mbed-TLS/mbedtls.git
synced 2025-03-31 01:20:35 +00:00
test: add key pair check verification for opaque EC keys
Signed-off-by: valerio <valerio.setti@nordicsemi.no>
This commit is contained in:
parent
8cbef4d55e
commit
6c666c6c8d
@ -562,6 +562,9 @@ exit:
|
|||||||
void mbedtls_pk_check_pair(char *pub_file, char *prv_file, int ret)
|
void mbedtls_pk_check_pair(char *pub_file, char *prv_file, int ret)
|
||||||
{
|
{
|
||||||
mbedtls_pk_context pub, prv, alt;
|
mbedtls_pk_context pub, prv, alt;
|
||||||
|
#if defined(MBEDTLS_USE_PSA_CRYPTO)
|
||||||
|
mbedtls_svc_key_id_t opaque_key_id = MBEDTLS_SVC_KEY_ID_INIT;
|
||||||
|
#endif /* MBEDTLS_USE_PSA_CRYPTO */
|
||||||
|
|
||||||
mbedtls_pk_init(&pub);
|
mbedtls_pk_init(&pub);
|
||||||
mbedtls_pk_init(&prv);
|
mbedtls_pk_init(&prv);
|
||||||
@ -575,7 +578,7 @@ void mbedtls_pk_check_pair(char *pub_file, char *prv_file, int ret)
|
|||||||
if (ret == MBEDTLS_ERR_ECP_BAD_INPUT_DATA) {
|
if (ret == MBEDTLS_ERR_ECP_BAD_INPUT_DATA) {
|
||||||
ret = MBEDTLS_ERR_PK_BAD_INPUT_DATA;
|
ret = MBEDTLS_ERR_PK_BAD_INPUT_DATA;
|
||||||
}
|
}
|
||||||
#endif
|
#endif /* MBEDTLS_USE_PSA_CRYPTO */
|
||||||
|
|
||||||
TEST_ASSERT(mbedtls_pk_parse_public_keyfile(&pub, pub_file) == 0);
|
TEST_ASSERT(mbedtls_pk_parse_public_keyfile(&pub, pub_file) == 0);
|
||||||
TEST_ASSERT(mbedtls_pk_parse_keyfile(&prv, prv_file, NULL,
|
TEST_ASSERT(mbedtls_pk_parse_keyfile(&prv, prv_file, NULL,
|
||||||
@ -596,7 +599,20 @@ void mbedtls_pk_check_pair(char *pub_file, char *prv_file, int ret)
|
|||||||
== ret);
|
== ret);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
#if defined(MBEDTLS_USE_PSA_CRYPTO)
|
||||||
|
if (mbedtls_pk_get_type(&prv) == MBEDTLS_PK_ECKEY) {
|
||||||
|
TEST_EQUAL(mbedtls_pk_wrap_as_opaque(&prv, &opaque_key_id,
|
||||||
|
PSA_ALG_ANY_HASH,
|
||||||
|
PSA_KEY_USAGE_EXPORT, 0), 0);
|
||||||
|
TEST_EQUAL(mbedtls_pk_check_pair(&pub, &prv, mbedtls_test_rnd_std_rand,
|
||||||
|
NULL), ret);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
exit:
|
||||||
|
#if defined(MBEDTLS_USE_PSA_CRYPTO)
|
||||||
|
psa_destroy_key(opaque_key_id);
|
||||||
|
#endif /* MBEDTLS_USE_PSA_CRYPTO */
|
||||||
mbedtls_pk_free(&pub);
|
mbedtls_pk_free(&pub);
|
||||||
mbedtls_pk_free(&prv);
|
mbedtls_pk_free(&prv);
|
||||||
mbedtls_pk_free(&alt);
|
mbedtls_pk_free(&alt);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user