/* scal_trivium.c */ /* This file is part of the AVR-Crypto-Lib. Copyright (C) 2006-2015 Daniel Otte (bg@nerilex.org) 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, 3, KS_INT(32), KS_INT(64), 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 */ 8, /* blocksize */ {(void_fpt)trivium_init}, /* init function pointer */ {(void_fpt)trivium_getbyte}, /* 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 */ };