diff options
author | Miklos Szeredi <mszeredi@redhat.com> | 2016-09-01 05:11:59 -0400 |
---|---|---|
committer | Miklos Szeredi <mszeredi@redhat.com> | 2016-09-01 05:11:59 -0400 |
commit | c11b9fdd6a612f376a5e886505f1c54c16d8c380 (patch) | |
tree | f4cb90cf9156ddca8b52114a887cbc4adaf92c0f | |
parent | 38b256973ea90fc7c2b7e1b734fa0e8b83538d50 (diff) |
ovl: remove posix_acl_default from workdir
Clear out posix acl xattrs on workdir and also reset the mode after
creation so that an inherited sgid bit is cleared.
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Cc: <stable@vger.kernel.org>
-rw-r--r-- | fs/overlayfs/super.c | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/fs/overlayfs/super.c b/fs/overlayfs/super.c index 4036132842b5..452fb7130efa 100644 --- a/fs/overlayfs/super.c +++ b/fs/overlayfs/super.c | |||
@@ -814,6 +814,10 @@ retry: | |||
814 | struct kstat stat = { | 814 | struct kstat stat = { |
815 | .mode = S_IFDIR | 0, | 815 | .mode = S_IFDIR | 0, |
816 | }; | 816 | }; |
817 | struct iattr attr = { | ||
818 | .ia_valid = ATTR_MODE, | ||
819 | .ia_mode = stat.mode, | ||
820 | }; | ||
817 | 821 | ||
818 | if (work->d_inode) { | 822 | if (work->d_inode) { |
819 | err = -EEXIST; | 823 | err = -EEXIST; |
@@ -829,6 +833,21 @@ retry: | |||
829 | err = ovl_create_real(dir, work, &stat, NULL, NULL, true); | 833 | err = ovl_create_real(dir, work, &stat, NULL, NULL, true); |
830 | if (err) | 834 | if (err) |
831 | goto out_dput; | 835 | goto out_dput; |
836 | |||
837 | err = vfs_removexattr(work, XATTR_NAME_POSIX_ACL_DEFAULT); | ||
838 | if (err && err != -ENODATA) | ||
839 | goto out_dput; | ||
840 | |||
841 | err = vfs_removexattr(work, XATTR_NAME_POSIX_ACL_ACCESS); | ||
842 | if (err && err != -ENODATA) | ||
843 | goto out_dput; | ||
844 | |||
845 | /* Clear any inherited mode bits */ | ||
846 | inode_lock(work->d_inode); | ||
847 | err = notify_change(work, &attr, NULL); | ||
848 | inode_unlock(work->d_inode); | ||
849 | if (err) | ||
850 | goto out_dput; | ||
832 | } | 851 | } |
833 | out_unlock: | 852 | out_unlock: |
834 | inode_unlock(dir); | 853 | inode_unlock(dir); |