From: "J. Bruce Fields" <bfields@fieldses.org>
To: Kosuke Tatsukawa <tatsu@ab.jp.nec.com>
Cc: Neil Brown <nfbrown@novell.com>,
Trond Myklebust <trond.myklebust@primarydata.com>,
Anna Schumaker <anna.schumaker@netapp.com>,
Jeff Layton <jlayton@poochiereds.net>,
"David S. Miller" <davem@davemloft.net>,
"linux-nfs@vger.kernel.org" <linux-nfs@vger.kernel.org>,
"netdev@vger.kernel.org" <netdev@vger.kernel.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH v2] sunrpc: fix waitqueue_active without memory barrier in sunrpc
Date: Mon, 12 Oct 2015 16:26:43 -0400 [thread overview]
Message-ID: <20151012202643.GM28755@fieldses.org> (raw)
In-Reply-To: <17EC94B0A072C34B8DCF0D30AD16044A02877311@BPXM09GP.gisp.nec.co.jp>
On Mon, Oct 12, 2015 at 10:41:06AM +0000, Kosuke Tatsukawa wrote:
> J. Bruce Fields wrote:
> > On Fri, Oct 09, 2015 at 06:29:44AM +0000, Kosuke Tatsukawa wrote:
> >> Neil Brown wrote:
> >> > Kosuke Tatsukawa <tatsu@ab.jp.nec.com> writes:
> >> >
> >> >> There are several places in net/sunrpc/svcsock.c which calls
> >> >> waitqueue_active() without calling a memory barrier. Add a memory
> >> >> barrier just as in wq_has_sleeper().
> >> >>
> >> >> I found this issue when I was looking through the linux source code
> >> >> for places calling waitqueue_active() before wake_up*(), but without
> >> >> preceding memory barriers, after sending a patch to fix a similar
> >> >> issue in drivers/tty/n_tty.c (Details about the original issue can be
> >> >> found here: https://lkml.org/lkml/2015/9/28/849).
> >> >
> >> > hi,
> >> > this feels like the wrong approach to the problem. It requires extra
> >> > 'smb_mb's to be spread around which are hard to understand as easy to
> >> > forget.
> >> >
> >> > A quick look seems to suggest that (nearly) every waitqueue_active()
> >> > will need an smb_mb. Could we just put the smb_mb() inside
> >> > waitqueue_active()??
> >> <snip>
> >>
> >> There are around 200 occurrences of waitqueue_active() in the kernel
> >> source, and most of the places which use it before wake_up are either
> >> protected by some spin lock, or already has a memory barrier or some
> >> kind of atomic operation before it.
> >>
> >> Simply adding smp_mb() to waitqueue_active() would incur extra cost in
> >> many cases and won't be a good idea.
> >>
> >> Another way to solve this problem is to remove the waitqueue_active(),
> >> making the code look like this;
> >> if (wq)
> >> wake_up_interruptible(wq);
> >> This also fixes the problem because the spinlock in the wake_up*() acts
> >> as a memory barrier and prevents the code from being reordered by the
> >> CPU (and it also makes the resulting code is much simpler).
> >
> > I might not care which we did, except I don't have the means to test
> > this quickly, and I guess this is some of our most frequently called
> > code.
> >
> > I suppose your patch is the most conservative approach, as the
> > alternative is a spinlock/unlock in wake_up_interruptible, which I
> > assume is necessarily more expensive than an smp_mb().
> >
> > As far as I can tell it's been this way since forever. (Well, since a
> > 2002 patch "NFSD: TCP: rationalise locking in RPC server routines" which
> > removed some spinlocks from the data_ready routines.)
> >
> > I don't understand what the actual race is yet (which code exactly is
> > missing the wakeup in this case? nfsd threads seem to instead get
> > woken up by the wake_up_process() in svc_xprt_do_enqueue().)
>
> Thank you for the reply. I tried looking into this.
>
> The callbacks in net/sunrpc/svcsock.c are set up in svc_tcp_init() and
> svc_udp_init(), which are both called from svc_setup_socket().
> svc_setup_socket() is called (indirectly) from lockd, nfsd, and nfsv4
> callback port related code.
>
> Maybe I'm wrong, but there might not be any kernel code that is using
> the socket's wait queue in this case.
As Trond points out there are probably waiters internal to the
networking code.
--b.
next prev parent reply other threads:[~2015-10-12 20:26 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-10-09 1:44 [PATCH v2] sunrpc: fix waitqueue_active without memory barrier in sunrpc Kosuke Tatsukawa
2015-10-09 5:56 ` Neil Brown
[not found] ` <87h9m04mbt.fsf-wvvUuzkyo1HefUI2i7LXDhCRmIWqnp/j@public.gmane.org>
2015-10-09 6:29 ` Kosuke Tatsukawa
2015-10-09 21:18 ` J. Bruce Fields
2015-10-09 21:21 ` Trond Myklebust
[not found] ` <20151009211819.GE8188-uC3wQj2KruNg9hUCZPvPmw@public.gmane.org>
2015-10-12 10:41 ` Kosuke Tatsukawa
2015-10-12 20:26 ` J. Bruce Fields [this message]
2015-10-14 3:57 ` Kosuke Tatsukawa
[not found] ` <17EC94B0A072C34B8DCF0D30AD16044A02877996-9lrffkYxhwTt6d3pZDjeaEtBU8KWyXPq@public.gmane.org>
2015-10-14 16:00 ` J. Bruce Fields
2015-10-15 0:09 ` Kosuke Tatsukawa
[not found] ` <17EC94B0A072C34B8DCF0D30AD16044A02877D53-9lrffkYxhwTt6d3pZDjeaEtBU8KWyXPq@public.gmane.org>
2015-10-15 11:44 ` Kosuke Tatsukawa
2015-10-15 20:57 ` J. Bruce Fields
2015-10-16 0:49 ` Neil Brown
[not found] ` <20151015205742.GB20155-uC3wQj2KruNg9hUCZPvPmw@public.gmane.org>
2015-10-16 1:46 ` Kosuke Tatsukawa
[not found] ` <17EC94B0A072C34B8DCF0D30AD16044A0287864B-9lrffkYxhwTt6d3pZDjeaEtBU8KWyXPq@public.gmane.org>
2015-10-16 2:28 ` Kosuke Tatsukawa
2015-10-22 16:31 ` J. Bruce Fields
[not found] ` <20151022163133.GB5205-uC3wQj2KruNg9hUCZPvPmw@public.gmane.org>
2015-10-23 4:14 ` Kosuke Tatsukawa
[not found] ` <17EC94B0A072C34B8DCF0D30AD16044A0287A7C2-9lrffkYxhwTt6d3pZDjeaEtBU8KWyXPq@public.gmane.org>
2015-10-23 20:49 ` J. Bruce Fields
[not found] ` <20151023204945.GD16137-uC3wQj2KruNg9hUCZPvPmw@public.gmane.org>
2015-10-24 1:19 ` Kosuke Tatsukawa
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=20151012202643.GM28755@fieldses.org \
--to=bfields@fieldses.org \
--cc=anna.schumaker@netapp.com \
--cc=davem@davemloft.net \
--cc=jlayton@poochiereds.net \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-nfs@vger.kernel.org \
--cc=netdev@vger.kernel.org \
--cc=nfbrown@novell.com \
--cc=tatsu@ab.jp.nec.com \
--cc=trond.myklebust@primarydata.com \
/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;
as well as URLs for NNTP newsgroup(s).