]> git.cryptolib.org Git - avr-crypto-lib.git/blob - scal/scal_trivium.c
bug fixing and support for malloc instead of stack memory (some functions)
[avr-crypto-lib.git] / scal / scal_trivium.c
1 /* scal_trivium.c */
2 /*
3     This file is part of the AVR-Crypto-Lib.
4     Copyright (C) 2011  Daniel Otte (daniel.otte@rub.de)
5
6     This program is free software: you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation, either version 3 of the License, or
9     (at your option) any later version.
10
11     This program is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with this program.  If not, see <http://www.gnu.org/licenses/>.
18 */
19
20 #include <stdlib.h>
21 #include <avr/pgmspace.h>
22 #include <stdint.h>
23 #include "streamcipher_descriptor.h"
24 #include "keysize_descriptor.h"
25
26 #include "trivium.h"
27
28 const char trivium_str[]   PROGMEM = "Trivium";
29
30 const uint8_t trivium_keysize_desc[] PROGMEM = {
31                 KS_TYPE_LIST, 1, KS_INT(80),
32             KS_TYPE_TERMINATOR   };
33
34 const uint8_t trivium_ivsize_desc[] PROGMEM = {
35                 KS_TYPE_LIST, 3, KS_INT(32), KS_INT(64), KS_INT(80),
36         KS_TYPE_TERMINATOR   };
37
38 const scdesc_t trivium_desc PROGMEM = {
39                 SCDESC_TYPE_STREAMCIPHER,     /* abstraction layer type designator */
40                 SC_INIT_TYPE_5|SC_GEN_TYPE_1, /* flags*/
41                 trivium_str,                  /* name string pointer */
42                 sizeof(trivium_ctx_t),        /* size of context */
43                 8,                            /* blocksize */
44                 {(void_fpt)trivium_init},     /* init function pointer */
45                 {(void_fpt)trivium_getbyte},  /* key stream generator function pointer */
46                 {(void_fpt)NULL},             /* key stream generator for random access function pointer */
47                 (sc_free_fpt)NULL,                /* free function pointer */
48                 trivium_keysize_desc,         /* key size descriptor pointer */
49                 trivium_ivsize_desc           /* iv size descriptor pointer */
50 };
51
52
53
54
55
56