2007-11-30 00:32:47

by Trond Myklebust

[permalink] [raw]
Subject: Re: [NFS] [PATCH 05/29] NFS: Ensure NFSv4 SETCLIENTID send buffer is large enough


On Thu, 2007-11-29 at 14:40 -0500, Chuck Lever wrote:
> Ensure that the RPC buffer size specified for NFSv4 SETCLIENTID procedures
> matches what we are encoding into the buffer. See the definition of
> struct nfs4_setclientid {} and the encode_setclientid() function.
>
> Signed-off-by: Chuck Lever <[email protected]>
> ---
>
> fs/nfs/nfs4xdr.c | 10 ++++++----
> include/linux/nfs_xdr.h | 13 +++++++------
> 2 files changed, 13 insertions(+), 10 deletions(-)
>
> diff --git a/fs/nfs/nfs4xdr.c b/fs/nfs/nfs4xdr.c
> index eae46f0..cb7a835 100644
> --- a/fs/nfs/nfs4xdr.c
> +++ b/fs/nfs/nfs4xdr.c
> @@ -116,10 +116,12 @@ static int nfs4_stat_to_errno(int);
> #define decode_renew_maxsz (op_decode_hdr_maxsz)
> #define encode_setclientid_maxsz \
> (op_encode_hdr_maxsz + \
> - 4 /*server->ip_addr*/ + \
> - 1 /*Netid*/ + \
> - 6 /*uaddr*/ + \
> - 6 + (NFS4_VERIFIER_SIZE >> 2))
> + XDR_QUADLEN(NFS4_VERIFIER_SIZE) + \
> + XDR_QUADLEN(48) /* sc_name */ + \
> + 1 /* sc_prog */ + \
> + XDR_QUADLEN(RPCBIND_MAXNETIDLEN) + \
> + XDR_QUADLEN(RPCBIND_MAXUADDRLEN) + \
> + 1) /* sc_cb_ident */
> #define decode_setclientid_maxsz \
> (op_decode_hdr_maxsz + \
> 2 + \
> diff --git a/include/linux/nfs_xdr.h b/include/linux/nfs_xdr.h
> index 58751f3..d740dfa 100644
> --- a/include/linux/nfs_xdr.h
> +++ b/include/linux/nfs_xdr.h
> @@ -666,16 +666,17 @@ struct nfs4_rename_res {
> struct nfs_fattr * new_fattr;
> };
>
> +#define NFS4_SETCLIENTID_NAMELEN (48)
> struct nfs4_setclientid {
> - const nfs4_verifier * sc_verifier; /* request */
> + const nfs4_verifier * sc_verifier;
> unsigned int sc_name_len;
> - char sc_name[48]; /* request */
> - u32 sc_prog; /* request */
> + char sc_name[NFS4_SETCLIENTID_NAMELEN];
> + u32 sc_prog;
> unsigned int sc_netid_len;
> - char sc_netid[4]; /* request */
> + char sc_netid[RPCBIND_MAXNETIDLEN];
> unsigned int sc_uaddr_len;
> - char sc_uaddr[24]; /* request */
> - u32 sc_cb_ident; /* request */
> + char sc_uaddr[RPCBIND_MAXUADDRLEN];
> + u32 sc_cb_ident;
> };
>
> struct nfs4_statfs_arg {

Hmm... This one looks a little odd. On the one hand you've replaced
sc_name[48] by sc_name[NFS4_SETCLIENTID_NAMELEN], but in
encode_setclientid_maxsz you've hard-coded the 48 again...

Cheers
Trond


-------------------------------------------------------------------------
SF.Net email is sponsored by: The Future of Linux Business White Paper
from Novell. From the desktop to the data center, Linux is going
mainstream. Let it simplify your IT future.
http://altfarm.mediaplex.com/ad/ck/8857-50307-18918-4
_______________________________________________
NFS maillist - [email protected]
https://lists.sourceforge.net/lists/listinfo/nfs
_______________________________________________
Please note that [email protected] is being discontinued.
Please subscribe to [email protected] instead.
http://vger.kernel.org/vger-lists.html#linux-nfs