summaryrefslogtreecommitdiff
path: root/lib/libcrypto/arc4random
diff options
context:
space:
mode:
authorBob Beck <beck@cvs.openbsd.org>2014-06-25 15:53:57 +0000
committerBob Beck <beck@cvs.openbsd.org>2014-06-25 15:53:57 +0000
commiteabd2fbf36635900dff52599f1625f7a06c8f326 (patch)
tree683b0bdcbe3a106ecba66397911b3807a878abd9 /lib/libcrypto/arc4random
parenta739707bfac111bf187dc49e8b40a27ad46f70b6 (diff)
O_NOFOLLOW would be very nice to have here if the version of linux
we are running supports it. from enh@google.com
Diffstat (limited to 'lib/libcrypto/arc4random')
-rw-r--r--lib/libcrypto/arc4random/getentropy_linux.c21
1 files changed, 11 insertions, 10 deletions
diff --git a/lib/libcrypto/arc4random/getentropy_linux.c b/lib/libcrypto/arc4random/getentropy_linux.c
index d833d4c9e16..81661318995 100644
--- a/lib/libcrypto/arc4random/getentropy_linux.c
+++ b/lib/libcrypto/arc4random/getentropy_linux.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: getentropy_linux.c,v 1.8 2014/06/23 03:47:46 beck Exp $ */
+/* $OpenBSD: getentropy_linux.c,v 1.9 2014/06/25 15:53:56 beck Exp $ */
/*
* Copyright (c) 2014 Theo de Raadt <deraadt@openbsd.org>
@@ -169,24 +169,25 @@ getentropy_urandom(void *buf, size_t len)
{
struct stat st;
size_t i;
- int fd, cnt;
+ int fd, cnt, flags;
int save_errno = errno;
start:
+
+ flags = O_RDONLY;
+#ifdef O_NOFOLLOW
+ flags |= O_NOFOLLOW;
+#endif
#ifdef O_CLOEXEC
- fd = open("/dev/urandom", O_RDONLY|O_CLOEXEC, 0);
- if (fd == -1) {
- if (errno == EINTR)
- goto start;
- goto nodevrandom;
- }
-#else
- fd = open("/dev/urandom", O_RDONLY, 0);
+ flags |= O_CLOEXEC;
+#endif
+ fd = open("/dev/urandom", flags, 0);
if (fd == -1) {
if (errno == EINTR)
goto start;
goto nodevrandom;
}
+#ifndef O_CLOEXEC
fcntl(fd, F_SETFD, fcntl(fd, F_GETFD) | FD_CLOEXEC);
#endif