diff options
author | deraadt <> | 2014-07-19 00:08:43 +0000 |
---|---|---|
committer | deraadt <> | 2014-07-19 00:08:43 +0000 |
commit | 63559a378edd18f00978f68eeb77fbd0f088a804 (patch) | |
tree | d1d1ea706aec9066edcbf60e8dd1c10257101a1d /src/lib/libcrypto/crypto/arc4random_win.h | |
parent | c08eb4d65e7656f34e0b7949bf7f3102cb5faaeb (diff) | |
download | openbsd-63559a378edd18f00978f68eeb77fbd0f088a804.tar.gz openbsd-63559a378edd18f00978f68eeb77fbd0f088a804.tar.bz2 openbsd-63559a378edd18f00978f68eeb77fbd0f088a804.zip |
Change _rs_allocate so it can combine the two regions (rs and rsx)
into one if a system has an awesome getentropy(). In that case it
is valid to totally throw away the rsx state in the child. If the
getentropy() is not very good and has a lazy reseed operation, this
combining is a bad idea, and the reseed should probably continue to
use the "something old, something new" mix. _rs_allocate() can
accomodate either method, but not on the fly.
ok matthew
Diffstat (limited to 'src/lib/libcrypto/crypto/arc4random_win.h')
-rw-r--r-- | src/lib/libcrypto/crypto/arc4random_win.h | 23 |
1 files changed, 13 insertions, 10 deletions
diff --git a/src/lib/libcrypto/crypto/arc4random_win.h b/src/lib/libcrypto/crypto/arc4random_win.h index 7d01d42be5..1fc228d109 100644 --- a/src/lib/libcrypto/crypto/arc4random_win.h +++ b/src/lib/libcrypto/crypto/arc4random_win.h | |||
@@ -1,4 +1,4 @@ | |||
1 | /* $OpenBSD: arc4random_win.h,v 1.1 2014/07/18 02:05:55 deraadt Exp $ */ | 1 | /* $OpenBSD: arc4random_win.h,v 1.2 2014/07/19 00:08:43 deraadt Exp $ */ |
2 | 2 | ||
3 | /* | 3 | /* |
4 | * Copyright (c) 1996, David Mazieres <dm@uun.org> | 4 | * Copyright (c) 1996, David Mazieres <dm@uun.org> |
@@ -22,10 +22,19 @@ | |||
22 | * Stub functions for portability. | 22 | * Stub functions for portability. |
23 | */ | 23 | */ |
24 | 24 | ||
25 | static inline void * | 25 | static inline int |
26 | _rs_allocate(size_t len) | 26 | _rs_allocate(struct _rs **rsp, struct _rsx **rsxp) |
27 | { | 27 | { |
28 | return calloc(1, sizeof(*rs)); | 28 | *rsp = calloc(1, sizeof(**rsp)); |
29 | if (*rsp == NULL) | ||
30 | return (-1); | ||
31 | |||
32 | *rsxp = calloc(1, sizeof(**rsxp)); | ||
33 | if (*rsxp == NULL) { | ||
34 | free(*rsp); | ||
35 | return (-1); | ||
36 | } | ||
37 | return (0); | ||
29 | } | 38 | } |
30 | 39 | ||
31 | static inline void | 40 | static inline void |
@@ -37,9 +46,3 @@ static inline void | |||
37 | _rs_forkdetect(void) | 46 | _rs_forkdetect(void) |
38 | { | 47 | { |
39 | } | 48 | } |
40 | |||
41 | static inline void | ||
42 | _rs_forkdetectsetup(struct _rs *rs, size_t len) | ||
43 | { | ||
44 | } | ||
45 | |||