summaryrefslogtreecommitdiff
path: root/util/libreboot-utils/lib/rand.c
diff options
context:
space:
mode:
authorLeah Rowe <leah@libreboot.org>2026-03-31 11:41:27 +0100
committerLeah Rowe <leah@libreboot.org>2026-03-31 11:45:21 +0100
commitaacf9fb6c9f6f364c8d1799b02f4d5fc0f63e98f (patch)
treea166d0f2630db46c36266fdeffe7137bb63ac0ff /util/libreboot-utils/lib/rand.c
parentf2dd830c7b9f283ba8db26c7cbb29fb1763f86aa (diff)
libreboot-utils: unified EINTR loop handling
absolutely unified. Signed-off-by: Leah Rowe <leah@libreboot.org>
Diffstat (limited to 'util/libreboot-utils/lib/rand.c')
-rw-r--r--util/libreboot-utils/lib/rand.c29
1 files changed, 14 insertions, 15 deletions
diff --git a/util/libreboot-utils/lib/rand.c b/util/libreboot-utils/lib/rand.c
index 9da8d9eb..7634903a 100644
--- a/util/libreboot-utils/lib/rand.c
+++ b/util/libreboot-utils/lib/rand.c
@@ -143,28 +143,27 @@ rset(void *buf, size_t 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; /* prevent infinite loop on fatal err */
@@ -176,7 +175,7 @@ retry_rand:
((USE_URANDOM) > 0)
close_on_eintr(&fd);
#endif
- goto out;
+
#endif
out:
errno = saved_errno;