]> git.sur5r.net Git - freertos/blob - FreeRTOS-Plus/Source/CyaSSL/cyassl/ctaocrypt/dsa.h
Add FreeRTOS-Plus directory with new directory structure so it matches the FreeRTOS...
[freertos] / FreeRTOS-Plus / Source / CyaSSL / cyassl / ctaocrypt / dsa.h
1 /* dsa.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_DSA
24
25 #ifndef CTAO_CRYPT_DSA_H
26 #define CTAO_CRYPT_DSA_H
27
28 #include <cyassl/ctaocrypt/types.h>
29 #include <cyassl/ctaocrypt/integer.h>
30 #include <cyassl/ctaocrypt/random.h>
31
32 #ifdef __cplusplus
33     extern "C" {
34 #endif
35
36
37 enum {
38     DSA_PUBLIC   = 0,
39     DSA_PRIVATE  = 1
40 };
41
42 /* DSA */
43 typedef struct DsaKey {
44     mp_int p, q, g, y, x;
45     int type;                               /* public or private */
46 } DsaKey;
47
48
49 CYASSL_API void InitDsaKey(DsaKey* key);
50 CYASSL_API void FreeDsaKey(DsaKey* key);
51
52 CYASSL_API int DsaSign(const byte* digest, byte* out, DsaKey* key, RNG* rng);
53 CYASSL_API int DsaVerify(const byte* digest, const byte* sig, DsaKey* key,
54                          int* answer);
55
56 CYASSL_API int DsaPublicKeyDecode(const byte* input, word32* inOutIdx, DsaKey*,
57                                   word32);
58 CYASSL_API int DsaPrivateKeyDecode(const byte* input, word32* inOutIdx, DsaKey*,
59                                    word32);
60
61 #ifdef __cplusplus
62     } /* extern "C" */
63 #endif
64
65 #endif /* CTAO_CRYPT_DSA_H */
66 #endif /* NO_DSA */
67