From 252b40c449ce71d21a2434c4c2ef6ccabc3ca037 Mon Sep 17 00:00:00 2001 From: Mike Yuan Date: Sat, 3 Jan 2026 20:25:53 +0100 Subject: [PATCH] core/dynamic-user: use fd_verify_linked() --- src/core/dynamic-user.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/core/dynamic-user.c b/src/core/dynamic-user.c index 576ce5c8b0e..921622d92c0 100644 --- a/src/core/dynamic-user.c +++ b/src/core/dynamic-user.c @@ -21,6 +21,7 @@ #include "serialize.h" #include "siphash24.h" #include "socket-util.h" +#include "stat-util.h" #include "stdio-util.h" #include "string-util.h" #include "uid-classification.h" @@ -232,8 +233,6 @@ static int pick_uid(char **suggested_paths, const char *name, uid_t *ret_uid) { xsprintf(lock_path, "/run/systemd/dynamic-uid/" UID_FMT, candidate); for (;;) { - struct stat st; - lock_fd = open(lock_path, O_CREAT|O_RDWR|O_NOFOLLOW|O_CLOEXEC|O_NOCTTY, 0600); if (lock_fd < 0) return -errno; @@ -246,10 +245,11 @@ static int pick_uid(char **suggested_paths, const char *name, uid_t *ret_uid) { return -errno; } - if (fstat(lock_fd, &st) < 0) - return -errno; - if (st.st_nlink > 0) + r = fd_verify_linked(lock_fd); + if (r >= 0) break; + if (r != -EIDRM) + return r; /* Oh, bummer, we got the lock, but the file was unlinked between the time we opened it and * got the lock. Close it, and try again. */ -- 2.47.3