NFSv4: Support NFSv4 optional attributes in the struct nfs_fattr
Currently, filling struct nfs_fattr is more or less an all or nothing operation, since NFSv2 and NFSv3 have only mandatory attributes. In NFSv4, some attributes are optional, and so we may simply not be able to fill in those fields. Furthermore, NFSv4 allows you to specify which attributes you are interested in retrieving, thus permitting you to optimise away retrieval of attributes that you know will no change... Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
This commit is contained in:
parent
78f945f88e
commit
9e6e70f8d8
5 changed files with 202 additions and 103 deletions
|
@ -3012,7 +3012,7 @@ static int decode_getfattr(struct xdr_stream *xdr, struct nfs_fattr *fattr, cons
|
|||
if ((status = decode_attr_type(xdr, bitmap, &type)) != 0)
|
||||
goto xdr_error;
|
||||
fattr->type = nfs_type2fmt[type].nfs2type;
|
||||
fmode = nfs_type2fmt[type].mode;
|
||||
fattr->mode = nfs_type2fmt[type].mode;
|
||||
|
||||
if ((status = decode_attr_change(xdr, bitmap, &fattr->change_attr)) != 0)
|
||||
goto xdr_error;
|
||||
|
@ -3026,7 +3026,7 @@ static int decode_getfattr(struct xdr_stream *xdr, struct nfs_fattr *fattr, cons
|
|||
struct nfs4_fs_locations,
|
||||
fattr))) != 0)
|
||||
goto xdr_error;
|
||||
if ((status = decode_attr_mode(xdr, bitmap, &fattr->mode)) != 0)
|
||||
if ((status = decode_attr_mode(xdr, bitmap, &fmode)) != 0)
|
||||
goto xdr_error;
|
||||
fattr->mode |= fmode;
|
||||
if ((status = decode_attr_nlink(xdr, bitmap, &fattr->nlink)) != 0)
|
||||
|
@ -3050,7 +3050,7 @@ static int decode_getfattr(struct xdr_stream *xdr, struct nfs_fattr *fattr, cons
|
|||
if (fattr->fileid == 0 && fileid != 0)
|
||||
fattr->fileid = fileid;
|
||||
if ((status = verify_attr_len(xdr, savep, attrlen)) == 0)
|
||||
fattr->valid = NFS_ATTR_FATTR | NFS_ATTR_FATTR_V3 | NFS_ATTR_FATTR_V4;
|
||||
fattr->valid = NFS_ATTR_FATTR_V4;
|
||||
xdr_error:
|
||||
dprintk("%s: xdr returned %d\n", __func__, -status);
|
||||
return status;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue