source: roaraudio/libroar/random.c @ 4454:8d5b183324bc

Last change on this file since 4454:8d5b183324bc was 4454:8d5b183324bc, checked in by phi, 14 years ago

implemented a overall crypto init function

File size: 2.6 KB
Line 
1//random.c:
2
3/*
4 *      Copyright (C) Philipp 'ph3-der-loewe' Schafft - 2010
5 *
6 *  This file is part of libroar a part of RoarAudio,
7 *  a cross-platform sound system for both, home and professional use.
8 *  See README for details.
9 *
10 *  This file is free software; you can redistribute it and/or modify
11 *  it under the terms of the GNU General Public License version 3
12 *  as published by the Free Software Foundation.
13 *
14 *  libroar is distributed in the hope that it will be useful,
15 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
16 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 *  GNU General Public License for more details.
18 *
19 *  You should have received a copy of the GNU General Public License
20 *  along with this software; see the file COPYING.  If not, write to
21 *  the Free Software Foundation, 51 Franklin Street, Fifth Floor,
22 *  Boston, MA 02110-1301, USA.
23 *
24 *  NOTE for everyone want's to change something and send patches:
25 *  read README and HACKING! There a addition information on
26 *  the license of this document you need to read before you send
27 *  any patches.
28 *
29 *  NOTE for uses of non-GPL (LGPL,...) software using libesd, libartsc
30 *  or libpulse*:
31 *  The libs libroaresd, libroararts and libroarpulse link this lib
32 *  and are therefore GPL. Because of this it may be illigal to use
33 *  them with any software that uses libesd, libartsc or libpulse*.
34 */
35
36#include "libroar.h"
37
38#ifdef ROAR_HAVE_LIBGCRYPT
39#include <gcrypt.h>
40#endif
41
42static void roar_random_init (void) {
43 static int inited = 0;
44
45 if (inited)
46  return;
47
48 // add stuff here needed to bring up random source.
49 roar_crypto_init();
50
51 inited = 1;
52}
53
54int roar_random_gen(void * buffer, size_t len, int quality) {
55 if ( len == 0 )
56  return 0;
57
58 if ( buffer == NULL )
59  return -1;
60
61 roar_random_init();
62
63 switch (quality) {
64  case ROAR_RANDOM_NONE:
65    // no entropy:
66    memset(buffer, 0, len);
67   break;
68#ifdef ROAR_HAVE_LIBGCRYPT
69  case ROAR_RANDOM_VERY_WEAK:
70  case ROAR_RANDOM_WEAK:
71    gcry_create_nonce(buffer, len);
72   break;
73  case ROAR_RANDOM_NORMAL:
74  case ROAR_RANDOM_STRONG:
75    gcry_randomize(buffer, len, GCRY_STRONG_RANDOM);
76   break;
77  case ROAR_RANDOM_VERY_STRONG:
78    gcry_randomize(buffer, len, GCRY_VERY_STRONG_RANDOM);
79   break;
80#endif
81  default:
82    return -1;
83   break;
84 }
85
86 return 0;
87}
88
89void * roar_random_genbuf(size_t len, int quality, int locked) {
90 void * ret = roar_mm_malloc(len);
91
92 if (ret == NULL)
93  return NULL;
94
95 if ( locked ) {
96  if ( roar_mm_mlock(ret, len) == -1 ) {
97   roar_mm_free(ret);
98   return NULL;
99  }
100 }
101
102 if ( roar_random_gen(ret, len, quality) == -1 ) {
103  roar_mm_free(ret);
104  return NULL;
105 }
106
107 return ret;
108}
109
110//ll
Note: See TracBrowser for help on using the repository browser.