From: Benny Halevy <bhalevy@panasas.com>
To: Ricardo Labiaga <Ricardo.Labiaga@netapp.com>
Cc: bfields@fieldses.org, pnfs@linux-nfs.org,
linux-nfs@vger.kernel.org, Andy Adamson <andros@netapp.com>
Subject: Re: [RFC 11/11] nfsd41: Refactor create_client()
Date: Wed, 20 May 2009 11:18:42 +0300 [thread overview]
Message-ID: <4A13BCE2.1070303@panasas.com> (raw)
In-Reply-To: <1242788428-18723-11-git-send-email-Ricardo.Labiaga@netapp.com>
Ricardo, this patch conflicts with Andy's DRC changes.
I'm not sure who'll go first into Bruce's branch but
the other guy will need to rebase his patches accordingly...
Benny
On May. 20, 2009, 6:00 +0300, Ricardo Labiaga <Ricardo.Labiaga@netapp.com> wrote:
> Move common initialization of 'struct nfs4_client' inside create_client().
>
> Signed-off-by: Ricardo Labiaga <Ricardo.Labiaga@netapp.com>
>
> [nfsd41: Remember the auth flavor to use for callbacks]
> Signed-off-by: Ricardo Labiaga <Ricardo.Labiaga@netapp.com>
> Signed-off-by: Benny Halevy <bhalevy@panasas.com>
> ---
> fs/nfsd/nfs4state.c | 90 +++++++++++++++++++++++++-------------------------
> 1 files changed, 45 insertions(+), 45 deletions(-)
>
> diff --git a/fs/nfsd/nfs4state.c b/fs/nfsd/nfs4state.c
> index 45cbbbc..1e4740f 100644
> --- a/fs/nfsd/nfs4state.c
> +++ b/fs/nfsd/nfs4state.c
> @@ -710,27 +710,6 @@ expire_client(struct nfs4_client *clp)
> put_nfs4_client(clp);
> }
>
> -static struct nfs4_client *create_client(struct xdr_netobj name, char *recdir)
> -{
> - struct nfs4_client *clp;
> -
> - clp = alloc_client(name);
> - if (clp == NULL)
> - return NULL;
> - memcpy(clp->cl_recdir, recdir, HEXDIR_LEN);
> - atomic_set(&clp->cl_count, 1);
> - atomic_set(&clp->cl_cb_conn.cb_set, 0);
> - INIT_LIST_HEAD(&clp->cl_idhash);
> - INIT_LIST_HEAD(&clp->cl_strhash);
> - INIT_LIST_HEAD(&clp->cl_openowners);
> - INIT_LIST_HEAD(&clp->cl_delegations);
> - INIT_LIST_HEAD(&clp->cl_sessions);
> - INIT_LIST_HEAD(&clp->cl_lru);
> - clear_bit(0, &clp->cl_cb_slot_busy);
> - rpc_init_wait_queue(&clp->cl_cb_waitq, "Backchannel slot table");
> - return clp;
> -}
> -
> static void copy_verf(struct nfs4_client *target, nfs4_verifier *source)
> {
> memcpy(target->cl_verifier.data, source->data,
> @@ -793,6 +772,46 @@ static void gen_confirm(struct nfs4_client *clp)
> *p++ = i++;
> }
>
> +static struct nfs4_client *create_client(struct xdr_netobj name, char *recdir,
> + struct svc_rqst *rqstp, nfs4_verifier *verf)
> +{
> + struct nfs4_client *clp;
> + u32 ip_addr = svc_addr_in(rqstp)->sin_addr.s_addr;
> + char *princ;
> +
> + clp = alloc_client(name);
> + if (clp == NULL)
> + return NULL;
> +
> + princ = svc_gss_principal(rqstp);
> + if (princ) {
> + clp->cl_principal = kstrdup(princ, GFP_KERNEL);
> + if (clp->cl_principal == NULL) {
> + free_client(clp);
> + return NULL;
> + }
> + }
> +
> + memcpy(clp->cl_recdir, recdir, HEXDIR_LEN);
> + atomic_set(&clp->cl_count, 1);
> + atomic_set(&clp->cl_cb_conn.cb_set, 0);
> + INIT_LIST_HEAD(&clp->cl_idhash);
> + INIT_LIST_HEAD(&clp->cl_strhash);
> + INIT_LIST_HEAD(&clp->cl_openowners);
> + INIT_LIST_HEAD(&clp->cl_delegations);
> + INIT_LIST_HEAD(&clp->cl_sessions);
> + INIT_LIST_HEAD(&clp->cl_lru);
> + clear_bit(0, &clp->cl_cb_slot_busy);
> + rpc_init_wait_queue(&clp->cl_cb_waitq, "Backchannel slot table");
> + copy_verf(clp, verf);
> + clp->cl_addr = ip_addr;
> + clp->cl_flavor = rqstp->rq_flavor;
> + copy_cred(&clp->cl_cred, &rqstp->rq_cred);
> + gen_confirm(clp);
> +
> + return clp;
> +}
> +
> static int check_name(struct xdr_netobj name)
> {
> if (name.len == 0)
> @@ -1285,17 +1304,13 @@ nfsd4_exchange_id(struct svc_rqst *rqstp,
>
> out_new:
> /* Normal case */
> - new = create_client(exid->clname, dname);
> + new = create_client(exid->clname, dname, rqstp, &verf);
> if (new == NULL) {
> status = nfserr_resource;
> goto out;
> }
>
> - copy_verf(new, &verf);
> - copy_cred(&new->cl_cred, &rqstp->rq_cred);
> - new->cl_addr = ip_addr;
> gen_clid(new);
> - gen_confirm(new);
> add_to_unconfirmed(new, strhashval);
> out_copy:
> exid->clientid.cl_boot = new->cl_clientid.cl_boot;
> @@ -1535,7 +1550,6 @@ __be32
> nfsd4_setclientid(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
> struct nfsd4_setclientid *setclid)
> {
> - struct sockaddr_in *sin = svc_addr_in(rqstp);
> struct xdr_netobj clname = {
> .len = setclid->se_namelen,
> .data = setclid->se_name,
> @@ -1544,7 +1558,6 @@ nfsd4_setclientid(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
> unsigned int strhashval;
> struct nfs4_client *conf, *unconf, *new;
> __be32 status;
> - char *princ;
> char dname[HEXDIR_LEN];
>
> if (!check_name(clname))
> @@ -1586,7 +1599,7 @@ nfsd4_setclientid(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
> */
> if (unconf)
> expire_client(unconf);
> - new = create_client(clname, dname);
> + new = create_client(clname, dname, rqstp, &clverifier);
> if (new == NULL)
> goto out;
> gen_clid(new);
> @@ -1603,7 +1616,7 @@ nfsd4_setclientid(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
> */
> expire_client(unconf);
> }
> - new = create_client(clname, dname);
> + new = create_client(clname, dname, rqstp, &clverifier);
> if (new == NULL)
> goto out;
> copy_clid(new, conf);
> @@ -1613,7 +1626,7 @@ nfsd4_setclientid(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
> * probable client reboot; state will be removed if
> * confirmed.
> */
> - new = create_client(clname, dname);
> + new = create_client(clname, dname, rqstp, &clverifier);
> if (new == NULL)
> goto out;
> gen_clid(new);
> @@ -1624,24 +1637,11 @@ nfsd4_setclientid(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
> * confirmed.
> */
> expire_client(unconf);
> - new = create_client(clname, dname);
> + new = create_client(clname, dname, rqstp, &clverifier);
> if (new == NULL)
> goto out;
> gen_clid(new);
> }
> - copy_verf(new, &clverifier);
> - new->cl_addr = sin->sin_addr.s_addr;
> - new->cl_flavor = rqstp->rq_flavor;
> - princ = svc_gss_principal(rqstp);
> - if (princ) {
> - new->cl_principal = kstrdup(princ, GFP_KERNEL);
> - if (new->cl_principal == NULL) {
> - free_client(new);
> - goto out;
> - }
> - }
> - copy_cred(&new->cl_cred, &rqstp->rq_cred);
> - gen_confirm(new);
> gen_callback(new, setclid);
> add_to_unconfirmed(new, strhashval);
> setclid->se_clientid.cl_boot = new->cl_clientid.cl_boot;
next prev parent reply other threads:[~2009-05-20 8:19 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-05-20 2:07 [RFC 0/10] nfsd41 server backchannel for 2.6.31 Labiaga, Ricardo
[not found] ` <273FE88A07F5D445824060902F70034405CEB64D-hX7t0kiaRRpT+ZUat5FNkAK/GNPrWCqfQQ4Iyu8u01E@public.gmane.org>
2009-05-20 3:00 ` [RFC 01/11] nfsd: cleanup nfs4.0 callback encode routines Ricardo Labiaga
2009-05-20 3:00 ` [RFC 02/11] nfsd: minorversion support for the back channel Ricardo Labiaga
2009-05-20 3:00 ` [RFC 03/11] nfsd41: sunrpc: svc_tcp_recv_record() Ricardo Labiaga
2009-05-20 3:00 ` [RFC 04/11] nfsd41: sunrpc: Added rpc server-side backchannel handling Ricardo Labiaga
2009-05-20 3:00 ` [RFC 05/11] nfsd41: callback infrastructure Ricardo Labiaga
2009-05-20 3:00 ` [RFC 06/11] nfsd41: Backchannel: Add sequence arguments to callback RPC arguments Ricardo Labiaga
2009-05-20 3:00 ` [RFC 07/11] nfsd41: Backchannel: Server backchannel RPC wait queue Ricardo Labiaga
2009-05-20 3:00 ` [RFC 08/11] nfsd41: Backchannel: Setup sequence information Ricardo Labiaga
2009-05-20 3:00 ` [RFC 09/11] nfsd41: cb_sequence callback Ricardo Labiaga
2009-05-20 3:00 ` [RFC 10/11] nfsd41: Backchannel: Implement cb_recall over NFSv4.1 Ricardo Labiaga
2009-05-20 3:00 ` [RFC 11/11] nfsd41: Refactor create_client() Ricardo Labiaga
2009-05-20 8:18 ` Benny Halevy [this message]
2009-05-20 18:27 ` Labiaga, Ricardo
2009-05-20 7:46 ` [RFC 10/11] nfsd41: Backchannel: Implement cb_recall over NFSv4.1 Benny Halevy
2009-05-20 18:17 ` Labiaga, Ricardo
2009-05-21 5:59 ` Benny Halevy
2009-05-21 6:54 ` Labiaga, Ricardo
2009-05-20 7:32 ` [RFC 06/11] nfsd41: Backchannel: Add sequence arguments to callback RPC arguments Benny Halevy
2009-05-20 18:05 ` Labiaga, Ricardo
2009-05-20 8:34 ` [RFC 04/11] nfsd41: sunrpc: Added rpc server-side backchannel handling Benny Halevy
2009-05-20 18:40 ` Labiaga, Ricardo
2009-05-20 3:04 ` [pnfs] [RFC 0/10] nfsd41 server backchannel for 2.6.31 Labiaga, Ricardo
-- strict thread matches above, loose matches on Subject: below --
2009-06-06 2:48 [RFC 0/10] nfsd41 server backchannel for 2.6.31 (try 3) Labiaga, Ricardo
2009-06-06 2:49 ` [RFC 01/11] nfsd41: Backchannel: cleanup nfs4.0 callback encode routines Ricardo Labiaga
2009-06-06 2:49 ` [RFC 02/11] nfsd41: Backchannel: minorversion support for the back channel Ricardo Labiaga
2009-06-06 2:49 ` [RFC 03/11] nfsd41: sunrpc: svc_tcp_recv_record() Ricardo Labiaga
2009-06-06 2:49 ` [RFC 04/11] nfsd41: sunrpc: Added rpc server-side backchannel handling Ricardo Labiaga
2009-06-06 2:50 ` [RFC 05/11] nfsd41: Backchannel: callback infrastructure Ricardo Labiaga
2009-06-06 2:50 ` [RFC 06/11] nfsd41: Backchannel: Add sequence arguments to callback RPC arguments Ricardo Labiaga
2009-06-06 2:50 ` [RFC 07/11] nfsd41: Backchannel: Server backchannel RPC wait queue Ricardo Labiaga
2009-06-06 2:50 ` [RFC 08/11] nfsd41: Backchannel: Setup sequence information Ricardo Labiaga
2009-06-06 2:50 ` [RFC 09/11] nfsd41: Backchannel: cb_sequence callback Ricardo Labiaga
2009-06-06 2:50 ` [RFC 10/11] nfsd41: Backchannel: Implement cb_recall over NFSv4.1 Ricardo Labiaga
2009-06-06 2:50 ` [RFC 11/11] nfsd41: Refactor create_client() Ricardo Labiaga
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4A13BCE2.1070303@panasas.com \
--to=bhalevy@panasas.com \
--cc=Ricardo.Labiaga@netapp.com \
--cc=andros@netapp.com \
--cc=bfields@fieldses.org \
--cc=linux-nfs@vger.kernel.org \
--cc=pnfs@linux-nfs.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox