diff options
| author | Leah Rowe <leah@libreboot.org> | 2026-03-28 08:09:14 +0000 |
|---|---|---|
| committer | Leah Rowe <leah@libreboot.org> | 2026-03-28 08:09:14 +0000 |
| commit | 49cac232d8e3cc6147a530d4f7971832f6b869b5 (patch) | |
| tree | d8ac4490b6cd9fc1211bc4f1a7416f512a56beec /util/libreboot-utils/lib/file.c | |
| parent | 03dd3c289439e46ba0c5840cc7ab73b3c3fa60a3 (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.c | 36 |
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; |
