X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;ds=sidebyside;f=fs%2Freiserfs%2Fxattr_user.c;h=073f39364b1136dcd9cbb808f5820b3e5581ff58;hb=43bc926fffd92024b46cafaf7350d669ba9ca884;hp=0772806466a867de2945ecd27fcc9195c9e000ca;hpb=cee37fe97739d85991964371c1f3a745c00dd236;p=linux-2.6.git diff --git a/fs/reiserfs/xattr_user.c b/fs/reiserfs/xattr_user.c index 077280646..073f39364 100644 --- a/fs/reiserfs/xattr_user.c +++ b/fs/reiserfs/xattr_user.c @@ -13,81 +13,50 @@ #define XATTR_USER_PREFIX "user." static int -user_get (struct inode *inode, const char *name, void *buffer, size_t size) +user_get(struct inode *inode, const char *name, void *buffer, size_t size) { - int error; - - if (strlen(name) < sizeof(XATTR_USER_PREFIX)) - return -EINVAL; - - if (!reiserfs_xattrs_user (inode->i_sb)) - return -EOPNOTSUPP; - - error = reiserfs_permission_locked (inode, MAY_READ, NULL); - if (error) - return error; - - return reiserfs_xattr_get (inode, name, buffer, size); + if (strlen(name) < sizeof(XATTR_USER_PREFIX)) + return -EINVAL; + if (!reiserfs_xattrs_user(inode->i_sb)) + return -EOPNOTSUPP; + return reiserfs_xattr_get(inode, name, buffer, size); } static int -user_set (struct inode *inode, const char *name, const void *buffer, - size_t size, int flags) +user_set(struct inode *inode, const char *name, const void *buffer, + size_t size, int flags) { - int error; - - if (strlen(name) < sizeof(XATTR_USER_PREFIX)) - return -EINVAL; - - if (!reiserfs_xattrs_user (inode->i_sb)) - return -EOPNOTSUPP; - - if (!S_ISREG (inode->i_mode) && - (!S_ISDIR (inode->i_mode) || inode->i_mode & S_ISVTX)) - return -EPERM; + if (strlen(name) < sizeof(XATTR_USER_PREFIX)) + return -EINVAL; - error = reiserfs_permission_locked (inode, MAY_WRITE, NULL); - if (error) - return error; - - return reiserfs_xattr_set (inode, name, buffer, size, flags); + if (!reiserfs_xattrs_user(inode->i_sb)) + return -EOPNOTSUPP; + return reiserfs_xattr_set(inode, name, buffer, size, flags); } -static int -user_del (struct inode *inode, const char *name) +static int user_del(struct inode *inode, const char *name) { - int error; - - if (strlen(name) < sizeof(XATTR_USER_PREFIX)) - return -EINVAL; - - if (!reiserfs_xattrs_user (inode->i_sb)) - return -EOPNOTSUPP; - - if (!S_ISREG (inode->i_mode) && - (!S_ISDIR (inode->i_mode) || inode->i_mode & S_ISVTX)) - return -EPERM; - - error = reiserfs_permission_locked (inode, MAY_WRITE, NULL); - if (error) - return error; + if (strlen(name) < sizeof(XATTR_USER_PREFIX)) + return -EINVAL; - return 0; + if (!reiserfs_xattrs_user(inode->i_sb)) + return -EOPNOTSUPP; + return 0; } static int -user_list (struct inode *inode, const char *name, int namelen, char *out) +user_list(struct inode *inode, const char *name, int namelen, char *out) { - int len = namelen; - if (!reiserfs_xattrs_user (inode->i_sb)) - return 0; + int len = namelen; + if (!reiserfs_xattrs_user(inode->i_sb)) + return 0; - if (out) - memcpy (out, name, len); + if (out) + memcpy(out, name, len); - return len; + return len; } struct reiserfs_xattr_handler user_handler = {