7dbdcbf6a692655716b955db638ccb8893e36823
[silc.git] / lib / silccrypt / silcrng.h
1 /*
2
3   silcrng.h 
4
5   Author: Pekka Riikonen <priikone@silcnet.org>
6
7   Copyright (C) 1997 - 2002 Pekka Riikonen
8
9   This program is free software; you can redistribute it and/or modify
10   it under the terms of the GNU General Public License as published by
11   the Free Software Foundation; version 2 of the License.
12
13   This program is distributed in the hope that it will be useful,
14   but WITHOUT ANY WARRANTY; without even the implied warranty of
15   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16   GNU General Public License for more details.
17
18 */
19
20 /****h* silccrypt/SILC RNG Interface
21  *
22  * DESCRIPTION
23  *
24  * SILC Random Number Generator is cryptographically strong pseudo random
25  * number generator. It is used to generate all the random numbers needed
26  * in the SILC sessions. All key material and other sources needing random
27  * numbers use this generator.
28  *
29  * The interface provides functions for retrieving different size of
30  * random number and arbitrary length of random data buffers. The interface
31  * also defines Global RNG API which makes it possible to call any
32  * RNG API function without specific RNG context.
33  *
34  ***/
35
36 #ifndef SILCRNG_H
37 #define SILCRNG_H
38
39 /****s* silccrypt/SilcRNGAPI/SilcRng
40  *
41  * NAME
42  * 
43  *    typedef struct SilcRngStruct *SilcRng;
44  *
45  * DESCRIPTION
46  *
47  *    This context is the actual Random Number Generator and is allocated
48  *    by silc_rng_alloc and given as argument usually to all silc_rng_*
49  *    functions.  It is freed by the silc_rng_free function.  The RNG is
50  *    initialized by calling the silc_rng_init function.
51  *
52  ***/
53 typedef struct SilcRngStruct *SilcRng;
54
55 /* Prototypes */
56
57 /****f* silccrypt/SilcRNGAPI/silc_rng_alloc
58  *
59  * SYNOPSIS
60  *
61  *    SilcRng silc_rng_alloc(void);
62  *
63  * DESCRIPTION
64  *
65  *    Allocates new SILC random number generator and returns context to
66  *    it.  After the RNG is allocated it must be initialized by calling
67  *    silc_rng_init before it actually can be used to produce any random
68  *    number.  This function returns NULL if RNG could not allocated.
69  *
70  ***/
71 SilcRng silc_rng_alloc(void);
72
73 /****f* silccrypt/SilcRNGAPI/silc_rng_free
74  *
75  * SYNOPSIS
76  *
77  *    void silc_rng_free(SilcRng rng);
78  *
79  * DESCRIPTION
80  *
81  *    Frees the random number generator and destroys the random number
82  *    pool.
83  *
84  ***/
85 void silc_rng_free(SilcRng rng);
86
87 /****f* silccrypt/SilcRNGAPI/silc_rng_init
88  *
89  * SYNOPSIS
90  *
91  *    void silc_rng_init(SilcRng rng);
92  *
93  * DESCRIPTION
94  *
95  *    This function is used to initialize the random number generator.
96  *    This is the function that must be called after the RNG is allocated
97  *    by calling silc_rng_alloc.  RNG cannot be used before this function
98  *    is called.
99  *
100  * NOTES
101  *
102  *    This function may be slow since it will acquire secret noise from
103  *    the environment in an attempt to set the RNG in unguessable state.
104  *
105  ***/
106 void silc_rng_init(SilcRng rng);
107
108 /****f* silccrypt/SilcRNGAPI/silc_rng_get_byte
109  *
110  * SYNOPSIS
111  *
112  *    SilcUInt8 silc_rng_get_byte(SilcRng rng);
113  *
114  * DESCRIPTION
115  *
116  *    Returns one 8-bit random byte from the random number generator.
117  *
118  ***/
119 SilcUInt8 silc_rng_get_byte(SilcRng rng);
120
121 /****f* silccrypt/SilcRNGAPI/silc_rng_get_byte_fast
122  *
123  * SYNOPSIS
124  *
125  *    SilcUInt8 silc_rng_get_byte_fast(SilcRng rng);
126  *
127  * DESCRIPTION
128  *
129  *    Returns one 8-bit random byte from the random number generator as
130  *    fast as possible.
131  *
132  * NOTES
133  *
134  *    This will read the data from /dev/urandom if it is available in the
135  *    operating system, since this may be faster than retrieving a byte
136  *    from the SILC RNG.  If /dev/urandom is not available this will take
137  *    the byte from SILC RNG and is effectively same as silc_rng_get_byte.
138  *
139  ***/
140 SilcUInt8 silc_rng_get_byte_fast(SilcRng rng);
141
142 /****f* silccrypt/SilcRNGAPI/silc_rng_get_rn16
143  *
144  * SYNOPSIS
145  *
146  *    SilcUInt16 silc_rng_get_rn16(SilcRng rng);
147  *
148  * DESCRIPTION
149  *
150  *    Returns one 16-bit random number from the random number generator.
151  *
152  ***/
153 SilcUInt16 silc_rng_get_rn16(SilcRng rng);
154
155 /****f* silccrypt/SilcRNGAPI/silc_rng_get_rn32
156  *
157  * SYNOPSIS
158  *
159  *    SilcUInt32 silc_rng_get_rn32(SilcRng rng);
160  *
161  * DESCRIPTION
162  *
163  *    Returns one 32-bit random number from the random number generator.
164  *
165  ***/
166 SilcUInt32 silc_rng_get_rn32(SilcRng rng);
167
168 /****f* silccrypt/SilcRNGAPI/silc_rng_get_rn_string
169  *
170  * SYNOPSIS
171  *
172  *    unsigned char *silc_rng_get_rn_string(SilcRng rng, SilcUInt32 len);
173  *
174  * DESCRIPTION
175  *
176  *    Returns random string in HEX form of the length of `len' bytes.
177  *    The caller must free returned data buffer.
178  *
179  ***/
180 unsigned char *silc_rng_get_rn_string(SilcRng rng, SilcUInt32 len);
181
182 /****f* silccrypt/SilcRNGAPI/silc_rng_get_rn_data
183  *
184  * SYNOPSIS
185  *
186  *    unsigned char *silc_rng_get_rn_data(SilcRng rng, SilcUInt32 len);
187  *
188  * DESCRIPTION
189  *
190  *    Returns random binary data of the length of `len' bytes.  The 
191  *    caller must free returned data buffer.
192  *
193  ***/
194 unsigned char *silc_rng_get_rn_data(SilcRng rng, SilcUInt32 len);
195
196 /****f* silccrypt/SilcRNGAPI/silc_rng_add_noise
197  *
198  * SYNOPSIS
199  *
200  *    void silc_rng_add_noise(SilcRng rng, unsigned char *buffer, SilcUInt32 len);
201  *
202  * DESCRIPTION
203  *
204  *    Add the data buffer indicated by `buffer' of length of `len' bytes 
205  *    as noise to the random number generator.  The random number generator
206  *    is restirred (reseeded) when this function is called.
207  *
208  ***/
209 void silc_rng_add_noise(SilcRng rng, unsigned char *buffer, SilcUInt32 len);
210
211 /****f* silccrypt/SilcRNGAPI/silc_rng_global_init
212  *
213  * SYNOPSIS
214  *
215  *    bool silc_rng_global_init(SilcRng rng);
216  *
217  * DESCRIPTION
218  *
219  *    This function sets the `rng' if non-NULL as global RNG context.
220  *    When any of the silc_rng_global_* functions is called the `rng' is
221  *    used as RNG.  If `rng' is NULL this will allocate new RNG as global
222  *    RNG.  The application in this case must free it later by calling
223  *    silc_rng_global_uninit.  Returns TRUE after Global RNG is initialized.
224  *
225  * NOTES
226  *
227  *    If `rng' was non-NULL, the silc_rng_init must have been called for
228  *    the `rng' already.
229  *
230  *    This function can be used to define the `rng' as global RNG and then
231  *    use silc_rng_global_* functions easily without need to provide
232  *    the RNG as argument.
233  *
234  ***/
235 bool silc_rng_global_init(SilcRng rng);
236
237 /****f* silccrypt/SilcRNGAPI/silc_rng_global_uninit
238  *
239  * SYNOPSIS
240  *
241  *    bool silc_rng_global_uninit(void);
242  *
243  * DESCRIPTION
244  *
245  *    Uninitialized the Global RNG object and frees it.  This should not
246  *    be called if silc_rng_global_init was called with non-NULL RNG.
247  *
248  ***/
249 bool silc_rng_global_uninit(void);
250
251 /****f* silccrypt/SilcRNGAPI/silc_rng_global_get_byte
252  *
253  * SYNOPSIS
254  *
255  *    SilcUInt8 silc_rng_global_get_byte(void);
256  *
257  * DESCRIPTION
258  *
259  *    Returns one 8-bit random byte from the random number generator.
260  *
261  ***/
262 SilcUInt8 silc_rng_global_get_byte(void);
263
264 /****f* silccrypt/SilcRNGAPI/silc_rng_global_get_byte_fast
265  *
266  * SYNOPSIS
267  *
268  *    SilcUInt8 silc_rng_global_get_byte_fast(void);
269  *
270  * DESCRIPTION
271  *
272  *    Returns one 8-bit random byte from the random number generator as
273  *    fast as possible.
274  *
275  * NOTES
276  *
277  *    This will read the data from /dev/urandom if it is available in the
278  *    operating system, since this may be faster than retrieving a byte
279  *    from the SILC RNG.  If /dev/urandom is not available this will take
280  *    the byte from SILC RNG and is effectively same as silc_rng_get_byte.
281  *
282  ***/
283 SilcUInt8 silc_rng_global_get_byte_fast(void);
284
285 /****f* silccrypt/SilcRNGAPI/silc_rng_global_get_rn16
286  *
287  * SYNOPSIS
288  *
289  *    SilcUInt16 silc_rng_global_get_rn16(void);
290  *
291  * DESCRIPTION
292  *
293  *    Returns one 16-bit random number from the random number generator.
294  *
295  ***/
296 SilcUInt16 silc_rng_global_get_rn16(void);
297
298 /****f* silccrypt/SilcRNGAPI/silc_rng_global_get_rn32
299  *
300  * SYNOPSIS
301  *
302  *    SilcUInt32 silc_rng_global_get_rn32(void);
303  *
304  * DESCRIPTION
305  *
306  *    Returns one 32-bit random number from the random number generator.
307  *
308  ***/
309 SilcUInt32 silc_rng_global_get_rn32(void);
310
311 /****f* silccrypt/SilcRNGAPI/silc_rng_global_get_rn_string
312  *
313  * SYNOPSIS
314  *
315  *    unsigned char *silc_rng_global_get_rn_string(SilcUInt32 len);
316  *
317  * DESCRIPTION
318  *
319  *    Returns random string in HEX form of the length of `len' bytes.
320  *    The caller must free returned data buffer.
321  *
322  ***/
323 unsigned char *silc_rng_global_get_rn_string(SilcUInt32 len);
324
325 /****f* silccrypt/SilcRNGAPI/silc_rng_global_get_rn_data
326  *
327  * SYNOPSIS
328  *
329  *    unsigned char *silc_rng_global_get_rn_data(SilcUInt32 len);
330  *
331  * DESCRIPTION
332  *
333  *    Returns random binary data of the length of `len' bytes.  The 
334  *    caller must free returned data buffer.
335  *
336  ***/
337 unsigned char *silc_rng_global_get_rn_data(SilcUInt32 len);
338
339 /****f* silccrypt/SilcRNGAPI/silc_rng_global_add_noise
340  *
341  * SYNOPSIS
342  *
343  *    void silc_rng_global_add_noise(unsigned char *buffer, SilcUInt32 len);
344  *
345  * DESCRIPTION
346  *
347  *    Add the data buffer indicated by `buffer' of length of `len' bytes 
348  *    as noise to the random number generator.  The random number generator
349  *    is restirred (reseeded) when this function is called.
350  *
351  ***/
352
353 void silc_rng_global_add_noise(unsigned char *buffer, SilcUInt32 len);
354
355 #endif