1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

sys/crypto: make AES_KEY struct private

This commit is contained in:
Benjamin Valentin 2023-02-20 18:22:00 +01:00
parent 523a39acd3
commit 2285961810
2 changed files with 16 additions and 23 deletions

View File

@ -32,8 +32,6 @@
* @} * @}
*/ */
#include <stdio.h>
#include <stdarg.h>
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
#include <stdint.h> #include <stdint.h>
@ -62,6 +60,16 @@
# define AES_KEY_SIZE(ctx) ctx->key_size # define AES_KEY_SIZE(ctx) ctx->key_size
#endif #endif
/**
* @brief AES key
* @see cipher_context_t
*/
typedef struct {
/** @cond INTERNAL */
uint32_t rd_key[4 * (AES_MAXNR + 1)];
int rounds;
/** @endcond */
} aes_key_t;
/** /**
* Interface to the aes cipher * Interface to the aes cipher
*/ */
@ -860,7 +868,7 @@ int aes_init(cipher_context_t *context, const uint8_t *key, uint8_t keySize)
* Expand the cipher key into the encryption key schedule. * Expand the cipher key into the encryption key schedule.
*/ */
static int aes_set_encrypt_key(const unsigned char *userKey, const int bits, static int aes_set_encrypt_key(const unsigned char *userKey, const int bits,
AES_KEY *key) aes_key_t *key)
{ {
u32 *rk; u32 *rk;
int i = 0; int i = 0;
@ -979,7 +987,7 @@ static int aes_set_encrypt_key(const unsigned char *userKey, const int bits,
* Expand the cipher key into the decryption key schedule. * Expand the cipher key into the decryption key schedule.
*/ */
static int aes_set_decrypt_key(const unsigned char *userKey, const int bits, static int aes_set_decrypt_key(const unsigned char *userKey, const int bits,
AES_KEY *key) aes_key_t *key)
{ {
u32 *rk; u32 *rk;
int i, j; int i, j;
@ -1062,8 +1070,8 @@ int aes_encrypt(const cipher_context_t *context, const uint8_t *plainBlock,
{ {
/* setup AES_KEY */ /* setup AES_KEY */
int res; int res;
AES_KEY aeskey; aes_key_t aeskey;
const AES_KEY *key = &aeskey; const aes_key_t *key = &aeskey;
res = aes_set_encrypt_key((unsigned char *)context->context, res = aes_set_encrypt_key((unsigned char *)context->context,
AES_KEY_SIZE(context) * 8, &aeskey); AES_KEY_SIZE(context) * 8, &aeskey);
@ -1331,8 +1339,8 @@ int aes_decrypt(const cipher_context_t *context, const uint8_t *cipherBlock,
{ {
/* setup AES_KEY */ /* setup AES_KEY */
int res; int res;
AES_KEY aeskey; aes_key_t aeskey;
const AES_KEY *key = &aeskey; const aes_key_t *key = &aeskey;
res = aes_set_decrypt_key((unsigned char *)context->context, res = aes_set_decrypt_key((unsigned char *)context->context,
AES_KEY_SIZE(context) * 8, &aeskey); AES_KEY_SIZE(context) * 8, &aeskey);

View File

@ -30,10 +30,6 @@
#ifndef CRYPTO_AES_H #ifndef CRYPTO_AES_H
#define CRYPTO_AES_H #define CRYPTO_AES_H
#include <stdio.h>
#include <stdarg.h>
#include <string.h>
#include <stdlib.h>
#include <stdint.h> #include <stdint.h>
#include "crypto/ciphers.h" #include "crypto/ciphers.h"
@ -64,17 +60,6 @@ typedef uint8_t u8;
#define AES_KEY_SIZE_256 32 #define AES_KEY_SIZE_256 32
/** @} */ /** @} */
/**
* @brief AES key
* @see cipher_context_t
*/
typedef struct aes_key_st {
/** @cond INTERNAL */
uint32_t rd_key[4 * (AES_MAXNR + 1)];
int rounds;
/** @endcond */
} AES_KEY;
/** /**
* @brief the cipher_context_t-struct adapted for AES * @brief the cipher_context_t-struct adapted for AES
*/ */