]> git.sur5r.net Git - freertos/blob - FreeRTOS-Plus/Source/CyaSSL/cyassl/ctaocrypt/ripemd.h
de062698c33563125dca5cd90d18ceec472c7512
[freertos] / FreeRTOS-Plus / Source / CyaSSL / cyassl / ctaocrypt / ripemd.h
1 /* ripemd.h
2  *
3  * Copyright (C) 2006-2014 wolfSSL Inc.
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
20  */
21
22
23 #ifdef CYASSL_RIPEMD
24
25 #ifndef CTAO_CRYPT_RIPEMD_H
26 #define CTAO_CRYPT_RIPEME_H
27
28 #include <cyassl/ctaocrypt/types.h>
29
30 #ifdef __cplusplus
31     extern "C" {
32 #endif
33
34
35 /* in bytes */
36 enum {
37     RIPEMD             =  3,    /* hash type unique */
38     RIPEMD_BLOCK_SIZE  = 64,
39     RIPEMD_DIGEST_SIZE = 20,
40     RIPEMD_PAD_SIZE    = 56
41 };
42
43
44 /* RipeMd 160 digest */
45 typedef struct RipeMd {
46     word32  buffLen;   /* in bytes          */
47     word32  loLen;     /* length in bytes   */
48     word32  hiLen;     /* length in bytes   */
49     word32  digest[RIPEMD_DIGEST_SIZE / sizeof(word32)];
50     word32  buffer[RIPEMD_BLOCK_SIZE  / sizeof(word32)];
51 } RipeMd;
52
53
54 CYASSL_API void InitRipeMd(RipeMd*);
55 CYASSL_API void RipeMdUpdate(RipeMd*, const byte*, word32);
56 CYASSL_API void RipeMdFinal(RipeMd*, byte*);
57
58
59 #ifdef __cplusplus
60     } /* extern "C" */
61 #endif
62
63 #endif /* CTAO_CRYPT_RIPEMD_H */
64 #endif /* CYASSL_RIPEMD */