OLD | NEW |
1 /* | 1 /* |
2 * alloc.h | 2 * rand_source_ossl.c |
3 * | 3 * |
4 * interface to memory allocation and deallocation, with optional debugging | 4 * implements a random source based on OpenSSL RAND_bytes() |
5 * | 5 * |
6 * David A. McGrew | 6 * John A. Foley |
7 * Cisco Systems, Inc. | 7 * Cisco Systems, Inc. |
8 */ | 8 */ |
9 /* | 9 /* |
10 *» | 10 * |
11 * Copyright (c) 2001-2006 Cisco Systems, Inc. | 11 * Copyright(c) 2013, Cisco Systems, Inc. |
12 * All rights reserved. | 12 * All rights reserved. |
13 * | 13 * |
14 * Redistribution and use in source and binary forms, with or without | 14 * Redistribution and use in source and binary forms, with or without |
15 * modification, are permitted provided that the following conditions | 15 * modification, are permitted provided that the following conditions |
16 * are met: | 16 * are met:crypto/test/aes_calc.c |
17 * | 17 * |
18 * Redistributions of source code must retain the above copyright | 18 * Redistributions of source code must retain the above copyright |
19 * notice, this list of conditions and the following disclaimer. | 19 * notice, this list of conditions and the following disclaimer. |
20 * | 20 * |
21 * Redistributions in binary form must reproduce the above | 21 * Redistributions in binary form must reproduce the above |
22 * copyright notice, this list of conditions and the following | 22 * copyright notice, this list of conditions and the following |
23 * disclaimer in the documentation and/or other materials provided | 23 * disclaimer in the documentation and/or other materials provided |
24 * with the distribution. | 24 * with the distribution. |
25 * | 25 * |
26 * Neither the name of the Cisco Systems, Inc. nor the names of its | 26 * Neither the name of the Cisco Systems, Inc. nor the names of its |
27 * contributors may be used to endorse or promote products derived | 27 * contributors may be used to endorse or promote products derived |
28 * from this software without specific prior written permission. | 28 * from this software without specific prior written permission. |
29 * | 29 * |
30 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 30 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
31 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 31 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
32 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS | 32 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS |
33 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE | 33 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE |
34 * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, | 34 * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, |
35 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | 35 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
36 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | 36 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR |
37 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | 37 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) |
38 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, | 38 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, |
39 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | 39 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
40 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED | 40 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED |
41 * OF THE POSSIBILITY OF SUCH DAMAGE. | 41 * OF THE POSSIBILITY OF SUCH DAMAGE. |
42 * | 42 * |
43 */ | 43 */ |
44 | 44 |
| 45 #ifdef HAVE_CONFIG_H |
| 46 #include <config.h> |
| 47 #endif |
45 | 48 |
46 #ifndef CRYPTO_ALLOC_H | 49 #include "rand_source.h" |
47 #define CRYPTO_ALLOC_H | 50 #include <openssl/rand.h> |
48 | 51 |
49 #include "datatypes.h" | |
50 | 52 |
51 void * | 53 err_status_t rand_source_init (void) |
52 crypto_alloc(size_t size); | 54 { |
| 55 return err_status_ok; |
| 56 } |
53 | 57 |
54 void | 58 err_status_t rand_source_get_octet_string (void *dest, uint32_t len) |
55 crypto_free(void *ptr); | 59 { |
| 60 if (RAND_bytes(dest, len) == 1) { |
| 61 return err_status_ok; |
| 62 } else { |
| 63 return err_status_fail; |
| 64 } |
| 65 } |
56 | 66 |
57 #endif /* CRYPTO_ALLOC_H */ | 67 err_status_t rand_source_deinit (void) |
| 68 { |
| 69 return err_status_ok; |
| 70 } |
OLD | NEW |