From: Mike Yuan Date: Sat, 3 Jan 2026 19:25:53 +0000 (+0100) Subject: core/dynamic-user: use fd_verify_linked() X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=252b40c449ce71d21a2434c4c2ef6ccabc3ca037;p=thirdparty%2Fsystemd.git core/dynamic-user: use fd_verify_linked() --- 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. */