/* * Copyright (c) 2019 Nordic Semiconductor ASA * * SPDX-License-Identifier: LicenseRef-BSD-5-Clause-Nordic */ #include "cc310_glue.h" int cc310_init(void) { /* Only initialize once */ static bool initialized; if (!initialized) { nrf_cc310_enable(); if (nrf_cc310_bl_init() != 0) { return -1; } initialized = true; nrf_cc310_disable(); } return 0; } void cc310_sha256_update(nrf_cc310_bl_hash_context_sha256_t *ctx, const void *data, uint32_t data_len) { /* * NRF Cryptocell can only read from RAM this allocates a buffer on the stack * if the data provided is not located in RAM. */ if ((uint32_t) data < CONFIG_SRAM_BASE_ADDRESS) { uint8_t stack_buffer[data_len]; uint32_t block_len = data_len; memcpy(stack_buffer, data, block_len); nrf_cc310_bl_hash_sha256_update(ctx, stack_buffer, block_len); } else { nrf_cc310_bl_hash_sha256_update(ctx, data, data_len); } }; int cc310_ecdsa_verify_secp256r1(uint8_t *hash, uint8_t *public_key, uint8_t *signature, size_t hash_len) { int rc; nrf_cc310_bl_ecdsa_verify_context_secp256r1_t ctx; cc310_init(); nrf_cc310_enable(); rc = nrf_cc310_bl_ecdsa_verify_secp256r1(&ctx, (nrf_cc310_bl_ecc_public_key_secp256r1_t *) public_key, (nrf_cc310_bl_ecc_signature_secp256r1_t *) signature, hash, hash_len); nrf_cc310_disable(); return rc; }