Commit e8b0ebaa authored by Barry Naujok's avatar Barry Naujok Committed by Lachlan McIlroy

[XFS] Cleanup xfs_attr a bit with xfs_name and remove cred

SGI-PV: 976035
SGI-Modid: xfs-linux-melb:xfs-kern:30913a
Signed-off-by: default avatarBarry Naujok <bnaujok@sgi.com>
Signed-off-by: default avatarChristoph Hellwig <hch@infradead.org>
Signed-off-by: default avatarLachlan McIlroy <lachlan@sgi.com>
parent 5df78e73
...@@ -505,14 +505,14 @@ xfs_attrmulti_attr_get( ...@@ -505,14 +505,14 @@ xfs_attrmulti_attr_get(
{ {
char *kbuf; char *kbuf;
int error = EFAULT; int error = EFAULT;
if (*len > XATTR_SIZE_MAX) if (*len > XATTR_SIZE_MAX)
return EINVAL; return EINVAL;
kbuf = kmalloc(*len, GFP_KERNEL); kbuf = kmalloc(*len, GFP_KERNEL);
if (!kbuf) if (!kbuf)
return ENOMEM; return ENOMEM;
error = xfs_attr_get(XFS_I(inode), name, kbuf, (int *)len, flags, NULL); error = xfs_attr_get(XFS_I(inode), name, kbuf, (int *)len, flags);
if (error) if (error)
goto out_kfree; goto out_kfree;
...@@ -546,7 +546,7 @@ xfs_attrmulti_attr_set( ...@@ -546,7 +546,7 @@ xfs_attrmulti_attr_set(
if (copy_from_user(kbuf, ubuf, len)) if (copy_from_user(kbuf, ubuf, len))
goto out_kfree; goto out_kfree;
error = xfs_attr_set(XFS_I(inode), name, kbuf, len, flags); error = xfs_attr_set(XFS_I(inode), name, kbuf, len, flags);
out_kfree: out_kfree:
......
...@@ -334,14 +334,15 @@ xfs_acl_iaccess( ...@@ -334,14 +334,15 @@ xfs_acl_iaccess(
{ {
xfs_acl_t *acl; xfs_acl_t *acl;
int rval; int rval;
struct xfs_name acl_name = {SGI_ACL_FILE, SGI_ACL_FILE_SIZE};
if (!(_ACL_ALLOC(acl))) if (!(_ACL_ALLOC(acl)))
return -1; return -1;
/* If the file has no ACL return -1. */ /* If the file has no ACL return -1. */
rval = sizeof(xfs_acl_t); rval = sizeof(xfs_acl_t);
if (xfs_attr_fetch(ip, SGI_ACL_FILE, SGI_ACL_FILE_SIZE, if (xfs_attr_fetch(ip, &acl_name, (char *)acl, &rval,
(char *)acl, &rval, ATTR_ROOT | ATTR_KERNACCESS, cr)) { ATTR_ROOT | ATTR_KERNACCESS)) {
_ACL_FREE(acl); _ACL_FREE(acl);
return -1; return -1;
} }
...@@ -579,7 +580,7 @@ xfs_acl_get_attr( ...@@ -579,7 +580,7 @@ xfs_acl_get_attr(
*error = xfs_attr_get(xfs_vtoi(vp), *error = xfs_attr_get(xfs_vtoi(vp),
kind == _ACL_TYPE_ACCESS ? kind == _ACL_TYPE_ACCESS ?
SGI_ACL_FILE : SGI_ACL_DEFAULT, SGI_ACL_FILE : SGI_ACL_DEFAULT,
(char *)aclp, &len, flags, sys_cred); (char *)aclp, &len, flags);
if (*error || (flags & ATTR_KERNOVAL)) if (*error || (flags & ATTR_KERNOVAL))
return; return;
xfs_acl_get_endian(aclp); xfs_acl_get_endian(aclp);
......
...@@ -101,14 +101,28 @@ STATIC int xfs_attr_rmtval_remove(xfs_da_args_t *args); ...@@ -101,14 +101,28 @@ STATIC int xfs_attr_rmtval_remove(xfs_da_args_t *args);
ktrace_t *xfs_attr_trace_buf; ktrace_t *xfs_attr_trace_buf;
#endif #endif
STATIC int
xfs_attr_name_to_xname(
struct xfs_name *xname,
const char *aname)
{
if (!aname)
return EINVAL;
xname->name = aname;
xname->len = strlen(aname);
if (xname->len >= MAXNAMELEN)
return EFAULT; /* match IRIX behaviour */
return 0;
}
/*======================================================================== /*========================================================================
* Overall external interface routines. * Overall external interface routines.
*========================================================================*/ *========================================================================*/
int int
xfs_attr_fetch(xfs_inode_t *ip, const char *name, int namelen, xfs_attr_fetch(xfs_inode_t *ip, struct xfs_name *name,
char *value, int *valuelenp, int flags, struct cred *cred) char *value, int *valuelenp, int flags)
{ {
xfs_da_args_t args; xfs_da_args_t args;
int error; int error;
...@@ -122,8 +136,8 @@ xfs_attr_fetch(xfs_inode_t *ip, const char *name, int namelen, ...@@ -122,8 +136,8 @@ xfs_attr_fetch(xfs_inode_t *ip, const char *name, int namelen,
* Fill in the arg structure for this request. * Fill in the arg structure for this request.
*/ */
memset((char *)&args, 0, sizeof(args)); memset((char *)&args, 0, sizeof(args));
args.name = name; args.name = name->name;
args.namelen = namelen; args.namelen = name->len;
args.value = value; args.value = value;
args.valuelen = *valuelenp; args.valuelen = *valuelenp;
args.flags = flags; args.flags = flags;
...@@ -162,31 +176,29 @@ xfs_attr_get( ...@@ -162,31 +176,29 @@ xfs_attr_get(
const char *name, const char *name,
char *value, char *value,
int *valuelenp, int *valuelenp,
int flags, int flags)
cred_t *cred)
{ {
int error, namelen; int error;
struct xfs_name xname;
XFS_STATS_INC(xs_attr_get); XFS_STATS_INC(xs_attr_get);
if (!name)
return(EINVAL);
namelen = strlen(name);
if (namelen >= MAXNAMELEN)
return(EFAULT); /* match IRIX behaviour */
if (XFS_FORCED_SHUTDOWN(ip->i_mount)) if (XFS_FORCED_SHUTDOWN(ip->i_mount))
return(EIO); return(EIO);
error = xfs_attr_name_to_xname(&xname, name);
if (error)
return error;
xfs_ilock(ip, XFS_ILOCK_SHARED); xfs_ilock(ip, XFS_ILOCK_SHARED);
error = xfs_attr_fetch(ip, name, namelen, value, valuelenp, flags, cred); error = xfs_attr_fetch(ip, &xname, value, valuelenp, flags);
xfs_iunlock(ip, XFS_ILOCK_SHARED); xfs_iunlock(ip, XFS_ILOCK_SHARED);
return(error); return(error);
} }
int STATIC int
xfs_attr_set_int(xfs_inode_t *dp, const char *name, int namelen, xfs_attr_set_int(xfs_inode_t *dp, struct xfs_name *name,
char *value, int valuelen, int flags) char *value, int valuelen, int flags)
{ {
xfs_da_args_t args; xfs_da_args_t args;
xfs_fsblock_t firstblock; xfs_fsblock_t firstblock;
...@@ -209,7 +221,7 @@ xfs_attr_set_int(xfs_inode_t *dp, const char *name, int namelen, ...@@ -209,7 +221,7 @@ xfs_attr_set_int(xfs_inode_t *dp, const char *name, int namelen,
*/ */
if (XFS_IFORK_Q(dp) == 0) { if (XFS_IFORK_Q(dp) == 0) {
int sf_size = sizeof(xfs_attr_sf_hdr_t) + int sf_size = sizeof(xfs_attr_sf_hdr_t) +
XFS_ATTR_SF_ENTSIZE_BYNAME(namelen, valuelen); XFS_ATTR_SF_ENTSIZE_BYNAME(name->len, valuelen);
if ((error = xfs_bmap_add_attrfork(dp, sf_size, rsvd))) if ((error = xfs_bmap_add_attrfork(dp, sf_size, rsvd)))
return(error); return(error);
...@@ -219,8 +231,8 @@ xfs_attr_set_int(xfs_inode_t *dp, const char *name, int namelen, ...@@ -219,8 +231,8 @@ xfs_attr_set_int(xfs_inode_t *dp, const char *name, int namelen,
* Fill in the arg structure for this request. * Fill in the arg structure for this request.
*/ */
memset((char *)&args, 0, sizeof(args)); memset((char *)&args, 0, sizeof(args));
args.name = name; args.name = name->name;
args.namelen = namelen; args.namelen = name->len;
args.value = value; args.value = value;
args.valuelen = valuelen; args.valuelen = valuelen;
args.flags = flags; args.flags = flags;
...@@ -236,7 +248,7 @@ xfs_attr_set_int(xfs_inode_t *dp, const char *name, int namelen, ...@@ -236,7 +248,7 @@ xfs_attr_set_int(xfs_inode_t *dp, const char *name, int namelen,
* Determine space new attribute will use, and if it would be * Determine space new attribute will use, and if it would be
* "local" or "remote" (note: local != inline). * "local" or "remote" (note: local != inline).
*/ */
size = xfs_attr_leaf_newentsize(namelen, valuelen, size = xfs_attr_leaf_newentsize(name->len, valuelen,
mp->m_sb.sb_blocksize, &local); mp->m_sb.sb_blocksize, &local);
nblks = XFS_DAENTER_SPACE_RES(mp, XFS_ATTR_FORK); nblks = XFS_DAENTER_SPACE_RES(mp, XFS_ATTR_FORK);
...@@ -429,26 +441,27 @@ xfs_attr_set( ...@@ -429,26 +441,27 @@ xfs_attr_set(
int valuelen, int valuelen,
int flags) int flags)
{ {
int namelen; int error;
struct xfs_name xname;
namelen = strlen(name);
if (namelen >= MAXNAMELEN)
return EFAULT; /* match IRIX behaviour */
XFS_STATS_INC(xs_attr_set); XFS_STATS_INC(xs_attr_set);
if (XFS_FORCED_SHUTDOWN(dp->i_mount)) if (XFS_FORCED_SHUTDOWN(dp->i_mount))
return (EIO); return (EIO);
return xfs_attr_set_int(dp, name, namelen, value, valuelen, flags); error = xfs_attr_name_to_xname(&xname, name);
if (error)
return error;
return xfs_attr_set_int(dp, &xname, value, valuelen, flags);
} }
/* /*
* Generic handler routine to remove a name from an attribute list. * Generic handler routine to remove a name from an attribute list.
* Transitions attribute list from Btree to shortform as necessary. * Transitions attribute list from Btree to shortform as necessary.
*/ */
int STATIC int
xfs_attr_remove_int(xfs_inode_t *dp, const char *name, int namelen, int flags) xfs_attr_remove_int(xfs_inode_t *dp, struct xfs_name *name, int flags)
{ {
xfs_da_args_t args; xfs_da_args_t args;
xfs_fsblock_t firstblock; xfs_fsblock_t firstblock;
...@@ -460,8 +473,8 @@ xfs_attr_remove_int(xfs_inode_t *dp, const char *name, int namelen, int flags) ...@@ -460,8 +473,8 @@ xfs_attr_remove_int(xfs_inode_t *dp, const char *name, int namelen, int flags)
* Fill in the arg structure for this request. * Fill in the arg structure for this request.
*/ */
memset((char *)&args, 0, sizeof(args)); memset((char *)&args, 0, sizeof(args));
args.name = name; args.name = name->name;
args.namelen = namelen; args.namelen = name->len;
args.flags = flags; args.flags = flags;
args.hashval = xfs_da_hashname(args.name, args.namelen); args.hashval = xfs_da_hashname(args.name, args.namelen);
args.dp = dp; args.dp = dp;
...@@ -575,17 +588,18 @@ xfs_attr_remove( ...@@ -575,17 +588,18 @@ xfs_attr_remove(
const char *name, const char *name,
int flags) int flags)
{ {
int namelen; int error;
struct xfs_name xname;
namelen = strlen(name);
if (namelen >= MAXNAMELEN)
return EFAULT; /* match IRIX behaviour */
XFS_STATS_INC(xs_attr_remove); XFS_STATS_INC(xs_attr_remove);
if (XFS_FORCED_SHUTDOWN(dp->i_mount)) if (XFS_FORCED_SHUTDOWN(dp->i_mount))
return (EIO); return (EIO);
error = xfs_attr_name_to_xname(&xname, name);
if (error)
return error;
xfs_ilock(dp, XFS_ILOCK_SHARED); xfs_ilock(dp, XFS_ILOCK_SHARED);
if (XFS_IFORK_Q(dp) == 0 || if (XFS_IFORK_Q(dp) == 0 ||
(dp->i_d.di_aformat == XFS_DINODE_FMT_EXTENTS && (dp->i_d.di_aformat == XFS_DINODE_FMT_EXTENTS &&
...@@ -595,10 +609,10 @@ xfs_attr_remove( ...@@ -595,10 +609,10 @@ xfs_attr_remove(
} }
xfs_iunlock(dp, XFS_ILOCK_SHARED); xfs_iunlock(dp, XFS_ILOCK_SHARED);
return xfs_attr_remove_int(dp, name, namelen, flags); return xfs_attr_remove_int(dp, &xname, flags);
} }
int /* error */ STATIC int
xfs_attr_list_int(xfs_attr_list_context_t *context) xfs_attr_list_int(xfs_attr_list_context_t *context)
{ {
int error; int error;
...@@ -2522,8 +2536,7 @@ attr_generic_get( ...@@ -2522,8 +2536,7 @@ attr_generic_get(
{ {
int error, asize = size; int error, asize = size;
error = xfs_attr_get(xfs_vtoi(vp), name, data, error = xfs_attr_get(xfs_vtoi(vp), name, data, &asize, xflags);
&asize, xflags, NULL);
if (!error) if (!error)
return asize; return asize;
return -error; return -error;
......
...@@ -158,14 +158,10 @@ struct xfs_da_args; ...@@ -158,14 +158,10 @@ struct xfs_da_args;
/* /*
* Overall external interface routines. * Overall external interface routines.
*/ */
int xfs_attr_set_int(struct xfs_inode *, const char *, int, char *, int, int);
int xfs_attr_remove_int(struct xfs_inode *, const char *, int, int);
int xfs_attr_list_int(struct xfs_attr_list_context *);
int xfs_attr_inactive(struct xfs_inode *dp); int xfs_attr_inactive(struct xfs_inode *dp);
int xfs_attr_shortform_getvalue(struct xfs_da_args *); int xfs_attr_shortform_getvalue(struct xfs_da_args *);
int xfs_attr_fetch(struct xfs_inode *, const char *, int, int xfs_attr_fetch(struct xfs_inode *, struct xfs_name *, char *, int *, int);
char *, int *, int, struct cred *);
int xfs_attr_rmtval_get(struct xfs_da_args *args); int xfs_attr_rmtval_get(struct xfs_da_args *args);
#endif /* __XFS_ATTR_H__ */ #endif /* __XFS_ATTR_H__ */
...@@ -49,7 +49,7 @@ int xfs_rename(struct xfs_inode *src_dp, struct xfs_name *src_name, ...@@ -49,7 +49,7 @@ int xfs_rename(struct xfs_inode *src_dp, struct xfs_name *src_name,
struct xfs_inode *src_ip, struct xfs_inode *target_dp, struct xfs_inode *src_ip, struct xfs_inode *target_dp,
struct xfs_name *target_name, struct xfs_inode *target_ip); struct xfs_name *target_name, struct xfs_inode *target_ip);
int xfs_attr_get(struct xfs_inode *ip, const char *name, char *value, int xfs_attr_get(struct xfs_inode *ip, const char *name, char *value,
int *valuelenp, int flags, cred_t *cred); int *valuelenp, int flags);
int xfs_attr_set(struct xfs_inode *dp, const char *name, char *value, int xfs_attr_set(struct xfs_inode *dp, const char *name, char *value,
int valuelen, int flags); int valuelen, int flags);
int xfs_attr_remove(struct xfs_inode *dp, const char *name, int flags); int xfs_attr_remove(struct xfs_inode *dp, const char *name, int flags);
......
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