lavu/random_seed: use arc4random() when available

arc4random() was designed as a superior interface for system random
number generation, designed for OpenBSD and subsequently incorporated by
other BSD's, Mac OS X, and some non-standard libc's. It is thus an improvement to
use it whenever available.

As a side note, this may or may not get included in glibc, and there is
a proposal to create a posix_random family based on these ideas:
http://austingroupbugs.net/view.php?id=859.

Tested on Mac OS X.

Signed-off-by: Ganesh Ajjanagadde <gajjanagadde@gmail.com>
This commit is contained in:
Ganesh Ajjanagadde 2015-12-06 21:10:21 -05:00
parent 7b880464cb
commit 39f8c7961d
2 changed files with 6 additions and 0 deletions

2
configure vendored
View File

@ -1841,6 +1841,7 @@ MATH_FUNCS="
SYSTEM_FUNCS=" SYSTEM_FUNCS="
access access
aligned_malloc aligned_malloc
arc4random
clock_gettime clock_gettime
closesocket closesocket
CommandLineToArgvW CommandLineToArgvW
@ -5232,6 +5233,7 @@ check_func ${malloc_prefix}memalign && enable memalign
check_func ${malloc_prefix}posix_memalign && enable posix_memalign check_func ${malloc_prefix}posix_memalign && enable posix_memalign
check_func access check_func access
check_func arc4random
check_func_headers time.h clock_gettime || { check_func_headers time.h clock_gettime -lrt && add_extralibs -lrt && LIBRT="-lrt"; } check_func_headers time.h clock_gettime || { check_func_headers time.h clock_gettime -lrt && add_extralibs -lrt && LIBRT="-lrt"; }
check_func fcntl check_func fcntl
check_func fork check_func fork

View File

@ -121,6 +121,10 @@ uint32_t av_get_random_seed(void)
} }
#endif #endif
#if HAVE_ARC4RANDOM
return arc4random();
#endif
if (read_random(&seed, "/dev/urandom") == sizeof(seed)) if (read_random(&seed, "/dev/urandom") == sizeof(seed))
return seed; return seed;
if (read_random(&seed, "/dev/random") == sizeof(seed)) if (read_random(&seed, "/dev/random") == sizeof(seed))