]> git.sur5r.net Git - freertos/blob - FreeRTOS-Plus/Source/CyaSSL/cyassl/ctaocrypt/hc128.h
d3e5f21e84dd50f7381d418661e177f5cda6c859
[freertos] / FreeRTOS-Plus / Source / CyaSSL / cyassl / ctaocrypt / hc128.h
1 /* hc128.h
2  *
3  * Copyright (C) 2006-2012 Sawtooth Consulting Ltd.
4  *
5  * This file is part of CyaSSL.
6  *
7  * CyaSSL is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 2 of the License, or
10  * (at your option) any later version.
11  *
12  * CyaSSL is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software
19  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
20  */
21
22
23 #ifndef NO_HC128
24
25 #ifndef CTAO_CRYPT_HC128_H
26 #define CTAO_CRYPT_HC128_H
27
28 #include <cyassl/ctaocrypt/types.h>
29
30 #ifdef __cplusplus
31     extern "C" {
32 #endif
33
34
35 enum {
36         HC128_ENC_TYPE    =  6    /* cipher unique type */
37 };
38
39 /* HC-128 stream cipher */
40 typedef struct HC128 {
41     word32 T[1024];             /* P[i] = T[i];  Q[i] = T[1024 + i ]; */
42     word32 X[16];
43     word32 Y[16];
44     word32 counter1024;         /* counter1024 = i mod 1024 at the ith step */
45     word32 key[8];
46     word32 iv[8];
47 } HC128;
48
49
50 CYASSL_API void Hc128_Process(HC128*, byte*, const byte*, word32);
51 CYASSL_API void Hc128_SetKey(HC128*, const byte* key, const byte* iv);
52
53
54 #ifdef __cplusplus
55     } /* extern "C" */
56 #endif
57
58 #endif /* CTAO_CRYPT_HC128_H */
59
60 #endif /* HAVE_HC128 */