mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-26 13:44:15 +08:00
764a5c6b1f
Change the list operation to only return whether or not an attribute should be listed. Copying the attribute names into the buffer is moved to the callers. Since the result only depends on the dentry and not on the attribute name, we do not pass the attribute name to list operations. Signed-off-by: Andreas Gruenbacher <agruenba@redhat.com> Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
47 lines
1.2 KiB
C
47 lines
1.2 KiB
C
#include "reiserfs.h"
|
|
#include <linux/capability.h>
|
|
#include <linux/errno.h>
|
|
#include <linux/fs.h>
|
|
#include <linux/pagemap.h>
|
|
#include <linux/xattr.h>
|
|
#include "xattr.h"
|
|
#include <linux/uaccess.h>
|
|
|
|
static int
|
|
trusted_get(const struct xattr_handler *handler, struct dentry *dentry,
|
|
const char *name, void *buffer, size_t size)
|
|
{
|
|
if (strlen(name) < sizeof(XATTR_TRUSTED_PREFIX))
|
|
return -EINVAL;
|
|
|
|
if (!capable(CAP_SYS_ADMIN) || IS_PRIVATE(d_inode(dentry)))
|
|
return -EPERM;
|
|
|
|
return reiserfs_xattr_get(d_inode(dentry), name, buffer, size);
|
|
}
|
|
|
|
static int
|
|
trusted_set(const struct xattr_handler *handler, struct dentry *dentry,
|
|
const char *name, const void *buffer, size_t size, int flags)
|
|
{
|
|
if (strlen(name) < sizeof(XATTR_TRUSTED_PREFIX))
|
|
return -EINVAL;
|
|
|
|
if (!capable(CAP_SYS_ADMIN) || IS_PRIVATE(d_inode(dentry)))
|
|
return -EPERM;
|
|
|
|
return reiserfs_xattr_set(d_inode(dentry), name, buffer, size, flags);
|
|
}
|
|
|
|
static bool trusted_list(struct dentry *dentry)
|
|
{
|
|
return capable(CAP_SYS_ADMIN) && !IS_PRIVATE(d_inode(dentry));
|
|
}
|
|
|
|
const struct xattr_handler reiserfs_xattr_trusted_handler = {
|
|
.prefix = XATTR_TRUSTED_PREFIX,
|
|
.get = trusted_get,
|
|
.set = trusted_set,
|
|
.list = trusted_list,
|
|
};
|