]> git.cryptolib.org Git - arm-crypto-lib.git/blob - scal/scal_salsa20.c
adding salsa20
[arm-crypto-lib.git] / scal / scal_salsa20.c
1 /* scal_salsa20.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 <stdint.h>
22 #include "streamcipher_descriptor.h"
23 #include "keysize_descriptor.h"
24
25 #include "salsa20.h"
26
27 const char salsa20_str[]  = "Salsa20";
28
29 const uint8_t salsa20_keysize_desc[] = {
30                 KS_TYPE_LIST, 2, KS_INT(128), KS_INT(256),
31         KS_TYPE_TERMINATOR   };
32
33 const uint8_t salsa20_ivsize_desc[] = {
34                 KS_TYPE_LIST, 1, KS_INT(64),
35         KS_TYPE_TERMINATOR   };
36
37 const scdesc_t salsa20_desc = {
38                 SCDESC_TYPE_STREAMCIPHER,     /* abstraction layer type designator */
39                 SC_INIT_TYPE_4|SC_GEN_TYPE_1, /* flags*/
40                 salsa20_str,                  /* name string pointer */
41                 sizeof(salsa20_ctx_t),        /* size of context */
42                 8,                            /* blocksize */
43                 {(void_fpt)salsa20_init},     /* init function pointer */
44                 {(void_fpt)salsa20_gen},      /* key stream generator function pointer */
45                 {(void_fpt)NULL},             /* key stream generator for random access function pointer */
46                 (sc_free_fpt)NULL,                /* free function pointer */
47                 salsa20_keysize_desc,         /* key size descriptor pointer */
48                 salsa20_ivsize_desc           /* iv size descriptor pointer */
49 };
50
51
52
53
54
55