]> git.sur5r.net Git - freertos/blob - FreeRTOS-Plus/CyaSSL/cyassl/ctaocrypt/random.h
Commit 3 RX100 low power demos.
[freertos] / FreeRTOS-Plus / CyaSSL / cyassl / ctaocrypt / random.h
1 /* random.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 CTAO_CRYPT_RANDOM_H
24 #define CTAO_CRYPT_RANDOM_H
25
26 #include <cyassl/ctaocrypt/arc4.h>
27
28 #ifdef __cplusplus
29     extern "C" {
30 #endif
31
32
33 #if defined(USE_WINDOWS_API)
34     #if defined(_WIN64)
35         typedef unsigned __int64 ProviderHandle;
36         /* type HCRYPTPROV, avoid #include <windows.h> */
37     #else
38         typedef unsigned long ProviderHandle;
39     #endif
40 #endif
41
42
43 /* OS specific seeder */
44 typedef struct OS_Seed {
45     #if defined(USE_WINDOWS_API)
46         ProviderHandle handle;
47     #else
48         int fd;
49     #endif
50 } OS_Seed;
51
52 CYASSL_LOCAL
53 int GenerateSeed(OS_Seed* os, byte* seed, word32 sz);
54
55
56 /* secure Random Nnumber Generator */
57 typedef struct RNG {
58     OS_Seed seed;
59     Arc4    cipher;
60 } RNG;
61
62
63 CYASSL_API int  InitRng(RNG*);
64 CYASSL_API void RNG_GenerateBlock(RNG*, byte*, word32 sz);
65 CYASSL_API byte RNG_GenerateByte(RNG*);
66
67
68 #ifdef __cplusplus
69     } /* extern "C" */
70 #endif
71
72 #endif /* CTAO_CRYPT_RANDOM_H */
73