block_cipher: add setkey()
Signed-off-by: Manuel Pégourié-Gonnard <manuel.pegourie-gonnard@arm.com>
This commit is contained in:
parent
21718769d1
commit
3e0884fc53
3 changed files with 68 additions and 2 deletions
|
@ -66,4 +66,25 @@ int mbedtls_block_cipher_setup(mbedtls_block_cipher_context_t *ctx,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int mbedtls_block_cipher_setkey(mbedtls_block_cipher_context_t *ctx,
|
||||||
|
const unsigned char *key,
|
||||||
|
unsigned key_bitlen)
|
||||||
|
{
|
||||||
|
switch (ctx->id) {
|
||||||
|
#if defined(MBEDTLS_AES_C)
|
||||||
|
case MBEDTLS_BLOCK_CIPHER_ID_AES:
|
||||||
|
return mbedtls_aes_setkey_enc(&ctx->ctx.aes, key, key_bitlen);
|
||||||
|
#endif
|
||||||
|
#if defined(MBEDTLS_ARIA_C)
|
||||||
|
case MBEDTLS_BLOCK_CIPHER_ID_ARIA:
|
||||||
|
return mbedtls_aria_setkey_enc(&ctx->ctx.aria, key, key_bitlen);
|
||||||
|
#endif
|
||||||
|
#if defined(MBEDTLS_CAMELLIA_C)
|
||||||
|
case MBEDTLS_BLOCK_CIPHER_ID_CAMELLIA:
|
||||||
|
return mbedtls_camellia_setkey_enc(&ctx->ctx.camellia, key, key_bitlen);
|
||||||
|
#endif
|
||||||
|
default:
|
||||||
|
return MBEDTLS_ERR_CIPHER_INVALID_CONTEXT;
|
||||||
|
}
|
||||||
|
}
|
||||||
#endif /* MBEDTLS_BLOCK_CIPHER_C */
|
#endif /* MBEDTLS_BLOCK_CIPHER_C */
|
||||||
|
|
|
@ -49,6 +49,24 @@ static inline void mbedtls_block_cipher_init(mbedtls_block_cipher_context_t *ctx
|
||||||
int mbedtls_block_cipher_setup(mbedtls_block_cipher_context_t *ctx,
|
int mbedtls_block_cipher_setup(mbedtls_block_cipher_context_t *ctx,
|
||||||
mbedtls_cipher_id_t cipher_id);
|
mbedtls_cipher_id_t cipher_id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Set the key into the context.
|
||||||
|
*
|
||||||
|
* \param ctx The context to configure.
|
||||||
|
* \param key The buffer holding the key material.
|
||||||
|
* \param key_bitlen The size of the key in bits.
|
||||||
|
*
|
||||||
|
* \retval \c 0 on success.
|
||||||
|
* \retval #MBEDTLS_ERR_CIPHER_INVALID_CONTEXT if the context was not
|
||||||
|
* properly set up before calling this function.
|
||||||
|
* \retval One of #MBEDTLS_ERR_AES_INVALID_KEY_LENGTH,
|
||||||
|
* #MBEDTLS_ERR_ARIA_BAD_INPUT_DATA,
|
||||||
|
* #MBEDTLS_ERR_CAMELLIA_BAD_INPUT_DATA if \p key_bitlen is
|
||||||
|
* invalid.
|
||||||
|
*/
|
||||||
|
int mbedtls_block_cipher_setkey(mbedtls_block_cipher_context_t *ctx,
|
||||||
|
const unsigned char *key,
|
||||||
|
unsigned key_bitlen);
|
||||||
/**
|
/**
|
||||||
* \brief Clear the context.
|
* \brief Clear the context.
|
||||||
*
|
*
|
||||||
|
|
|
@ -2,6 +2,19 @@
|
||||||
#include "block_cipher_internal.h"
|
#include "block_cipher_internal.h"
|
||||||
|
|
||||||
#define BLOCK_SIZE 16
|
#define BLOCK_SIZE 16
|
||||||
|
|
||||||
|
#if defined(MBEDTLS_AES_C)
|
||||||
|
#define VALID_CIPHER_ID MBEDTLS_CIPHER_ID_AES
|
||||||
|
#define BADKEY_ERROR MBEDTLS_ERR_AES_INVALID_KEY_LENGTH
|
||||||
|
#elif defined(MBEDTLS_ARIA_C)
|
||||||
|
#define VALID_CIPHER_ID MBEDTLS_CIPHER_ID_ARIA
|
||||||
|
#define BADKEY_ERROR MBEDTLS_ERR_ARIA_BAD_INPUT_DATA
|
||||||
|
#elif defined(MBEDTLS_CAMELLIA_C)
|
||||||
|
#define VALID_CIPHER_ID MBEDTLS_CIPHER_ID_CAMELLIA
|
||||||
|
#define BADKEY_ERROR MBEDTLS_ERR_CAMELLIA_BAD_INPUT_DATA
|
||||||
|
#else
|
||||||
|
#undef VALID_CIPHER_ID
|
||||||
|
#endif
|
||||||
/* END_HEADER */
|
/* END_HEADER */
|
||||||
|
|
||||||
/* BEGIN_DEPENDENCIES
|
/* BEGIN_DEPENDENCIES
|
||||||
|
@ -9,19 +22,33 @@
|
||||||
* END_DEPENDENCIES
|
* END_DEPENDENCIES
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* BEGIN_CASE */
|
/* BEGIN_CASE depends_on:VALID_CIPHER_ID */
|
||||||
void invalid()
|
void invalid()
|
||||||
{
|
{
|
||||||
|
/* That size is valid for a key or an input/output block. */
|
||||||
|
unsigned char buf[16] = { 0 };
|
||||||
|
|
||||||
mbedtls_block_cipher_context_t ctx;
|
mbedtls_block_cipher_context_t ctx;
|
||||||
|
|
||||||
mbedtls_block_cipher_init(&ctx);
|
mbedtls_block_cipher_init(&ctx);
|
||||||
|
|
||||||
|
/* Bad parameters to setup */
|
||||||
TEST_EQUAL(MBEDTLS_ERR_CIPHER_BAD_INPUT_DATA,
|
TEST_EQUAL(MBEDTLS_ERR_CIPHER_BAD_INPUT_DATA,
|
||||||
mbedtls_block_cipher_setup(&ctx, MBEDTLS_CIPHER_ID_NONE));
|
mbedtls_block_cipher_setup(&ctx, MBEDTLS_CIPHER_ID_NONE));
|
||||||
|
|
||||||
TEST_EQUAL(MBEDTLS_ERR_CIPHER_BAD_INPUT_DATA,
|
TEST_EQUAL(MBEDTLS_ERR_CIPHER_BAD_INPUT_DATA,
|
||||||
mbedtls_block_cipher_setup(&ctx, MBEDTLS_CIPHER_ID_DES));
|
mbedtls_block_cipher_setup(&ctx, MBEDTLS_CIPHER_ID_DES));
|
||||||
|
|
||||||
|
/* setkey() before successful setup() */
|
||||||
|
TEST_EQUAL(MBEDTLS_ERR_CIPHER_INVALID_CONTEXT,
|
||||||
|
mbedtls_block_cipher_setkey(&ctx, buf, 128));
|
||||||
|
|
||||||
|
/* Now properly setup the context */
|
||||||
|
TEST_EQUAL(0, mbedtls_block_cipher_setup(&ctx, VALID_CIPHER_ID));
|
||||||
|
|
||||||
|
/* Bad parameters to setkey() */
|
||||||
|
TEST_EQUAL(BADKEY_ERROR,
|
||||||
|
mbedtls_block_cipher_setkey(&ctx, buf, 42));
|
||||||
|
|
||||||
exit:
|
exit:
|
||||||
mbedtls_block_cipher_free(&ctx);
|
mbedtls_block_cipher_free(&ctx);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue