Received: by 10.223.176.5 with SMTP id f5csp3391292wra; Mon, 29 Jan 2018 12:30:32 -0800 (PST) X-Google-Smtp-Source: AH8x226QiOf7tWOOKF9kE1xLJHUPVmb7jj3MntO7DjG1NlM0CxfogftEWLuw0ssLp8cr3rl1F5Qs X-Received: by 10.101.64.4 with SMTP id f4mr21588689pgp.171.1517257832666; Mon, 29 Jan 2018 12:30:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517257832; cv=none; d=google.com; s=arc-20160816; b=ecw1mDINRir6drsjtTYcFoUmGZRbMKrpBPyQ3Nzw05OsaP/qZgBhVlAwsTv9zSkWFe Tj7H4V9cUWKVFhtNZK6cXPEG4gCR/fi4sBOolmVuiwWQMKkjzNix0nA8Fzg7llQQSyP4 ONWy+zsOSNBTlYoWIE3TmRY+309FOOCoAnrzDZZx9h91dMXtoV01XoH+UvOyWzm0/mw9 GclPdY/N1vblhhZkV/bshEnK4UltLwr7b+uRjbxpIAC7C03H0b1c0QyCRcq5IPjp3cAW BHe2SH4V2PbwZQOam5BYl0CTUVFwFuZQ1w8Fm2mUuIWAWV+Cwhaooy9q28ooUuM8em5s Sygw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=FEg5C8QLNbKjcAlZdl7/o4G6wNRghCLXINPBjgeX4d4=; b=LDcsRCHnJP5AsPro9SWowXX1M8wEsbhtHoXN5Q20ucWdCnEa1jfrYQEiMQzRWlbmg0 FjTdcX1HHmx+WDSjLhbz1OMLOi6MuDlkAtaAC2nKejDfRcC7MoyfWkJda4IQoKnyt89v 0hmPvUMPpnSOgRKfTTKqyll6B5d1uKNC7zKaRz/77ne0HA/Bc5xV4P1/GhkRfkQezI0w bnOYNKZDkhCSp2oHeA81usl3HMIr9y3K7rJdM0733ab6yQ2Nb6wrBDQzh22GIOtgYnSm B2uz9oUFwen5f/KxDPUdvSXD53BJVCWbIU2rlvG2sQtGL6jyPtJvgL0ZkKXwMnMPJX1n 6bGg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v11-v6si536403plz.285.2018.01.29.12.30.18; Mon, 29 Jan 2018 12:30:32 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932578AbeA2U3F (ORCPT + 99 others); Mon, 29 Jan 2018 15:29:05 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:43584 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754422AbeA2UQB (ORCPT ); Mon, 29 Jan 2018 15:16:01 -0500 Received: from localhost (LFbn-1-12258-90.w90-92.abo.wanadoo.fr [90.92.71.90]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id E46232F14; Mon, 29 Jan 2018 13:02:27 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, reiserfs-devel@vger.kernel.org, Jan Kara Subject: [PATCH 4.4 44/74] reiserfs: Dont clear SGID when inheriting ACLs Date: Mon, 29 Jan 2018 13:56:49 +0100 Message-Id: <20180129123849.559043741@linuxfoundation.org> X-Mailer: git-send-email 2.16.1 In-Reply-To: <20180129123847.507563674@linuxfoundation.org> References: <20180129123847.507563674@linuxfoundation.org> User-Agent: quilt/0.65 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.4-stable review patch. If anyone has any objections, please let me know. ------------------ From: Jan Kara commit 6883cd7f68245e43e91e5ee583b7550abf14523f upstream. When new directory 'DIR1' is created in a directory 'DIR0' with SGID bit set, DIR1 is expected to have SGID bit set (and owning group equal to the owning group of 'DIR0'). However when 'DIR0' also has some default ACLs that 'DIR1' inherits, setting these ACLs will result in SGID bit on 'DIR1' to get cleared if user is not member of the owning group. Fix the problem by moving posix_acl_update_mode() out of __reiserfs_set_acl() into reiserfs_set_acl(). That way the function will not be called when inheriting ACLs which is what we want as it prevents SGID bit clearing and the mode has been properly set by posix_acl_create() anyway. Fixes: 073931017b49d9458aa351605b43a7e34598caef CC: reiserfs-devel@vger.kernel.org Signed-off-by: Jan Kara Signed-off-by: Greg Kroah-Hartman --- fs/reiserfs/xattr_acl.c | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) --- a/fs/reiserfs/xattr_acl.c +++ b/fs/reiserfs/xattr_acl.c @@ -37,7 +37,14 @@ reiserfs_set_acl(struct inode *inode, st error = journal_begin(&th, inode->i_sb, jcreate_blocks); reiserfs_write_unlock(inode->i_sb); if (error == 0) { + if (type == ACL_TYPE_ACCESS && acl) { + error = posix_acl_update_mode(inode, &inode->i_mode, + &acl); + if (error) + goto unlock; + } error = __reiserfs_set_acl(&th, inode, type, acl); +unlock: reiserfs_write_lock(inode->i_sb); error2 = journal_end(&th); reiserfs_write_unlock(inode->i_sb); @@ -245,11 +252,6 @@ __reiserfs_set_acl(struct reiserfs_trans switch (type) { case ACL_TYPE_ACCESS: name = POSIX_ACL_XATTR_ACCESS; - if (acl) { - error = posix_acl_update_mode(inode, &inode->i_mode, &acl); - if (error) - return error; - } break; case ACL_TYPE_DEFAULT: name = POSIX_ACL_XATTR_DEFAULT;