summaryrefslogtreecommitdiff
path: root/util/libreboot-utils/lib/rand.c
diff options
context:
space:
mode:
Diffstat (limited to 'util/libreboot-utils/lib/rand.c')
-rw-r--r--util/libreboot-utils/lib/rand.c39
1 files changed, 20 insertions, 19 deletions
diff --git a/util/libreboot-utils/lib/rand.c b/util/libreboot-utils/lib/rand.c
index 9da8d9eb..adfad3d7 100644
--- a/util/libreboot-utils/lib/rand.c
+++ b/util/libreboot-utils/lib/rand.c
@@ -127,6 +127,7 @@ void
rset(void *buf, size_t n)
{
int saved_errno = errno;
+ errno = 0;
if (if_err(buf == NULL, EFAULT))
goto err;
@@ -140,31 +141,32 @@ rset(void *buf, size_t n)
((USE_URANDOM) > 0))
arc4random_buf(buf, n);
- goto out;
#else
size_t off = 0;
- ssize_t rc = 0;
+
+retry_rand:
#if defined(USE_URANDOM) && \
((USE_URANDOM) > 0)
+ ssize_t rc;
int fd = -1;
- open_on_eintr("/dev/urandom", &fd, O_RDONLY, 0400, NULL);
-retry_rand:
- if ((rc = read_on_eintr(fd,
- (unsigned char *)buf + off, n - off)) < 0) {
+
+ open_file_on_eintr("/dev/urandom", &fd, O_RDONLY, 0400, NULL);
+
+ while (rw_retry(saved_errno,
+ rc = read_on_eintr(fd,
+ (unsigned char *)buf + off, n - off, 0)));
#elif defined(__linux__)
-retry_rand:
- if ((rc = (ssize_t)syscall(SYS_getrandom,
- (unsigned char *)buf + off, n - off, 0)) < 0) {
+ long rc;
+ while (sys_retry(saved_errno,
+ rc = syscall(SYS_getrandom,
+ (unsigned char *)buf + off, n - off, 0)));
#else
#error Unsupported operating system (possibly unsecure randomisation)
#endif
- if (errno == EINTR ||
- errno == EAGAIN)
- goto retry_rand;
- goto err; /* possibly unsupported by kernel */
- }
+ if (rc < 0)
+ goto err; /* syscall fehler */
if (rc == 0)
goto err; /* prevent infinite loop on fatal err */
@@ -176,18 +178,17 @@ retry_rand:
((USE_URANDOM) > 0)
close_on_eintr(&fd);
#endif
- goto out;
+
#endif
-out:
- errno = saved_errno;
+ reset_caller_errno(0);
return;
err:
#if defined(USE_URANDOM) && \
((USE_URANDOM) > 0)
close_on_eintr(&fd);
#endif
- err_exit(ECANCELED,
- "Randomisation failure, possibly unsupported in your kernel");
+ (void) with_fallback_errno(ECANCELED);
+ err_exit(errno, "Randomisierungsfehler");
exit(EXIT_FAILURE);
}
#endif