All of lore.kernel.org
 help / color / mirror / Atom feed
From: "J. Bruce Fields" <bfields@fieldses.org>
To: Trond Myklebust <trond.myklebust@fys.uio.no>
Cc: linux-fsdevel@vger.kernel.org, nfs@lists.sourceforge.net,
	Marc Eshel <eshel@almaden.ibm.com>
Subject: Re: [PATCH 9/14] lockd: handle fl_notify callbacks
Date: Sat, 3 Feb 2007 21:10:44 -0500	[thread overview]
Message-ID: <20070204021044.GK7588@fieldses.org> (raw)
In-Reply-To: <1170549605.5749.5.camel@lade.trondhjem.org>

On Sat, Feb 03, 2007 at 04:40:05PM -0800, Trond Myklebust wrote:
> On Sat, 2007-02-03 at 00:34 -0500, J. Bruce Fields wrote:
> >  nlmsvc_notify_blocked(struct file_lock *fl, struct file_lock *conf, int result)
> >  {
> >  	struct nlm_block	*block;
> > +	int rc = -ENOENT;
> >  
> >  	dprintk("lockd: nlmsvc_notify_blocked lock %p conf %p result %d\n",
> >  							fl, conf, result);
> > +	lock_kernel();
> >  	list_for_each_entry(block, &nlm_blocked, b_list) {
> >  		if (nlm_compare_locks(&block->b_call->a_args.lock.fl, fl)) {
> > +			dprintk("lockd: nlmsvc_notify_blocked block %p flags %d\n",
> > +							block, block->b_flags);
> > +			if (block->b_flags & B_QUEUED) {
> > +				if (block->b_flags & B_TOO_LATE) {
> > +					rc = -ENOLCK;
> > +					break;
> > +				}
> > +				nlmsvc_update_deferred_block(block, conf, result);
> 
> but nlmsvc_update_deferred_block() can sleep!

Yep, you're right.  Fortunately, the only reason it sleeps is a single
allocation that's probably easy enough to do elsewhere, which I believe
would fix this:

> How are you protecting against races with notification? Also, how are
> you guaranteeing that the block queue won't change underneath you when
> you lose the BKL.

--b.

-------------------------------------------------------------------------
Using Tomcat but need to do more? Need to support web services, security?
Get stuff done quickly with pre-integrated technology to make your job easier.
Download IBM WebSphere Application Server v.1.0.1 based on Apache Geronimo
http://sel.as-us.falkag.net/sel?cmd=lnk&kid=120709&bid=263057&dat=121642
_______________________________________________
NFS maillist  -  NFS@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/nfs

  reply	other threads:[~2007-02-04  2:10 UTC|newest]

Thread overview: 43+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <11704808501171-git-send-email->
     [not found] ` <11704808502512-git-send-email->
     [not found]   ` <11704808513862-git-send-email->
     [not found]     ` <1170480851972-git-send-email->
     [not found]       ` <11704808513070-git-send-email->
     [not found]         ` <117048085185-git-send-email->
     [not found]           ` <11704808513263-git-send-email->
     [not found]             ` <11704808513185-git-send-email->
     [not found]               ` <11704808511238-git-send-email->
     [not found]                 ` <11704808513085-git-send-email->
     [not found]                   ` <11704808521765-git-send-email->
     [not found]                     ` <11704808523686-git-send-email->
2007-02-03  5:33 ` [PATCH 1/14] locks: always unlock on close J. Bruce Fields
2007-02-03  5:33   ` J. Bruce Fields
2007-02-03  5:33   ` J. Bruce Fields
2007-02-03  5:33   ` [PATCH 2/14] locks: factor out generic/filesystem switch from test_lock J. Bruce Fields
2007-02-03  5:33     ` J. Bruce Fields
2007-02-03  5:33     ` J. Bruce Fields
2007-02-03  8:50     ` Christoph Hellwig
2007-02-04  1:48       ` J. Bruce Fields
2007-02-04  8:41         ` Christoph Hellwig
2007-02-04  0:32     ` [NFS] " Trond Myklebust
2007-02-04  1:52       ` J. Bruce Fields
2007-02-03  5:33   ` [PATCH 3/14] locks: factor out generic/filesystem switch from setlock code J. Bruce Fields
2007-02-03  5:33     ` J. Bruce Fields
2007-02-03  5:33     ` J. Bruce Fields
2007-02-03  8:51     ` Christoph Hellwig
2007-02-03  5:16       ` Brad Boyer
2007-02-04  2:27         ` J. Bruce Fields
2007-02-04  8:37         ` Christoph Hellwig
2007-02-03 21:27           ` Brad Boyer
2007-02-04  1:58       ` J. Bruce Fields
2007-02-03  5:34   ` [PATCH 4/14] locks: add locking function that returns conflicting lock J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  8:54     ` Christoph Hellwig
2007-02-04  2:02       ` J. Bruce Fields
2007-02-03  5:34   ` [PATCH 5/14] locks: add fl_notify arguments for asynchronous lock return J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34   ` [PATCH 6/14] locks: add lock cancel command J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34   ` [PATCH 7/14] nfsd4: Convert NFSv4 to new lock interface J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34   ` [PATCH 8/14] lockd: save lock state on deferral J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34   ` [PATCH 9/14] lockd: handle fl_notify callbacks J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-04  0:40     ` [NFS] " Trond Myklebust
2007-02-04  2:10       ` J. Bruce Fields [this message]
2007-02-03  5:34   ` [PATCH 10/14] lockd: pass cookie in nlmsvc_testlock J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34   ` [PATCH 11/14] lockd: handle test_lock deferrals J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34   ` [PATCH 12/14] lockd: always preallocate block in nlmsvc_lock() J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34   ` [PATCH 13/14] lockd: add code to handle deferred lock requests J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34   ` [PATCH 14/14] gfs2: nfs lock support for gfs2 J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields
2007-02-03  5:34     ` J. Bruce Fields

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=20070204021044.GK7588@fieldses.org \
    --to=bfields@fieldses.org \
    --cc=eshel@almaden.ibm.com \
    --cc=linux-fsdevel@vger.kernel.org \
    --cc=nfs@lists.sourceforge.net \
    --cc=trond.myklebust@fys.uio.no \
    /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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.