/* * Copyright (C) 2013 Freie Universität Berlin, Computer Systems & Telematics * * 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. */ /** * @ingroup sys_crypto * @{ * * @file * @brief Headers for the packet encryption class. They are used to encrypt single packets. * * @author Freie Universitaet Berlin, Computer Systems & Telematics * @author Nicolai Schmittberger * @author Zakaria Kasmi * @author Mark Essien */ #ifndef __CIPHERS_H_ #define __CIPHERS_H_ #ifdef __cplusplus extern "C" { #endif /* Shared header file for all cipher algorithms */ /* Set the algorithms that should be compiled in here. When these defines * are set, then packets will be compiled 5 times. * * */ #define AES // #define RC5 // #define THREEDES // #define AES // #define TWOFISH // #define SKIPJACK /** @brief the length of keys in bytes */ #define PARSEC_MAX_BLOCK_CIPHERS 5 #define CIPHERS_KEYSIZE 20 /** * @brief the context for cipher-operations * always order by number of bytes descending!!!
* rc5 needs 104 bytes
* threedes needs 24 bytes
* aes needs PARSEC_KEYSIZE bytes
* twofish needs PARSEC_KEYSIZE bytes
* skipjack needs 20 bytes
* identity needs 1 byte
*/ typedef struct { #if defined(RC5) uint8_t context[104]; /**< supports RC5 and lower */ #elif defined(THREEDES) uint8_t context[24]; /**< supports ThreeDES and lower */ #elif defined(AES) uint8_t context[CIPHERS_KEYSIZE]; /**< supports AES and lower */ #elif defined(TWOFISH) uint8_t context[CIPHERS_KEYSIZE]; /**< supports TwoFish and lower */ #elif defined(SKIPJACK) uint8_t context[20]; /**< supports SkipJack and lower */ #endif } cipher_context_t; /** * @brief BlockCipher-Interface for the Cipher-Algorithms */ typedef struct { /** the name of the cipher algorithm as a string */ char name[10]; /** the init function */ int (*BlockCipher_init)(cipher_context_t *context, uint8_t blockSize, uint8_t keySize, uint8_t *key); /** the encrypt function */ int (*BlockCipher_encrypt)(cipher_context_t *context, uint8_t *plainBlock, uint8_t *cipherBlock); /** the decrypt function */ int (*BlockCipher_decrypt)(cipher_context_t *context, uint8_t *cipherBlock, uint8_t *plainBlock); /** the setupKey function */ int (*setupKey)(cipher_context_t *context, uint8_t *key, uint8_t keysize); /** read the BlockSize of this Cipher */ uint8_t (*BlockCipherInfo_getPreferredBlockSize)(void); } block_cipher_interface_t; /** * @brief The cipher mode context */ typedef struct CipherModeContext { cipher_context_t cc; /**< CipherContext for the cipher-operations */ uint8_t context[24]; /**< context for the block-cipher-modes' */ } CipherModeContext; /** * @brief struct for an archive of all available ciphers */ typedef struct { /** the number of available ciphers */ uint8_t NoCiphers; /** the ciphers in form or BlockCipherInterface_ts */ block_cipher_interface_t ciphers[PARSEC_MAX_BLOCK_CIPHERS]; } block_cipher_archive_t; #ifdef __cplusplus } #endif /** @} */ #endif /* __CIPHERS_H_ */