xiaozhengsheng 6df0f7d96e 初始版本
2025-08-19 09:49:41 +08:00

1214 lines
42 KiB
C

/**
* Copyright (c) 2018 - 2020, Nordic Semiconductor ASA
*
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form, except as embedded into a Nordic
* Semiconductor ASA integrated circuit in a product or a software update for
* such product, must reproduce the above copyright notice, this list of
* conditions and the following disclaimer in the documentation and/or other
* materials provided with the distribution.
*
* 3. Neither the name of Nordic Semiconductor ASA nor the names of its
* contributors may be used to endorse or promote products derived from this
* software without specific prior written permission.
*
* 4. This software, with or without modification, must only be used with a
* Nordic Semiconductor ASA integrated circuit.
*
* 5. Any software provided in binary form under this license must not be reverse
* engineered, decompiled, modified and/or disassembled.
*
* THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS
* OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
* GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
*/
#include "sdk_common.h"
#if NRF_MODULE_ENABLED(NRF_CRYPTO)
/*lint -save -e????*/
#include "mbedtls/md.h"
#include "mbedtls/aes.h"
#include "mbedtls/cipher.h"
/*lint -restore*/
#include "nrf_crypto_error.h"
#include "mbedtls_backend_aes.h"
#if NRF_MODULE_ENABLED(NRF_CRYPTO_MBEDTLS_AES)
/* macro changing bits to bytes */
#define BITS_TO_BYTES(bits) ((bits)>>3)
#define BACKEND_ERROR_CHECK(error) \
do { \
if ((error) != 0) \
{ \
return result_get((error)); \
} \
} while (0);
/**@internal @brief Type declarations of templates matching all possible context sizes
* for this backend.
*/
typedef struct
{
nrf_crypto_aes_internal_context_t header; /**< Common header for context. */
nrf_crypto_backend_aes_ctx_t backend; /**< Backend-specific internal context. */
uint32_t context[1]; /**< AES context internal to mbed TLS. */
} nrf_crypto_backend_mbedtls_aes_any_context_t;
/**@internal @brief Type declarations of templates matching all possible context sizes
* for this backend.
*/
typedef union
{
nrf_crypto_backend_mbedtls_aes_any_context_t any; /**< Common for all contexts. */
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_ECB)
nrf_crypto_backend_aes_ecb_context_t ecb;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC)
nrf_crypto_backend_aes_cbc_context_t cbc;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CTR)
nrf_crypto_backend_aes_ctr_context_t ctr;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CFB)
nrf_crypto_backend_aes_cfb_context_t cfb;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_MAC)
nrf_crypto_backend_aes_cbc_mac_context_t cbc_mac;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CMAC)
nrf_crypto_backend_aes_cmac_context_t cmac;
#endif
} nrf_crypto_backend_mbedtls_aes_context_t;
static ret_code_t result_get(int error)
{
ret_code_t ret_val;
switch (error)
{
case 0:
ret_val = NRF_SUCCESS;
break;
case MBEDTLS_ERR_AES_INVALID_INPUT_LENGTH:
ret_val = NRF_ERROR_CRYPTO_INPUT_LENGTH;
break;
case MBEDTLS_ERR_CIPHER_BAD_INPUT_DATA:
ret_val = NRF_ERROR_CRYPTO_INPUT_LENGTH;
break;
case MBEDTLS_ERR_CIPHER_ALLOC_FAILED:
ret_val = NRF_ERROR_CRYPTO_ALLOC_FAILED;
break;
case MBEDTLS_ERR_CIPHER_FEATURE_UNAVAILABLE:
ret_val = NRF_ERROR_CRYPTO_FEATURE_UNAVAILABLE;
break;
case MBEDTLS_ERR_MD_BAD_INPUT_DATA:
ret_val = NRF_ERROR_CRYPTO_INVALID_PARAM;
break;
default:
ret_val = NRF_ERROR_CRYPTO_INTERNAL;
break;
}
return ret_val;
}
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CMAC)
static ret_code_t backend_cmac_init(nrf_crypto_backend_aes_cmac_context_t * const p_cmac_ctx)
{
int error;
mbedtls_cipher_type_t cipher_type;
mbedtls_cipher_info_t const * p_cipher_info;
mbedtls_cipher_init(&p_cmac_ctx->context);
switch (p_cmac_ctx->header.p_info->key_size)
{
case NRF_CRYPTO_KEY_SIZE_128:
cipher_type = MBEDTLS_CIPHER_AES_128_ECB;
break;
case NRF_CRYPTO_KEY_SIZE_192:
cipher_type = MBEDTLS_CIPHER_AES_192_ECB;
break;
case NRF_CRYPTO_KEY_SIZE_256:
cipher_type = MBEDTLS_CIPHER_AES_256_ECB;
break;
default:
return NRF_ERROR_CRYPTO_CONTEXT_NOT_INITIALIZED;
}
p_cipher_info = mbedtls_cipher_info_from_type(cipher_type);
if (p_cipher_info == NULL)
{
return NRF_ERROR_CRYPTO_INTERNAL;
}
error = mbedtls_cipher_setup(&p_cmac_ctx->context, p_cipher_info);
BACKEND_ERROR_CHECK(error);
return NRF_SUCCESS;
}
#endif
static ret_code_t backend_mbedtls_init(void * const p_context, nrf_crypto_operation_t operation)
{
ret_code_t ret_val = NRF_SUCCESS;
nrf_crypto_backend_mbedtls_aes_context_t * p_ctx =
(nrf_crypto_backend_mbedtls_aes_context_t *)p_context;
switch (p_ctx->any.header.p_info->key_size)
{
case NRF_CRYPTO_KEY_SIZE_128:
case NRF_CRYPTO_KEY_SIZE_192:
case NRF_CRYPTO_KEY_SIZE_256:
break;
default:
return NRF_ERROR_CRYPTO_KEY_SIZE;
}
switch (p_ctx->any.header.p_info->mode)
{
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC)
case NRF_CRYPTO_AES_MODE_CBC:
case NRF_CRYPTO_AES_MODE_CBC_PAD_PCKS7:
VERIFY_FALSE(((operation != NRF_CRYPTO_ENCRYPT) && (operation != NRF_CRYPTO_DECRYPT)),
NRF_ERROR_CRYPTO_INVALID_PARAM);
memset(&p_ctx->cbc.backend, 0, sizeof(p_ctx->cbc.backend));
mbedtls_aes_init(&p_ctx->cbc.context);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CTR)
case NRF_CRYPTO_AES_MODE_CTR:
VERIFY_FALSE(((operation != NRF_CRYPTO_ENCRYPT) && (operation != NRF_CRYPTO_DECRYPT)),
NRF_ERROR_CRYPTO_INVALID_PARAM);
memset(&p_ctx->ctr.backend, 0, sizeof(p_ctx->ctr.backend));
mbedtls_aes_init(&p_ctx->ctr.context);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CFB)
case NRF_CRYPTO_AES_MODE_CFB:
VERIFY_FALSE(((operation != NRF_CRYPTO_ENCRYPT) && (operation != NRF_CRYPTO_DECRYPT)),
NRF_ERROR_CRYPTO_INVALID_PARAM);
memset(&p_ctx->cfb.backend, 0, sizeof(p_ctx->cfb.backend));
mbedtls_aes_init(&p_ctx->cfb.context);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_ECB)
case NRF_CRYPTO_AES_MODE_ECB:
case NRF_CRYPTO_AES_MODE_ECB_PAD_PCKS7:
VERIFY_FALSE(((operation != NRF_CRYPTO_ENCRYPT) && (operation != NRF_CRYPTO_DECRYPT)),
NRF_ERROR_CRYPTO_INVALID_PARAM);
memset(&p_ctx->ecb.backend, 0, sizeof(p_ctx->ecb.backend));
mbedtls_aes_init(&p_ctx->ecb.context);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_MAC)
case NRF_CRYPTO_AES_MODE_CBC_MAC:
case NRF_CRYPTO_AES_MODE_CBC_MAC_PAD_PCKS7:
VERIFY_TRUE((operation == NRF_CRYPTO_MAC_CALCULATE), NRF_ERROR_CRYPTO_INVALID_PARAM);
memset(&p_ctx->cbc_mac.backend, 0, sizeof(p_ctx->cbc_mac.backend));
mbedtls_aes_init(&p_ctx->cbc_mac.context);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CMAC)
case NRF_CRYPTO_AES_MODE_CMAC:
VERIFY_TRUE((operation == NRF_CRYPTO_MAC_CALCULATE), NRF_ERROR_CRYPTO_INVALID_PARAM);
ret_val = backend_cmac_init(&p_ctx->cmac);
break;
#endif
default:
ret_val = NRF_ERROR_CRYPTO_FEATURE_UNAVAILABLE;
break;
}
p_ctx->any.backend.operation = operation;
return ret_val;
}
static ret_code_t backend_mbedtls_uninit(void * const p_context)
{
nrf_crypto_backend_mbedtls_aes_context_t * p_ctx =
(nrf_crypto_backend_mbedtls_aes_context_t *)p_context;
switch (p_ctx->any.header.p_info->mode)
{
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC)
case NRF_CRYPTO_AES_MODE_CBC:
case NRF_CRYPTO_AES_MODE_CBC_PAD_PCKS7:
mbedtls_aes_free(&p_ctx->cbc.context);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CTR)
case NRF_CRYPTO_AES_MODE_CTR:
mbedtls_aes_free(&p_ctx->ctr.context);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CFB)
case NRF_CRYPTO_AES_MODE_CFB:
mbedtls_aes_free(&p_ctx->cfb.context);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_ECB)
case NRF_CRYPTO_AES_MODE_ECB:
case NRF_CRYPTO_AES_MODE_ECB_PAD_PCKS7:
mbedtls_aes_free(&p_ctx->ecb.context);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_MAC)
case NRF_CRYPTO_AES_MODE_CBC_MAC:
case NRF_CRYPTO_AES_MODE_CBC_MAC_PAD_PCKS7:
mbedtls_aes_free(&p_ctx->cbc_mac.context);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CMAC)
case NRF_CRYPTO_AES_MODE_CMAC:
mbedtls_cipher_free(&p_ctx->cmac.context);
break;
#endif
default:
return NRF_ERROR_CRYPTO_FEATURE_UNAVAILABLE;
}
return NRF_SUCCESS;
}
static ret_code_t backend_mbedtls_key_set(void * const p_context, uint8_t * p_key)
{
int error;
ret_code_t ret_val;
nrf_crypto_backend_mbedtls_aes_context_t * p_ctx =
(nrf_crypto_backend_mbedtls_aes_context_t *)p_context;
switch (p_ctx->any.header.p_info->mode)
{
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC)
case NRF_CRYPTO_AES_MODE_CBC:
case NRF_CRYPTO_AES_MODE_CBC_PAD_PCKS7:
if (p_ctx->cbc.backend.operation == NRF_CRYPTO_ENCRYPT)
{
error = mbedtls_aes_setkey_enc(&p_ctx->cbc.context,
(uint8_t const *)p_key,
p_ctx->cbc.header.p_info->key_size);
}
else
{
error = mbedtls_aes_setkey_dec(&p_ctx->cbc.context,
(uint8_t const *)p_key,
p_ctx->cbc.header.p_info->key_size);
}
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CTR)
case NRF_CRYPTO_AES_MODE_CTR:
/* Due to the nature of CFB / CTR, you should use the same key schedule for both
encryption and decryption.*/
error = mbedtls_aes_setkey_enc(&p_ctx->ctr.context,
(uint8_t const *)p_key,
p_ctx->ctr.header.p_info->key_size);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CFB)
case NRF_CRYPTO_AES_MODE_CFB:
/* Due to the nature of CFB / CTR, you should use the same key schedule for both
encryption and decryption.*/
error = mbedtls_aes_setkey_enc(&p_ctx->cfb.context,
(uint8_t const *)p_key,
p_ctx->cfb.header.p_info->key_size);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_ECB)
case NRF_CRYPTO_AES_MODE_ECB:
case NRF_CRYPTO_AES_MODE_ECB_PAD_PCKS7:
if (p_ctx->ecb.backend.operation == NRF_CRYPTO_ENCRYPT)
{
error = mbedtls_aes_setkey_enc(&p_ctx->ecb.context,
(uint8_t const *)p_key,
p_ctx->ecb.header.p_info->key_size);
}
else
{
error = mbedtls_aes_setkey_dec(&p_ctx->ecb.context,
(uint8_t const *)p_key,
p_ctx->ecb.header.p_info->key_size);
}
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_MAC)
case NRF_CRYPTO_AES_MODE_CBC_MAC:
case NRF_CRYPTO_AES_MODE_CBC_MAC_PAD_PCKS7:
error = mbedtls_aes_setkey_enc(&p_ctx->cbc_mac.context,
(uint8_t const *)p_key,
p_ctx->cbc_mac.header.p_info->key_size);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CMAC)
case NRF_CRYPTO_AES_MODE_CMAC:
error = mbedtls_cipher_cmac_starts(&p_ctx->cmac.context,
p_key,
p_ctx->cmac.header.p_info->key_size);
break;
#endif
default:
return NRF_ERROR_CRYPTO_FEATURE_UNAVAILABLE;
}
ret_val = result_get(error);
return ret_val;
}
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC) || \
NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CTR) || \
NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CFB) || \
NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_MAC)
static ret_code_t backend_mbedtls_iv_set(void * const p_context, uint8_t * p_iv)
{
nrf_crypto_backend_mbedtls_aes_context_t * p_ctx =
(nrf_crypto_backend_mbedtls_aes_context_t *)p_context;
memcpy(&p_ctx->any.backend.iv[0], p_iv, sizeof(p_ctx->any.backend.iv));
return NRF_SUCCESS;
}
static ret_code_t backend_mbedtls_iv_get(void * const p_context, uint8_t * p_iv)
{
nrf_crypto_backend_mbedtls_aes_context_t * p_ctx =
(nrf_crypto_backend_mbedtls_aes_context_t *)p_context;
memcpy(p_iv, p_ctx->any.backend.iv, sizeof(p_ctx->any.backend.iv));
return NRF_SUCCESS;
}
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_ECB)
/* Function extending mbedtls_aes_crypt_ecb functionality. It allows to process more than 1
data block. It is returning MBEDTLS error type. */
static int backend_mbedtls_ecb_crypt(nrf_crypto_backend_aes_ecb_context_t * const p_ctx,
uint8_t * p_text_in,
uint8_t * p_text_out,
size_t text_size)
{
int error = 0;
size_t crypted_text = 0;
if ((text_size & 0x0F) != 0)
{
return MBEDTLS_ERR_AES_INVALID_INPUT_LENGTH;
}
while (crypted_text < text_size)
{
error = mbedtls_aes_crypt_ecb(&p_ctx->context,
(int)p_ctx->backend.operation,
p_text_in + crypted_text,
p_text_out + crypted_text);
if (error != 0)
{
break;
}
crypted_text += NRF_CRYPTO_AES_BLOCK_SIZE;
}
return error;
}
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_MAC)
static int backend_mbedtls_cbc_mac_update(void * const p_context,
uint8_t * p_data_in,
size_t data_size,
uint8_t * p_data_out)
{
int error = 0;
nrf_crypto_backend_mbedtls_aes_context_t * p_ctx =
(nrf_crypto_backend_mbedtls_aes_context_t *)p_context;
for (size_t i = 0; i < data_size; i += NRF_CRYPTO_AES_BLOCK_SIZE)
{
error = mbedtls_aes_crypt_cbc(&p_ctx->cbc_mac.context,
MBEDTLS_AES_ENCRYPT,
NRF_CRYPTO_AES_BLOCK_SIZE,
p_ctx->cbc_mac.backend.iv,
(uint8_t const *)p_data_in + i,
p_data_out);
if (error != 0)
{
return error;
}
}
return error;
}
static ret_code_t backend_mbedtls_cbc_mac_finalize(void * const p_context,
uint8_t * p_data_in,
size_t data_size,
uint8_t * p_data_out,
size_t * p_data_out_size)
{
int error;
if (*p_data_out_size < NRF_CRYPTO_AES_BLOCK_SIZE)
{
return NRF_ERROR_CRYPTO_OUTPUT_LENGTH;
}
/* this function does not support padding */
if ((data_size & 0xF) != 0)
{
return NRF_ERROR_CRYPTO_INPUT_LENGTH;
}
error = backend_mbedtls_cbc_mac_update(p_context, p_data_in, data_size, p_data_out);
BACKEND_ERROR_CHECK(error);
*p_data_out_size = NRF_CRYPTO_AES_BLOCK_SIZE;
return NRF_SUCCESS;
}
static ret_code_t backend_mbedtls_cbc_mac_padding_finalize(void * const p_context,
uint8_t * p_data_in,
size_t data_size,
uint8_t * p_data_out,
size_t * p_data_out_size)
{
ret_code_t ret_val;
uint8_t padding_buffer[NRF_CRYPTO_AES_BLOCK_SIZE] = {0};
uint8_t msg_ending = (uint8_t)(data_size & (size_t)0x0F);
if (*p_data_out_size < NRF_CRYPTO_AES_BLOCK_SIZE)
{
/* output buffer too small */
return NRF_ERROR_CRYPTO_OUTPUT_LENGTH;
}
data_size -= msg_ending;
if (data_size > 0)
{
ret_val = backend_mbedtls_cbc_mac_update(p_context,
p_data_in,
data_size,
p_data_out);
VERIFY_SUCCESS(ret_val);
}
ret_val = padding_pkcs7_add(&padding_buffer[0],
p_data_in + data_size,
msg_ending);
VERIFY_SUCCESS(ret_val);
ret_val = backend_mbedtls_cbc_mac_finalize(p_context,
&padding_buffer[0],
NRF_CRYPTO_AES_BLOCK_SIZE,
p_data_out,
p_data_out_size);
VERIFY_SUCCESS(ret_val);
return ret_val;
}
#endif
static ret_code_t backend_mbedtls_update(void * const p_context,
uint8_t * p_data_in,
size_t data_size,
uint8_t * p_data_out)
{
int error;
nrf_crypto_backend_mbedtls_aes_context_t * p_ctx =
(nrf_crypto_backend_mbedtls_aes_context_t *)p_context;
switch (p_ctx->any.header.p_info->mode)
{
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC)
case NRF_CRYPTO_AES_MODE_CBC:
case NRF_CRYPTO_AES_MODE_CBC_PAD_PCKS7:
error = mbedtls_aes_crypt_cbc(&p_ctx->cbc.context,
(int)p_ctx->cbc.backend.operation,
data_size,
p_ctx->cbc.backend.iv,
(uint8_t const *)p_data_in,
p_data_out);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CTR)
case NRF_CRYPTO_AES_MODE_CTR:
{
size_t nc_off = 0;
uint8_t stream_block[NRF_CRYPTO_AES_BLOCK_SIZE];
error = mbedtls_aes_crypt_ctr(&p_ctx->ctr.context,
data_size,
&nc_off,
p_ctx->ctr.backend.iv,
stream_block,
(uint8_t const *)p_data_in,
p_data_out);
break;
}
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CFB)
case NRF_CRYPTO_AES_MODE_CFB:
error = mbedtls_aes_crypt_cfb8(&p_ctx->cfb.context,
(int)p_ctx->cfb.backend.operation,
data_size,
p_ctx->cfb.backend.iv,
(uint8_t const *)p_data_in,
p_data_out);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_ECB)
case NRF_CRYPTO_AES_MODE_ECB:
case NRF_CRYPTO_AES_MODE_ECB_PAD_PCKS7:
error = backend_mbedtls_ecb_crypt(&p_ctx->ecb, p_data_in, p_data_out, data_size);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_MAC)
case NRF_CRYPTO_AES_MODE_CBC_MAC:
case NRF_CRYPTO_AES_MODE_CBC_MAC_PAD_PCKS7:
error = backend_mbedtls_cbc_mac_update(p_context, p_data_in, data_size, p_data_out);
break;
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CMAC)
case NRF_CRYPTO_AES_MODE_CMAC:
error = mbedtls_cipher_cmac_update(&p_ctx->cmac.context,
p_data_in,
data_size);
break;
#endif
default:
return NRF_ERROR_CRYPTO_CONTEXT_NOT_INITIALIZED;
}
BACKEND_ERROR_CHECK(error);
return NRF_SUCCESS;
}
static ret_code_t backend_mbedtls_finalize(void * const p_context,
uint8_t * p_data_in,
size_t data_size,
uint8_t * p_data_out,
size_t * p_data_out_size)
{
ret_code_t ret_val;
nrf_crypto_backend_mbedtls_aes_context_t * p_ctx =
(nrf_crypto_backend_mbedtls_aes_context_t *)p_context;
if (*p_data_out_size < data_size)
{
return NRF_ERROR_CRYPTO_OUTPUT_LENGTH;
}
/* data is not multiple of 16 bytes */
if ((data_size & 0x0F) != 0)
{
if ((p_ctx->any.header.p_info->mode != NRF_CRYPTO_AES_MODE_CTR) &&
(p_ctx->any.header.p_info->mode != NRF_CRYPTO_AES_MODE_CFB))
{
/* There are separate handlers for AES modes with padding and for MAC modes. */
return NRF_ERROR_CRYPTO_INPUT_LENGTH;
}
}
ret_val = backend_mbedtls_update(p_context, p_data_in, data_size, p_data_out);
VERIFY_SUCCESS(ret_val);
*p_data_out_size = data_size;
return ret_val;
}
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CMAC)
static ret_code_t backend_mbedtls_cmac_finalize(void * const p_context,
uint8_t * p_data_in,
size_t data_size,
uint8_t * p_data_out,
size_t * p_data_out_size)
{
int error;
nrf_crypto_backend_mbedtls_aes_context_t * p_ctx =
(nrf_crypto_backend_mbedtls_aes_context_t *)p_context;
if (*p_data_out_size < NRF_CRYPTO_AES_BLOCK_SIZE)
{
return NRF_ERROR_CRYPTO_OUTPUT_LENGTH;
}
error = mbedtls_cipher_cmac_update(&p_ctx->cmac.context, p_data_in, data_size);
BACKEND_ERROR_CHECK(error);
error = mbedtls_cipher_cmac_finish(&p_ctx->cmac.context, p_data_out);
BACKEND_ERROR_CHECK(error);
*p_data_out_size = NRF_CRYPTO_AES_BLOCK_SIZE;
return NRF_SUCCESS;
}
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC) || \
NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_ECB)
static ret_code_t backend_mbedtls_padding_finalize(void * const p_context,
uint8_t * p_data_in,
size_t data_size,
uint8_t * p_data_out,
size_t * p_data_out_size)
{
ret_code_t ret_val;
size_t buff_out_size;
uint8_t padding_buffer[NRF_CRYPTO_AES_BLOCK_SIZE] = {0};
uint8_t msg_ending = (uint8_t)(data_size & (size_t)0x0F);
nrf_crypto_backend_mbedtls_aes_context_t * p_ctx =
(nrf_crypto_backend_mbedtls_aes_context_t *)p_context;
if (p_ctx->any.backend.operation == NRF_CRYPTO_DECRYPT)
{
ret_val = backend_mbedtls_finalize(p_context,
p_data_in,
data_size,
p_data_out,
p_data_out_size);
VERIFY_SUCCESS(ret_val);
ret_val = padding_pkcs7_remove(p_data_out,
p_data_out_size);
return ret_val;
}
/* -------------- ENCRYPTION --------------*/
data_size -= msg_ending;
if (*p_data_out_size < (data_size + NRF_CRYPTO_AES_BLOCK_SIZE))
{
/* no space for padding */
return NRF_ERROR_CRYPTO_OUTPUT_LENGTH;
}
if (data_size > 0)
{
/* Encrypt 16 byte blocks */
ret_val = backend_mbedtls_update(p_context,
p_data_in,
data_size,
p_data_out);
VERIFY_SUCCESS(ret_val);
}
ret_val = padding_pkcs7_add(&padding_buffer[0],
p_data_in + data_size,
msg_ending);
VERIFY_SUCCESS(ret_val);
buff_out_size = *p_data_out_size - data_size;
ret_val = backend_mbedtls_finalize(p_context,
&padding_buffer[0],
NRF_CRYPTO_AES_BLOCK_SIZE,
p_data_out + data_size,
&buff_out_size);
VERIFY_SUCCESS(ret_val);
*p_data_out_size = buff_out_size + data_size;
return ret_val;
}
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC)
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cbc_128_info =
{
.mode = NRF_CRYPTO_AES_MODE_CBC,
.key_size = NRF_CRYPTO_KEY_SIZE_128,
.context_size = sizeof(nrf_crypto_backend_aes_cbc_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cbc_192_info =
{
.mode = NRF_CRYPTO_AES_MODE_CBC,
.key_size = NRF_CRYPTO_KEY_SIZE_192,
.context_size = sizeof(nrf_crypto_backend_aes_cbc_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cbc_256_info =
{
.mode = NRF_CRYPTO_AES_MODE_CBC,
.key_size = NRF_CRYPTO_KEY_SIZE_256,
.context_size = sizeof(nrf_crypto_backend_aes_cbc_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cbc_128_pad_pkcs7_info =
{
.mode = NRF_CRYPTO_AES_MODE_CBC_PAD_PCKS7,
.key_size = NRF_CRYPTO_KEY_SIZE_128,
.context_size = sizeof(nrf_crypto_backend_aes_cbc_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_padding_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cbc_192_pad_pkcs7_info =
{
.mode = NRF_CRYPTO_AES_MODE_CBC_PAD_PCKS7,
.key_size = NRF_CRYPTO_KEY_SIZE_192,
.context_size = sizeof(nrf_crypto_backend_aes_cbc_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_padding_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cbc_256_pad_pkcs7_info =
{
.mode = NRF_CRYPTO_AES_MODE_CBC_PAD_PCKS7,
.key_size = NRF_CRYPTO_KEY_SIZE_256,
.context_size = sizeof(nrf_crypto_backend_aes_cbc_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_padding_finalize
};
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CTR)
nrf_crypto_aes_info_t const g_nrf_crypto_aes_ctr_128_info =
{
.mode = NRF_CRYPTO_AES_MODE_CTR,
.key_size = NRF_CRYPTO_KEY_SIZE_128,
.context_size = sizeof(nrf_crypto_backend_aes_ctr_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_ctr_192_info =
{
.mode = NRF_CRYPTO_AES_MODE_CTR,
.key_size = NRF_CRYPTO_KEY_SIZE_192,
.context_size = sizeof(nrf_crypto_backend_aes_ctr_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_ctr_256_info =
{
.mode = NRF_CRYPTO_AES_MODE_CTR,
.key_size = NRF_CRYPTO_KEY_SIZE_256,
.context_size = sizeof(nrf_crypto_backend_aes_ctr_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_finalize
};
#endif
// CFB
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CFB)
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cfb_128_info =
{
.mode = NRF_CRYPTO_AES_MODE_CFB,
.key_size = NRF_CRYPTO_KEY_SIZE_128,
.context_size = sizeof(nrf_crypto_backend_aes_cfb_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cfb_192_info =
{
.mode = NRF_CRYPTO_AES_MODE_CFB,
.key_size = NRF_CRYPTO_KEY_SIZE_192,
.context_size = sizeof(nrf_crypto_backend_aes_cfb_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cfb_256_info =
{
.mode = NRF_CRYPTO_AES_MODE_CFB,
.key_size = NRF_CRYPTO_KEY_SIZE_256,
.context_size = sizeof(nrf_crypto_backend_aes_cfb_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_finalize
};
#endif
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_ECB)
nrf_crypto_aes_info_t const g_nrf_crypto_aes_ecb_128_info =
{
.mode = NRF_CRYPTO_AES_MODE_ECB,
.key_size = NRF_CRYPTO_KEY_SIZE_128,
.context_size = sizeof(nrf_crypto_backend_aes_ecb_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = NULL,
.iv_get_fn = NULL,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_ecb_192_info =
{
.mode = NRF_CRYPTO_AES_MODE_ECB,
.key_size = NRF_CRYPTO_KEY_SIZE_192,
.context_size = sizeof(nrf_crypto_backend_aes_ecb_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = NULL,
.iv_get_fn = NULL,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_ecb_256_info =
{
.mode = NRF_CRYPTO_AES_MODE_ECB,
.key_size = NRF_CRYPTO_KEY_SIZE_256,
.context_size = sizeof(nrf_crypto_backend_aes_ecb_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = NULL,
.iv_get_fn = NULL,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_ecb_128_pad_pkcs7_info =
{
.mode = NRF_CRYPTO_AES_MODE_ECB_PAD_PCKS7,
.key_size = NRF_CRYPTO_KEY_SIZE_128,
.context_size = sizeof(nrf_crypto_backend_aes_ecb_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = NULL,
.iv_get_fn = NULL,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_padding_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_ecb_192_pad_pkcs7_info =
{
.mode = NRF_CRYPTO_AES_MODE_ECB_PAD_PCKS7,
.key_size = NRF_CRYPTO_KEY_SIZE_192,
.context_size = sizeof(nrf_crypto_backend_aes_ecb_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = NULL,
.iv_get_fn = NULL,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_padding_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_ecb_256_pad_pkcs7_info =
{
.mode = NRF_CRYPTO_AES_MODE_ECB_PAD_PCKS7,
.key_size = NRF_CRYPTO_KEY_SIZE_256,
.context_size = sizeof(nrf_crypto_backend_aes_ecb_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = NULL,
.iv_get_fn = NULL,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_padding_finalize
};
#endif
// CBC MAC
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_MAC)
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cbc_mac_128_info =
{
.mode = NRF_CRYPTO_AES_MODE_CBC_MAC,
.key_size = NRF_CRYPTO_KEY_SIZE_128,
.context_size = sizeof(nrf_crypto_backend_aes_cbc_mac_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_cbc_mac_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cbc_mac_192_info =
{
.mode = NRF_CRYPTO_AES_MODE_CBC_MAC,
.key_size = NRF_CRYPTO_KEY_SIZE_192,
.context_size = sizeof(nrf_crypto_backend_aes_cbc_mac_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_cbc_mac_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cbc_mac_256_info =
{
.mode = NRF_CRYPTO_AES_MODE_CBC_MAC,
.key_size = NRF_CRYPTO_KEY_SIZE_256,
.context_size = sizeof(nrf_crypto_backend_aes_cbc_mac_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_cbc_mac_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cbc_mac_128_pad_pkcs7_info =
{
.mode = NRF_CRYPTO_AES_MODE_CBC_MAC_PAD_PCKS7,
.key_size = NRF_CRYPTO_KEY_SIZE_128,
.context_size = sizeof(nrf_crypto_backend_aes_cbc_mac_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_cbc_mac_padding_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cbc_mac_192_pad_pkcs7_info =
{
.mode = NRF_CRYPTO_AES_MODE_CBC_MAC_PAD_PCKS7,
.key_size = NRF_CRYPTO_KEY_SIZE_192,
.context_size = sizeof(nrf_crypto_backend_aes_cbc_mac_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_cbc_mac_padding_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cbc_mac_256_pad_pkcs7_info =
{
.mode = NRF_CRYPTO_AES_MODE_CBC_MAC_PAD_PCKS7,
.key_size = NRF_CRYPTO_KEY_SIZE_256,
.context_size = sizeof(nrf_crypto_backend_aes_cbc_mac_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = backend_mbedtls_iv_set,
.iv_get_fn = backend_mbedtls_iv_get,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_cbc_mac_padding_finalize
};
#endif
// CMAC
#if NRF_MODULE_ENABLED(NRF_CRYPTO_BACKEND_MBEDTLS_AES_CMAC)
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cmac_128_info =
{
.mode = NRF_CRYPTO_AES_MODE_CMAC,
.key_size = NRF_CRYPTO_KEY_SIZE_128,
.context_size = sizeof(nrf_crypto_backend_aes_cmac_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = NULL,
.iv_get_fn = NULL,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_cmac_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cmac_192_info =
{
.mode = NRF_CRYPTO_AES_MODE_CMAC,
.key_size = NRF_CRYPTO_KEY_SIZE_192,
.context_size = sizeof(nrf_crypto_backend_aes_cmac_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = NULL,
.iv_get_fn = NULL,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_cmac_finalize
};
nrf_crypto_aes_info_t const g_nrf_crypto_aes_cmac_256_info =
{
.mode = NRF_CRYPTO_AES_MODE_CMAC,
.key_size = NRF_CRYPTO_KEY_SIZE_256,
.context_size = sizeof(nrf_crypto_backend_aes_cmac_context_t),
.init_fn = backend_mbedtls_init,
.uninit_fn = backend_mbedtls_uninit,
.key_set_fn = backend_mbedtls_key_set,
.iv_set_fn = NULL,
.iv_get_fn = NULL,
.update_fn = backend_mbedtls_update,
.finalize_fn = backend_mbedtls_cmac_finalize
};
#endif
#endif // #if NRF_MODULE_ENABLED(NRF_CRYPTO_MBEDTLS_AES)
#endif // MODULE_ENABLED(NRF_CRYPTO)