summaryrefslogtreecommitdiff
path: root/util/libreboot-utils/lib/file.c
diff options
context:
space:
mode:
authorLeah Rowe <leah@libreboot.org>2026-03-28 08:09:14 +0000
committerLeah Rowe <leah@libreboot.org>2026-03-28 08:09:14 +0000
commit49cac232d8e3cc6147a530d4f7971832f6b869b5 (patch)
treed8ac4490b6cd9fc1211bc4f1a7416f512a56beec /util/libreboot-utils/lib/file.c
parent03dd3c289439e46ba0c5840cc7ab73b3c3fa60a3 (diff)
libreboot-utils: much stricter open() handling
abort on error, and do EINTR looping Signed-off-by: Leah Rowe <leah@libreboot.org>
Diffstat (limited to 'util/libreboot-utils/lib/file.c')
-rw-r--r--util/libreboot-utils/lib/file.c36
1 files changed, 34 insertions, 2 deletions
diff --git a/util/libreboot-utils/lib/file.c b/util/libreboot-utils/lib/file.c
index 3c7a3ba2..5d656e0e 100644
--- a/util/libreboot-utils/lib/file.c
+++ b/util/libreboot-utils/lib/file.c
@@ -590,6 +590,36 @@ free_and_set_null(char **buf)
}
void
+open_on_eintr(char *path,
+ int *fd, int flags, mode_t mode)
+{
+ int r = -1;
+ int saved_errno = errno;
+
+ if (path == NULL)
+ err_exit(EINVAL, "open_on_eintr: null path");
+
+ if (fd == NULL)
+ err_exit(EFAULT, "%s: open_on_eintr: null fd ptr", path);
+
+ if (*fd >= 0)
+ err_exit(EBADF, "%s: open_on_eintr: file already open", path);
+
+ do {
+ r = open(path, flags, mode);
+ } while (r == -1 && (
+ errno == EINTR || errno == EAGAIN ||
+ errno == EWOULDBLOCK || errno == ETXTBSY));
+
+ if (r < 0)
+ err_exit(errno, "%s: open_on_eintr: could not close", path);
+
+ *fd = r;
+
+ errno = saved_errno;
+}
+
+void
close_on_eintr(int *fd)
{
int r;
@@ -672,8 +702,10 @@ rootfs(void)
if (!fs_initialised) {
- global_fs.rootfd =
- open("/", O_RDONLY | O_DIRECTORY | O_CLOEXEC);
+ global_fs.rootfd = -1;
+
+ open_on_eintr("/", &global_fs.rootfd,
+ O_RDONLY | O_DIRECTORY | O_CLOEXEC, 0400);
if (global_fs.rootfd < 0)
return NULL;