when I use the function , I got the code -0x0010 => MBEDTLS_ERR_MPI_ALLOC_FAILED; What should I do?
my code:
unsigned char temp_key_data[65] = {0x04, 0xf3, 0x47, 0x6f, 0xb3, 0x72, 0x70, 0xee,
0xf0, 0x99, 0x66, 0xfd, 0x17, 0xca, 0x79, 0x67,
0xed, 0xe6, 0x3a, 0x2b, 0xb3, 0xd2, 0x3b, 0x4a,
0xee, 0x6e, 0x8b, 0x45, 0x94, 0x82, 0xae, 0xbd,
0x7a, 0x93, 0x9a, 0x95, 0xcb, 0xbb, 0xd0, 0x1a,
0x1e, 0xc4, 0x6b, 0x19, 0x76, 0x50, 0x9e, 0x1c,
0xb8, 0x29, 0x90, 0xd8, 0xee, 0xc3, 0x4c, 0x98,
0xd1, 0x4b, 0x69, 0xc5, 0xd8, 0xf7, 0xce, 0xe2,
0x1c};
mbedtls_ecp_group grp;
mbedtls_ecp_point Q;
mbedtls_ecp_group_init(&grp);
mbedtls_ecp_point_init(&Q);
// SECP256R1
int ret = mbedtls_ecp_group_load(&grp, MBEDTLS_ECP_DP_SECP256R1);
if (ret != 0)
{
NRF_LOG_INFO("mbedtls_ecp_group_load failed: %s\n", error_buf);
APP_ERROR_CHECK(ret);
}
ret = mbedtls_ecp_point_read_binary(&grp, &Q, temp_key_data, sizeof(temp_key_data));
if (ret != 0)
{
NRF_LOG_INFO("mbedtls_ecp_point_read_binary failed: %s\n", error_buf);
APP_ERROR_CHECK(ret);
}
mbedtls_ecp_point_free(&Q);
mbedtls_ecp_group_free(&grp);