[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20120213173027.GC12117@google.com>
Date: Mon, 13 Feb 2012 09:30:27 -0800
From: Tejun Heo <tj@...nel.org>
To: Alan Stern <stern@...land.harvard.edu>
Cc: Jens Axboe <axboe@...nel.dk>, "Rafael J. Wysocki" <rjw@...k.pl>,
Linux-pm mailing list <linux-pm@...r.kernel.org>,
Kernel development list <linux-kernel@...r.kernel.org>
Subject: Re: Bug in disk event polling
Hello, Alan.
On Sun, Feb 12, 2012 at 12:48:22PM -0500, Alan Stern wrote:
> > I think it would be better to use wq for most kthreads. A lot of them
> > aren't strictly correct in the way they deal with
> > kthread_should_stop() and freezing. kthread in general simply seems
> > way too difficult to use correctly.
>
> Maybe so, but getting rid of it at this point would be a big change.
Ooh, yeah, if we do it, it would be a gradual transition.
> Also, kthreads were originally considered more suitable for tasks that
> would need to run for a long time; is this no longer true?
wq no longer has problem w/ long running work items. The only
limiting parameter is max_active, which is primarily there to protect
against berserk cases.
> > > kthread_run() can be adjusted on a case-by-case basis, by inserting
> > > calls to set_freezable() and try_to_freeze() at the appropriate places.
> > > But what about async_schedule()?
> >
> > Given the stuff async is used for, maybe just make all async execution
> > freezable?
>
> That probably won't work. What if a driver relies on async thread
> execution to carry out its I/O?
>
> As another example, sd_probe() calls async_schedule(sd_probe_async,...)
> to handle the long-running parts of probing a SCSI disk. In turn,
> sd_remove() calls async_synchronize_full() to insure that probing is
> over before the device is unbound from sd.
>
> What happens if a hot-unpluggable disk drive is unplugged while the
> system is asleep? It's entirely possible that the bus subsystem's
> resume routine would see the device was gone and would try to
> unregister it. Then sd_remove would wait for the async thread
> to finish, which would never happen because the thread would be frozen
> and wouldn't be thawed until all the resume routines had finished.
>
> In this case, the proper solution is to have the SCSI prepare method
> call async_synchronize_full(). Other cases will require other
> solutions.
Hmmm.... I don't know then. :)
Thanks.
--
tejun
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists