Commit 9a2add46 authored by Al Viro's avatar Al Viro Committed by Luis Henriques

reiserfs: switch to generic_{get,set,remove}xattr()

BugLink: http://bugs.launchpad.net/bugs/1637501

commit 79a628d1 upstream.

reiserfs_xattr_[sg]et() will fail with -EOPNOTSUPP for V1 inodes anyway,
and all reiserfs instances of ->[sg]et() call it and so does ->set_acl().

Checks for name length in the instances had been bogus; they should've
been "bugger off if it's _exactly_ the prefix" (as generic would
do on its own) and not "bugger off if it's shorter than the prefix" -
that can't happen.

xattr_full_name() is needed to adjust for the fact that generic instances
will skip the prefix in the name passed to ->[gs]et(); reiserfs homegrown
analogues didn't.
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
[jeffm: Backported to v4.4: adjust context]
Signed-off-by: default avatarJeff Mahoney <jeffm@suse.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarTim Gardner <tim.gardner@canonical.com>
parent 135b9a33
...@@ -260,10 +260,10 @@ const struct file_operations reiserfs_file_operations = { ...@@ -260,10 +260,10 @@ const struct file_operations reiserfs_file_operations = {
const struct inode_operations reiserfs_file_inode_operations = { const struct inode_operations reiserfs_file_inode_operations = {
.setattr = reiserfs_setattr, .setattr = reiserfs_setattr,
.setxattr = reiserfs_setxattr, .setxattr = generic_setxattr,
.getxattr = reiserfs_getxattr, .getxattr = generic_getxattr,
.listxattr = reiserfs_listxattr, .listxattr = reiserfs_listxattr,
.removexattr = reiserfs_removexattr, .removexattr = generic_removexattr,
.permission = reiserfs_permission, .permission = reiserfs_permission,
.get_acl = reiserfs_get_acl, .get_acl = reiserfs_get_acl,
.set_acl = reiserfs_set_acl, .set_acl = reiserfs_set_acl,
......
...@@ -1649,10 +1649,10 @@ const struct inode_operations reiserfs_dir_inode_operations = { ...@@ -1649,10 +1649,10 @@ const struct inode_operations reiserfs_dir_inode_operations = {
.mknod = reiserfs_mknod, .mknod = reiserfs_mknod,
.rename = reiserfs_rename, .rename = reiserfs_rename,
.setattr = reiserfs_setattr, .setattr = reiserfs_setattr,
.setxattr = reiserfs_setxattr, .setxattr = generic_setxattr,
.getxattr = reiserfs_getxattr, .getxattr = generic_getxattr,
.listxattr = reiserfs_listxattr, .listxattr = reiserfs_listxattr,
.removexattr = reiserfs_removexattr, .removexattr = generic_removexattr,
.permission = reiserfs_permission, .permission = reiserfs_permission,
.get_acl = reiserfs_get_acl, .get_acl = reiserfs_get_acl,
.set_acl = reiserfs_set_acl, .set_acl = reiserfs_set_acl,
...@@ -1667,10 +1667,10 @@ const struct inode_operations reiserfs_symlink_inode_operations = { ...@@ -1667,10 +1667,10 @@ const struct inode_operations reiserfs_symlink_inode_operations = {
.follow_link = page_follow_link_light, .follow_link = page_follow_link_light,
.put_link = page_put_link, .put_link = page_put_link,
.setattr = reiserfs_setattr, .setattr = reiserfs_setattr,
.setxattr = reiserfs_setxattr, .setxattr = generic_setxattr,
.getxattr = reiserfs_getxattr, .getxattr = generic_getxattr,
.listxattr = reiserfs_listxattr, .listxattr = reiserfs_listxattr,
.removexattr = reiserfs_removexattr, .removexattr = generic_removexattr,
.permission = reiserfs_permission, .permission = reiserfs_permission,
}; };
...@@ -1679,10 +1679,10 @@ const struct inode_operations reiserfs_symlink_inode_operations = { ...@@ -1679,10 +1679,10 @@ const struct inode_operations reiserfs_symlink_inode_operations = {
*/ */
const struct inode_operations reiserfs_special_inode_operations = { const struct inode_operations reiserfs_special_inode_operations = {
.setattr = reiserfs_setattr, .setattr = reiserfs_setattr,
.setxattr = reiserfs_setxattr, .setxattr = generic_setxattr,
.getxattr = reiserfs_getxattr, .getxattr = generic_getxattr,
.listxattr = reiserfs_listxattr, .listxattr = reiserfs_listxattr,
.removexattr = reiserfs_removexattr, .removexattr = generic_removexattr,
.permission = reiserfs_permission, .permission = reiserfs_permission,
.get_acl = reiserfs_get_acl, .get_acl = reiserfs_get_acl,
.set_acl = reiserfs_set_acl, .set_acl = reiserfs_set_acl,
......
...@@ -763,60 +763,6 @@ find_xattr_handler_prefix(const struct xattr_handler **handlers, ...@@ -763,60 +763,6 @@ find_xattr_handler_prefix(const struct xattr_handler **handlers,
return xah; return xah;
} }
/*
* Inode operation getxattr()
*/
ssize_t
reiserfs_getxattr(struct dentry * dentry, const char *name, void *buffer,
size_t size)
{
const struct xattr_handler *handler;
handler = find_xattr_handler_prefix(dentry->d_sb->s_xattr, name);
if (!handler || get_inode_sd_version(d_inode(dentry)) == STAT_DATA_V1)
return -EOPNOTSUPP;
return handler->get(handler, dentry, name, buffer, size);
}
/*
* Inode operation setxattr()
*
* d_inode(dentry)->i_mutex down
*/
int
reiserfs_setxattr(struct dentry *dentry, const char *name, const void *value,
size_t size, int flags)
{
const struct xattr_handler *handler;
handler = find_xattr_handler_prefix(dentry->d_sb->s_xattr, name);
if (!handler || get_inode_sd_version(d_inode(dentry)) == STAT_DATA_V1)
return -EOPNOTSUPP;
return handler->set(handler, dentry, name, value, size, flags);
}
/*
* Inode operation removexattr()
*
* d_inode(dentry)->i_mutex down
*/
int reiserfs_removexattr(struct dentry *dentry, const char *name)
{
const struct xattr_handler *handler;
handler = find_xattr_handler_prefix(dentry->d_sb->s_xattr, name);
if (!handler || get_inode_sd_version(d_inode(dentry)) == STAT_DATA_V1)
return -EOPNOTSUPP;
return handler->set(handler, dentry, name, NULL, 0, XATTR_REPLACE);
}
struct listxattr_buf { struct listxattr_buf {
struct dir_context ctx; struct dir_context ctx;
size_t size; size_t size;
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/list.h> #include <linux/list.h>
#include <linux/rwsem.h> #include <linux/rwsem.h>
#include <linux/xattr.h>
struct inode; struct inode;
struct dentry; struct dentry;
...@@ -18,12 +19,7 @@ int reiserfs_permission(struct inode *inode, int mask); ...@@ -18,12 +19,7 @@ int reiserfs_permission(struct inode *inode, int mask);
#ifdef CONFIG_REISERFS_FS_XATTR #ifdef CONFIG_REISERFS_FS_XATTR
#define has_xattr_dir(inode) (REISERFS_I(inode)->i_flags & i_has_xattr_dir) #define has_xattr_dir(inode) (REISERFS_I(inode)->i_flags & i_has_xattr_dir)
ssize_t reiserfs_getxattr(struct dentry *dentry, const char *name,
void *buffer, size_t size);
int reiserfs_setxattr(struct dentry *dentry, const char *name,
const void *value, size_t size, int flags);
ssize_t reiserfs_listxattr(struct dentry *dentry, char *buffer, size_t size); ssize_t reiserfs_listxattr(struct dentry *dentry, char *buffer, size_t size);
int reiserfs_removexattr(struct dentry *dentry, const char *name);
int reiserfs_xattr_get(struct inode *, const char *, void *, size_t); int reiserfs_xattr_get(struct inode *, const char *, void *, size_t);
int reiserfs_xattr_set(struct inode *, const char *, const void *, size_t, int); int reiserfs_xattr_set(struct inode *, const char *, const void *, size_t, int);
...@@ -92,10 +88,7 @@ static inline void reiserfs_init_xattr_rwsem(struct inode *inode) ...@@ -92,10 +88,7 @@ static inline void reiserfs_init_xattr_rwsem(struct inode *inode)
#else #else
#define reiserfs_getxattr NULL
#define reiserfs_setxattr NULL
#define reiserfs_listxattr NULL #define reiserfs_listxattr NULL
#define reiserfs_removexattr NULL
static inline void reiserfs_init_xattr_rwsem(struct inode *inode) static inline void reiserfs_init_xattr_rwsem(struct inode *inode)
{ {
......
...@@ -12,26 +12,24 @@ static int ...@@ -12,26 +12,24 @@ static int
security_get(const struct xattr_handler *handler, struct dentry *dentry, security_get(const struct xattr_handler *handler, struct dentry *dentry,
const char *name, void *buffer, size_t size) const char *name, void *buffer, size_t size)
{ {
if (strlen(name) < sizeof(XATTR_SECURITY_PREFIX))
return -EINVAL;
if (IS_PRIVATE(d_inode(dentry))) if (IS_PRIVATE(d_inode(dentry)))
return -EPERM; return -EPERM;
return reiserfs_xattr_get(d_inode(dentry), name, buffer, size); return reiserfs_xattr_get(d_inode(dentry),
xattr_full_name(handler, name),
buffer, size);
} }
static int static int
security_set(const struct xattr_handler *handler, struct dentry *dentry, security_set(const struct xattr_handler *handler, struct dentry *dentry,
const char *name, const void *buffer, size_t size, int flags) const char *name, const void *buffer, size_t size, int flags)
{ {
if (strlen(name) < sizeof(XATTR_SECURITY_PREFIX))
return -EINVAL;
if (IS_PRIVATE(d_inode(dentry))) if (IS_PRIVATE(d_inode(dentry)))
return -EPERM; return -EPERM;
return reiserfs_xattr_set(d_inode(dentry), name, buffer, size, flags); return reiserfs_xattr_set(d_inode(dentry),
xattr_full_name(handler, name),
buffer, size, flags);
} }
static size_t security_list(const struct xattr_handler *handler, static size_t security_list(const struct xattr_handler *handler,
......
...@@ -11,26 +11,24 @@ static int ...@@ -11,26 +11,24 @@ static int
trusted_get(const struct xattr_handler *handler, struct dentry *dentry, trusted_get(const struct xattr_handler *handler, struct dentry *dentry,
const char *name, void *buffer, size_t size) 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))) if (!capable(CAP_SYS_ADMIN) || IS_PRIVATE(d_inode(dentry)))
return -EPERM; return -EPERM;
return reiserfs_xattr_get(d_inode(dentry), name, buffer, size); return reiserfs_xattr_get(d_inode(dentry),
xattr_full_name(handler, name),
buffer, size);
} }
static int static int
trusted_set(const struct xattr_handler *handler, struct dentry *dentry, trusted_set(const struct xattr_handler *handler, struct dentry *dentry,
const char *name, const void *buffer, size_t size, int flags) 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))) if (!capable(CAP_SYS_ADMIN) || IS_PRIVATE(d_inode(dentry)))
return -EPERM; return -EPERM;
return reiserfs_xattr_set(d_inode(dentry), name, buffer, size, flags); return reiserfs_xattr_set(d_inode(dentry),
xattr_full_name(handler, name),
buffer, size, flags);
} }
static size_t trusted_list(const struct xattr_handler *handler, static size_t trusted_list(const struct xattr_handler *handler,
......
...@@ -10,24 +10,22 @@ static int ...@@ -10,24 +10,22 @@ static int
user_get(const struct xattr_handler *handler, struct dentry *dentry, user_get(const struct xattr_handler *handler, struct dentry *dentry,
const char *name, void *buffer, size_t size) const char *name, void *buffer, size_t size)
{ {
if (strlen(name) < sizeof(XATTR_USER_PREFIX))
return -EINVAL;
if (!reiserfs_xattrs_user(dentry->d_sb)) if (!reiserfs_xattrs_user(dentry->d_sb))
return -EOPNOTSUPP; return -EOPNOTSUPP;
return reiserfs_xattr_get(d_inode(dentry), name, buffer, size); return reiserfs_xattr_get(d_inode(dentry),
xattr_full_name(handler, name),
buffer, size);
} }
static int static int
user_set(const struct xattr_handler *handler, struct dentry *dentry, user_set(const struct xattr_handler *handler, struct dentry *dentry,
const char *name, const void *buffer, size_t size, int flags) const char *name, const void *buffer, size_t size, int flags)
{ {
if (strlen(name) < sizeof(XATTR_USER_PREFIX))
return -EINVAL;
if (!reiserfs_xattrs_user(dentry->d_sb)) if (!reiserfs_xattrs_user(dentry->d_sb))
return -EOPNOTSUPP; return -EOPNOTSUPP;
return reiserfs_xattr_set(d_inode(dentry), name, buffer, size, flags); return reiserfs_xattr_set(d_inode(dentry),
xattr_full_name(handler, name),
buffer, size, flags);
} }
static size_t user_list(const struct xattr_handler *handler, static size_t user_list(const struct xattr_handler *handler,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment