diff options
| author | deraadt <> | 2014-12-08 21:45:20 +0000 | 
|---|---|---|
| committer | deraadt <> | 2014-12-08 21:45:20 +0000 | 
| commit | 9736a7f2a9e739ee9fc431040def5680fbb8794a (patch) | |
| tree | bf17a76201de02c2ce50358a383001a6b6c5cc64 /src/lib/libc/stdlib/lrand48.c | |
| parent | c8f8008b6d95ffedabe97be1582beacd08ae7afb (diff) | |
| download | openbsd-9736a7f2a9e739ee9fc431040def5680fbb8794a.tar.gz openbsd-9736a7f2a9e739ee9fc431040def5680fbb8794a.tar.bz2 openbsd-9736a7f2a9e739ee9fc431040def5680fbb8794a.zip | |
Change rand(), random(), drand48(), lrand48(), mrand48(), and srand48()
to returning strong random by default, source from arc4random(3).
Parameters to the seeding functions are ignored, and the subsystems remain
in strong random mode.  If you wish the standardized deterministic mode,
call srand_deterministic(), srandom_determistic(), srand48_deterministic(),
seed48_deterministic() or lcong48_deterministic() instead.
The re-entrant functions rand_r(), erand48(), nrand48(), jrand48() are
unaffected by this change and remain in deterministic mode (for now).
Verified as a good roadmap forward by auditing 8800 pieces of software.
Roughly 60 pieces of software will need adaptation to request the
deterministic mode.
Violates POSIX and C89, which violate best practice in this century.
ok guenther tedu millert
Diffstat (limited to 'src/lib/libc/stdlib/lrand48.c')
| -rw-r--r-- | src/lib/libc/stdlib/lrand48.c | 4 | 
1 files changed, 3 insertions, 1 deletions
| diff --git a/src/lib/libc/stdlib/lrand48.c b/src/lib/libc/stdlib/lrand48.c index 21beb858ca..22508594fc 100644 --- a/src/lib/libc/stdlib/lrand48.c +++ b/src/lib/libc/stdlib/lrand48.c | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | /* $OpenBSD: lrand48.c,v 1.3 2005/08/08 08:05:36 espie Exp $ */ | 1 | /* $OpenBSD: lrand48.c,v 1.4 2014/12/08 21:45:20 deraadt Exp $ */ | 
| 2 | /* | 2 | /* | 
| 3 | * Copyright (c) 1993 Martin Birgmeier | 3 | * Copyright (c) 1993 Martin Birgmeier | 
| 4 | * All rights reserved. | 4 | * All rights reserved. | 
| @@ -19,6 +19,8 @@ extern unsigned short __rand48_seed[3]; | |||
| 19 | long | 19 | long | 
| 20 | lrand48(void) | 20 | lrand48(void) | 
| 21 | { | 21 | { | 
| 22 | if (__rand48_deterministic == 0) | ||
| 23 | return arc4random() & 0x7fffffff; | ||
| 22 | __dorand48(__rand48_seed); | 24 | __dorand48(__rand48_seed); | 
| 23 | return ((long) __rand48_seed[2] << 15) + ((long) __rand48_seed[1] >> 1); | 25 | return ((long) __rand48_seed[2] << 15) + ((long) __rand48_seed[1] >> 1); | 
| 24 | } | 26 | } | 
