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
next prev parent 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