2013-11-28 18:12:40 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2013 Freie Universität Berlin, Computer Systems & Telematics
|
|
|
|
*
|
2014-08-23 15:43:13 +02:00
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
2013-11-28 18:12:40 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup sys_crypto
|
|
|
|
* @{
|
2014-02-11 18:15:43 +01:00
|
|
|
*
|
2015-05-22 07:34:41 +02:00
|
|
|
* @file
|
2013-11-28 18:12:40 +01:00
|
|
|
* @brief Headers for the implementation of the AES cipher-algorithm
|
|
|
|
*
|
2021-04-14 22:18:59 +02:00
|
|
|
* The default key size is 128 bits. To use a different key size add
|
|
|
|
* USEMODULE += crypto_aes_192 and/or USEMODULE += crypto_aes_256 to
|
|
|
|
* your Makefile.
|
|
|
|
*
|
|
|
|
* If only one key size is needed and that key size is not 128 bits, the 128 bit
|
|
|
|
* key size can be disabled with DISABLE_MODULE += crypto_aes_128 as an
|
|
|
|
* optimization.
|
|
|
|
*
|
2013-11-28 18:12:40 +01:00
|
|
|
* @author Freie Universitaet Berlin, Computer Systems & Telematics
|
|
|
|
* @author Nicolai Schmittberger <nicolai.schmittberger@fu-berlin.de>
|
|
|
|
* @author Fabrice Bellard
|
|
|
|
* @author Zakaria Kasmi <zkasmi@inf.fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#ifndef CRYPTO_AES_H
|
|
|
|
#define CRYPTO_AES_H
|
2013-11-28 18:12:40 +01:00
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "crypto/ciphers.h"
|
|
|
|
|
2014-10-10 11:51:11 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
2013-11-28 18:12:40 +01:00
|
|
|
|
|
|
|
typedef uint32_t u32;
|
|
|
|
typedef uint16_t u16;
|
|
|
|
typedef uint8_t u8;
|
|
|
|
|
|
|
|
# define GETU32(pt) (((u32)(pt)[0] << 24) ^ ((u32)(pt)[1] << 16) ^ \
|
2018-10-17 14:05:06 +02:00
|
|
|
((u32)(pt)[2] << 8) ^ ((u32)(pt)[3]))
|
2013-11-28 18:12:40 +01:00
|
|
|
# define PUTU32(ct, st) { (ct)[0] = (u8)((st) >> 24); \
|
2018-10-17 14:05:06 +02:00
|
|
|
(ct)[1] = (u8)((st) >> 16); \
|
|
|
|
(ct)[2] = (u8)((st) >> 8); \
|
|
|
|
(ct)[3] = (u8)(st); }
|
2013-11-28 18:12:40 +01:00
|
|
|
|
|
|
|
#define AES_MAXNR 14
|
|
|
|
#define AES_BLOCK_SIZE 16
|
2021-04-14 22:18:59 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @name AES key sizes
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define AES_KEY_SIZE_128 16
|
|
|
|
#define AES_KEY_SIZE_192 24
|
|
|
|
#define AES_KEY_SIZE_256 32
|
|
|
|
/** @} */
|
2013-11-28 18:12:40 +01:00
|
|
|
|
2014-12-06 11:55:28 +01:00
|
|
|
/**
|
|
|
|
* @brief AES key
|
|
|
|
* @see cipher_context_t
|
|
|
|
*/
|
2021-04-14 22:18:59 +02:00
|
|
|
typedef struct aes_key_st {
|
2014-12-06 11:55:28 +01:00
|
|
|
/** @cond INTERNAL */
|
2013-11-28 18:12:40 +01:00
|
|
|
uint32_t rd_key[4 * (AES_MAXNR + 1)];
|
|
|
|
int rounds;
|
2014-12-06 11:55:28 +01:00
|
|
|
/** @endcond */
|
2021-04-14 22:18:59 +02:00
|
|
|
} AES_KEY;
|
2013-11-28 18:12:40 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief the cipher_context_t-struct adapted for AES
|
|
|
|
*/
|
|
|
|
typedef struct {
|
2014-12-06 11:55:28 +01:00
|
|
|
/** context data buffer */
|
2013-11-28 18:12:40 +01:00
|
|
|
uint32_t context[(4 * (AES_MAXNR + 1)) + 1];
|
|
|
|
} aes_context_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief initializes the AES Cipher-algorithm with the passed parameters
|
|
|
|
*
|
2018-10-13 23:04:23 +02:00
|
|
|
* @param context the cipher_context_t-struct to save the
|
|
|
|
* initialization of the cipher in
|
2013-11-28 18:12:40 +01:00
|
|
|
* @param keySize the size of the key
|
2018-10-26 16:21:50 +02:00
|
|
|
* Must be 16, since this implementation does not
|
|
|
|
* support key lengths of 24 or 32 bytes
|
2013-11-28 18:12:40 +01:00
|
|
|
* @param key a pointer to the key
|
|
|
|
*
|
2016-10-04 10:03:47 +02:00
|
|
|
* @return CIPHER_INIT_SUCCESS if the initialization was successful.
|
2018-10-13 23:04:23 +02:00
|
|
|
* @return CIPHER_ERR_BAD_CONTEXT_SIZE if CIPHER_MAX_CONTEXT_SIZE has not
|
|
|
|
* been defined (which means that the cipher has not been included
|
|
|
|
* in the build)
|
2013-11-28 18:12:40 +01:00
|
|
|
*/
|
2015-04-02 08:56:18 +02:00
|
|
|
int aes_init(cipher_context_t *context, const uint8_t *key, uint8_t keySize);
|
2013-11-28 18:12:40 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief encrypts one plainBlock-block and saves the result in cipherblock.
|
|
|
|
* encrypts one blocksize long block of plaintext pointed to by
|
|
|
|
* plainBlock to one blocksize long block of ciphertext which will be
|
|
|
|
* written to the the memory-area pointed to by cipherBlock
|
|
|
|
*
|
2014-11-30 22:34:50 +01:00
|
|
|
* @param context the cipher_context_t-struct to use for this
|
|
|
|
* encryption
|
|
|
|
* @param plain_block a pointer to the plaintext-block (of size
|
|
|
|
* blocksize)
|
|
|
|
* @param cipher_block a pointer to the place where the ciphertext will
|
|
|
|
* be stored
|
2013-11-28 18:12:40 +01:00
|
|
|
*
|
2018-10-13 23:04:23 +02:00
|
|
|
* @return 1 on success
|
|
|
|
* @return A negative value if the cipher key cannot be expanded with the
|
|
|
|
* AES key schedule
|
2013-11-28 18:12:40 +01:00
|
|
|
*/
|
2015-04-02 08:56:18 +02:00
|
|
|
int aes_encrypt(const cipher_context_t *context, const uint8_t *plain_block,
|
2013-11-28 18:12:40 +01:00
|
|
|
uint8_t *cipher_block);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief decrypts one cipher-block and saves the plain-block in plainBlock.
|
|
|
|
* decrypts one blocksize long block of ciphertext pointed to by
|
|
|
|
* cipherBlock to one blocksize long block of plaintext and stores
|
|
|
|
* the plaintext in the memory-area pointed to by plainBlock
|
|
|
|
*
|
2014-11-30 22:34:50 +01:00
|
|
|
* @param context the cipher_context_t-struct to use for this
|
|
|
|
* decryption
|
|
|
|
* @param cipher_block a pointer to the ciphertext-block (of size
|
|
|
|
* blocksize) to be decrypted
|
|
|
|
* @param plain_block a pointer to the place where the decrypted
|
|
|
|
* plaintext will be stored
|
2013-11-28 18:12:40 +01:00
|
|
|
*
|
2018-10-13 23:04:23 +02:00
|
|
|
* @return 1 on success
|
|
|
|
* @return A negative value if the cipher key cannot be expanded with the
|
|
|
|
* AES key schedule
|
2013-11-28 18:12:40 +01:00
|
|
|
*/
|
2015-04-02 08:56:18 +02:00
|
|
|
int aes_decrypt(const cipher_context_t *context, const uint8_t *cipher_block,
|
2013-11-28 18:12:40 +01:00
|
|
|
uint8_t *plain_block);
|
|
|
|
|
2014-10-10 11:51:11 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2013-11-28 18:12:40 +01:00
|
|
|
/** @} */
|
2017-05-23 18:19:52 +02:00
|
|
|
#endif /* CRYPTO_AES_H */
|