From: Mike Yuan Date: Sat, 25 Nov 2023 10:57:53 +0000 (+0800) Subject: Revert "nspawn-patch-uid: try fchmodat2() to restore mode of symlink" X-Git-Tag: v255~67^2~1 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=677e644530f4f5ea7b077f546cc4425c563fc172;p=platform%2Fupstream%2Fsystemd.git Revert "nspawn-patch-uid: try fchmodat2() to restore mode of symlink" This reverts commit 30462563b19b92d8c6ed196d30d3cf7de90e8131. fchmodat2(), while accepting AT_SYMLINK_NOFOLLOW as a valid flag, always returns EOPNOTSUPP when operating on a symlink. The Linux kernel simply doesn't support changing the mode of a symlink. Fixes #30157 --- diff --git a/src/nspawn/nspawn-patch-uid.c b/src/nspawn/nspawn-patch-uid.c index 063995d..66663ad 100644 --- a/src/nspawn/nspawn-patch-uid.c +++ b/src/nspawn/nspawn-patch-uid.c @@ -11,7 +11,6 @@ #include "fileio.h" #include "fs-util.h" #include "missing_magic.h" -#include "missing_syscall.h" #include "nspawn-def.h" #include "nspawn-patch-uid.h" #include "stat-util.h" @@ -240,18 +239,14 @@ static int patch_fd(int fd, const char *name, const struct stat *st, uid_t shift /* The Linux kernel alters the mode in some cases of chown(). Let's undo this. */ if (name) { - /* It looks like older glibc (before 2016) did not support AT_SYMLINK_NOFOLLOW. */ if (!S_ISLNK(st->st_mode)) - r = RET_NERRNO(fchmodat(fd, name, st->st_mode, 0)); - else { - r = RET_NERRNO(fchmodat2(fd, name, st->st_mode, AT_SYMLINK_NOFOLLOW)); - if (IN_SET(r, -ENOSYS, -EPERM)) - r = 0; - } + r = fchmodat(fd, name, st->st_mode, 0); + else /* AT_SYMLINK_NOFOLLOW is not available for fchmodat() */ + r = 0; } else - r = RET_NERRNO(fchmod(fd, st->st_mode)); + r = fchmod(fd, st->st_mode); if (r < 0) - return r; + return -errno; changed = true; }