From ef8bf4acd51c5eba9d205506b36e66da7a7bbc8b Mon Sep 17 00:00:00 2001 From: Kévin Le Gouguec Date: Tue, 27 Nov 2018 10:16:54 +0100 Subject: Extraction de fonctions communes à ΘCB3 et SCT-2 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/ae-common.h | 69 +++++++++++++++++++++++++++++++++ src/lilliput-ae-i.c | 107 +++++++++++++--------------------------------------- 2 files changed, 95 insertions(+), 81 deletions(-) create mode 100644 src/ae-common.h (limited to 'src') diff --git a/src/ae-common.h b/src/ae-common.h new file mode 100644 index 0000000..6343f98 --- /dev/null +++ b/src/ae-common.h @@ -0,0 +1,69 @@ +#ifndef AE_COMMON_H +#define AE_COMMON_H + +#include +#include +#include + +#include "cipher.h" +#include "parameters.h" + + +static inline uint8_t upper_nibble(uint8_t i) +{ + return i >> 4; +} + +static inline uint8_t lower_nibble(uint8_t i) +{ + return i & 0x0f; +} + +static inline void encrypt(const uint8_t K[KEY_BYTES], + const uint8_t T[TWEAK_BYTES], + const uint8_t M[BLOCK_BYTES], + uint8_t C[BLOCK_BYTES]) +{ + lilliput_tbc_encrypt(K, T, M, C); +} + +static inline void decrypt(const uint8_t K[KEY_BYTES], + const uint8_t T[TWEAK_BYTES], + const uint8_t C[BLOCK_BYTES], + uint8_t M[BLOCK_BYTES]) +{ + lilliput_tbc_decrypt(K, T, C, M); +} + +static inline void xor_into(uint8_t dest[BLOCK_BYTES], const uint8_t src[BLOCK_BYTES]) +{ + for (size_t i=0; i 1) + { + memset(padded, 0, pad_len-1); + } +} + + +#endif /* AE_COMMON_H */ diff --git a/src/lilliput-ae-i.c b/src/lilliput-ae-i.c index 60a916b..5d1a630 100644 --- a/src/lilliput-ae-i.c +++ b/src/lilliput-ae-i.c @@ -2,6 +2,7 @@ #include #include +#include "ae-common.h" #include "cipher.h" #include "lilliput-ae.h" @@ -12,62 +13,6 @@ static const uint8_t _0n[BLOCK_BYTES] = { }; -static uint8_t _upper_nibble(uint8_t i) -{ - return i >> 4; -} - -static uint8_t _lower_nibble(uint8_t i) -{ - return i & 0x0f; -} - -static void _encrypt(const uint8_t K[KEY_BYTES], - const uint8_t T[TWEAK_BYTES], - const uint8_t M[BLOCK_BYTES], - uint8_t C[BLOCK_BYTES]) -{ - lilliput_tbc_encrypt(K, T, M, C); -} - -static void _decrypt(const uint8_t K[KEY_BYTES], - const uint8_t T[TWEAK_BYTES], - const uint8_t C[BLOCK_BYTES], - uint8_t M[BLOCK_BYTES]) -{ - lilliput_tbc_decrypt(K, T, C, M); -} - -static void _xor_into(uint8_t dest[BLOCK_BYTES], const uint8_t src[BLOCK_BYTES]) -{ - for (size_t i=0; i 1) - { - memset(padded, 0, pad_len-1); - } -} - static void _fill_ad_tweak( uint8_t prefix, uint64_t block_nb, @@ -119,14 +64,14 @@ static void _fill_msg_tweak( tweak[i] = b; } - tweak[sizeof(block_nb)] = _lower_nibble(N[0]) << 4; + tweak[sizeof(block_nb)] = lower_nibble(N[0]) << 4; for (size_t i=1; i