]> git.baikalelectronics.ru Git - kernel.git/commit
btrfs: Don't clear SGID when inheriting ACLs
authorJan Kara <jack@suse.cz>
Thu, 22 Jun 2017 13:31:07 +0000 (15:31 +0200)
committerDavid Sterba <dsterba@suse.com>
Thu, 29 Jun 2017 18:24:59 +0000 (20:24 +0200)
commitbdbfdb555d40d5961d745e3049dbef944a9fb013
tree17b73f9cf6811fe203b0e76c0f21e29382368d77
parent7ced174ccc898169e8b7355f8cc27602af77a4f3
btrfs: Don't clear SGID when inheriting ACLs

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
__btrfs_set_acl() into btrfs_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: b93308b56096afa920d6e36d3aad8d07e559d96e
CC: stable@vger.kernel.org
CC: linux-btrfs@vger.kernel.org
CC: David Sterba <dsterba@suse.com>
Signed-off-by: Jan Kara <jack@suse.cz>
Signed-off-by: David Sterba <dsterba@suse.com>
fs/btrfs/acl.c