summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNero <nero@w1r3.net>2023-09-23 11:50:04 +0000
committerChris Boot <bootc@debian.org>2023-11-23 12:35:38 +0000
commit9606b71d6134abd1a91d24c25ba31d26302322aa (patch)
tree0fb08956ef23605ff14cdcf251976b2f271ca45c
parent7f2ce2e38cc569913bf7009153baa67a5891f413 (diff)
[PATCH] install: Fix chown resetting suid/sgid bits from chmodarchive/debian/1%1.36.1-6_exp.1
Since Linux 2.2.13, chown(2) resets the suid/gid bits for all users. This patch changes the ordering so that chmod gets called after chown. This behavior follows GNU coreutils. Signed-off-by: Nero <nero@w1r3.net> Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com> Gbp-Pq: Name install-fix-chown-resetting-suid-sgid-bits-from-chmod.patch
-rw-r--r--coreutils/install.c16
1 files changed, 9 insertions, 7 deletions
diff --git a/coreutils/install.c b/coreutils/install.c
index c0f1c538a..00f8be87e 100644
--- a/coreutils/install.c
+++ b/coreutils/install.c
@@ -244,6 +244,15 @@ int install_main(int argc, char **argv)
}
}
+ /* Set the user and group id */
+ /* (must be before chmod, or else chown may clear suid/gid bits) */
+ if ((opts & (OPT_OWNER|OPT_GROUP))
+ && lchown(dest, uid, gid) == -1
+ ) {
+ bb_perror_msg("can't change %s of %s", "ownership", dest);
+ ret = EXIT_FAILURE;
+ }
+
/* Set the file mode (always, not only with -m).
* GNU coreutils 6.10 is not affected by umask. */
if (chmod(dest, mode) == -1) {
@@ -254,13 +263,6 @@ int install_main(int argc, char **argv)
if (use_default_selinux_context)
setdefaultfilecon(dest);
#endif
- /* Set the user and group id */
- if ((opts & (OPT_OWNER|OPT_GROUP))
- && lchown(dest, uid, gid) == -1
- ) {
- bb_perror_msg("can't change %s of %s", "ownership", dest);
- ret = EXIT_FAILURE;
- }
next:
if (ENABLE_FEATURE_CLEAN_UP && isdir)
free(dest);