提交 ffc4c922 编写于 作者: A Andreas Gruenbacher 提交者: Al Viro

sysfs: Do not return POSIX ACL xattrs via listxattr

Commit 786534b9 introduced a regression that caused listxattr to
return the POSIX ACL attribute names even though sysfs doesn't support
POSIX ACLs.  This happens because simple_xattr_list checks for NULL
i_acl / i_default_acl, but inode_init_always initializes those fields
to ACL_NOT_CACHED ((void *)-1).  For example:
    $ getfattr -m- -d /sys
    /sys: system.posix_acl_access: Operation not supported
    /sys: system.posix_acl_default: Operation not supported
Fix this in simple_xattr_list by checking if the filesystem supports POSIX ACLs.

Fixes: 786534b9 ("tmpfs: listxattr should include POSIX ACL xattrs")
Reported-by: NMarc Aurèle La France <tsi@tuyoix.net>
Tested-by: NMarc Aurèle La France <tsi@tuyoix.net>
Signed-off-by: NAndreas Gruenbacher <agruenba@redhat.com>
Cc: stable@vger.kernel.org # v4.5+
Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
上级 5b394b2d
...@@ -948,17 +948,19 @@ ssize_t simple_xattr_list(struct inode *inode, struct simple_xattrs *xattrs, ...@@ -948,17 +948,19 @@ ssize_t simple_xattr_list(struct inode *inode, struct simple_xattrs *xattrs,
int err = 0; int err = 0;
#ifdef CONFIG_FS_POSIX_ACL #ifdef CONFIG_FS_POSIX_ACL
if (inode->i_acl) { if (IS_POSIXACL(inode)) {
err = xattr_list_one(&buffer, &remaining_size, if (inode->i_acl) {
XATTR_NAME_POSIX_ACL_ACCESS); err = xattr_list_one(&buffer, &remaining_size,
if (err) XATTR_NAME_POSIX_ACL_ACCESS);
return err; if (err)
} return err;
if (inode->i_default_acl) { }
err = xattr_list_one(&buffer, &remaining_size, if (inode->i_default_acl) {
XATTR_NAME_POSIX_ACL_DEFAULT); err = xattr_list_one(&buffer, &remaining_size,
if (err) XATTR_NAME_POSIX_ACL_DEFAULT);
return err; if (err)
return err;
}
} }
#endif #endif
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册