From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1161298AbWG1VKJ (ORCPT ); Fri, 28 Jul 2006 17:10:09 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1161305AbWG1VKI (ORCPT ); Fri, 28 Jul 2006 17:10:08 -0400 Received: from mail.fieldses.org ([66.93.2.214]:4317 "EHLO pickle.fieldses.org") by vger.kernel.org with ESMTP id S1161298AbWG1VKH (ORCPT ); Fri, 28 Jul 2006 17:10:07 -0400 Date: Fri, 28 Jul 2006 17:10:00 -0400 To: NeilBrown Cc: Andrew Morton , nfs@lists.sourceforge.net, linux-kernel@vger.kernel.org Subject: Re: [PATCH 000 of 4] knfsd: Introduction Message-ID: <20060728211000.GA19563@fieldses.org> References: <20060728150606.29533.patches@notabene> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20060728150606.29533.patches@notabene> User-Agent: Mutt/1.5.12-2006-07-14 From: "J. Bruce Fields" Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Jul 28, 2006 at 03:09:40PM +1000, NeilBrown wrote: > Following are 4 patches for knfsd in 2.6-mm-latest. They address some > issues found by Bruce Fields greatly appreciated patch review. Thanks Bruce. > They (like the patches they build on) are *not* 2.6.18 material. By the way, the one thing that looked to me like a real bug was the failure to do a lockd_down() when the user deletes a socket (comments resent below), which these patches don't seem to deal with. Of course, it's entirely possible I just didn't understand something.... --b. On Tue, Jul 25, 2006 at 11:55:08AM +1000, NeilBrown wrote: > + err = nfsd_create_serv(); > + if (!err) { > + int proto = 0; > + err = svc_addsock(nfsd_serv, fd, buf, &proto); > + /* Decrease the count, but don't shutdown the > + * the service > + */ > + if (err >= 0) > + lockd_up(proto); > + nfsd_serv->sv_nrthreads--; .... > @@ -211,8 +211,6 @@ static inline int nfsd_create_serv(void) > nfsd_last_thread); > if (nfsd_serv == NULL) > err = -ENOMEM; > - else > - nfsd_serv->sv_nrthreads++; I don't understand these sv_nrthreads changes. > @@ -449,18 +450,23 @@ int one_sock_name(char *buf, struct svc_ > } > > int > -svc_sock_names(char *buf, struct svc_serv *serv) > +svc_sock_names(char *buf, struct svc_serv *serv, char *toclose) > { > - struct svc_sock *svsk; > + struct svc_sock *svsk, *closesk = NULL; > int len = 0; > > if (!serv) return 0; > spin_lock(&serv->sv_lock); > list_for_each_entry(svsk, &serv->sv_permsocks, sk_list) { > int onelen = one_sock_name(buf+len, svsk); > - len += onelen; > + if (toclose && strcmp(toclose, buf+len) == 0) > + closesk = svsk; > + else > + len += onelen; > } > spin_unlock(&serv->sv_lock); > + if (closesk) > + svc_delete_socket(closesk); Am I missing something, or do we end up missing a lockd_down() in this case? (Because nfsd_last_thread() isn't going to be calling lockd_down() for this thread now that we've removed it from sv_permsocks). --b.