X-Git-Url: https://git.cryptolib.org/?p=avr-crypto-lib.git;a=blobdiff_plain;f=scal%2Fscal_trivium.c;fp=scal%2Fscal_trivium.c;h=a8a2789f79ceab0319975e21fcd79e52d77db0db;hp=0000000000000000000000000000000000000000;hb=12b222bf434f472559a8791acdb57c0f154111fb;hpb=66c915087d1f7b8eb7280be43c16e9588faf2e55 diff --git a/scal/scal_trivium.c b/scal/scal_trivium.c new file mode 100644 index 0000000..a8a2789 --- /dev/null +++ b/scal/scal_trivium.c @@ -0,0 +1,56 @@ +/* scal_trivium.c */ +/* + This file is part of the AVR-Crypto-Lib. + Copyright (C) 2011 Daniel Otte (daniel.otte@rub.de) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . +*/ + +#include +#include +#include +#include "streamcipher_descriptor.h" +#include "keysize_descriptor.h" + +#include "trivium.h" + +const char trivium_str[] PROGMEM = "Trivium"; + +const uint8_t trivium_keysize_desc[] PROGMEM = { + KS_TYPE_LIST, 1, KS_INT(80), + KS_TYPE_TERMINATOR }; + +const uint8_t trivium_ivsize_desc[] PROGMEM = { + KS_TYPE_LIST, 2, KS_INT(32), KS_INT(80), + KS_TYPE_TERMINATOR }; + +const scdesc_t trivium_desc PROGMEM = { + SCDESC_TYPE_STREAMCIPHER, /* abstraction layer type designator */ + SC_INIT_TYPE_5|SC_GEN_TYPE_1, /* flags*/ + trivium_str, /* name string pointer */ + sizeof(trivium_ctx_t), /* size of context */ + 1, /* blocksize */ + {(void_fpt)trivium_init}, /* init function pointer */ + {(void_fpt)trivium_enc}, /* key stream generator function pointer */ + {(void_fpt)NULL}, /* key stream generator for random access function pointer */ + (sc_free_fpt)NULL, /* free function pointer */ + trivium_keysize_desc, /* key size descriptor pointer */ + trivium_ivsize_desc /* iv size descriptor pointer */ +}; + + + + + +