public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Tejun Heo <tj@kernel.org>
To: Alan Stern <stern@rowland.harvard.edu>
Cc: Kernel development list <linux-kernel@vger.kernel.org>
Subject: Re: Warn people about flush_scheduled_work()
Date: Tue, 15 Dec 2009 08:25:14 +0900	[thread overview]
Message-ID: <4B26C95A.8000708@kernel.org> (raw)
In-Reply-To: <Pine.LNX.4.44L0.0912141809390.2690-100000@iolanthe.rowland.org>

Hello,

On 12/15/2009 08:14 AM, Alan Stern wrote:
>> I think both problems can be detected by lockdep, right?  So, they
>> aren't that difficult to detect.
> 
> Maybe they can, now.  It used to be they couldn't.

I think they can now.  Workqueue workers acquire pseudo lock known to
lockdep around execution of a work function and flush_workqueue()
grabs and releases the pseudo lock too, so both are known to lockdep.

> However, lockdep doesn't help much -- it tells you the cause of the
> deadlock but it doesn't prevent the deadlock from occurring.  The
> programmer has to do this, by avoiding flush_scheduled_work().  I guess 
> that could be added to the comment.

As lockdep computes deadlocks from all possible combinations, it
usually detects deadlocks pretty quickly during devel cycle, so it
doesn't prevent them from happening but still helps a lot.

>> Yeah, recommending more work-specific constructs definitely would be
>> better.  It's bad that we can't recommend the use of flush_work() as
>> it doesn't do cross-cpu flushing.  Maybe that needs explanation too.
> 
> I'll do my comments, and you can do yours.  :-)

Fair enough.  :-)

> Should these changes go through Andrew Morton?  Or can you take them?

I already have a tree set up for workqueue changes, so I guess I can
take them.

Thanks.

-- 
tejun

  reply	other threads:[~2009-12-14 23:25 UTC|newest]

Thread overview: 11+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-12-14 21:33 Warn people about flush_scheduled_work() Alan Stern
2009-12-14 21:42 ` Oliver Neukum
2009-12-14 22:02   ` Alan Stern
2009-12-14 22:12     ` Oliver Neukum
2009-12-14 23:04       ` Alan Stern
2009-12-14 22:38 ` Tejun Heo
2009-12-14 23:14   ` Alan Stern
2009-12-14 23:25     ` Tejun Heo [this message]
2009-12-16 15:52   ` [PATCH] Warn " Alan Stern
2009-12-21  8:26     ` Tejun Heo
2010-02-12  8:47       ` Tejun Heo

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=4B26C95A.8000708@kernel.org \
    --to=tj@kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=stern@rowland.harvard.edu \
    /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