Re: Boot time regression in 2.6.38 after initial wq merge

From: Tejun Heo
Date: Wed Feb 23 2011 - 04:40:00 EST


Hello,

On Tue, Feb 22, 2011 at 09:20:42PM -0800, Dmitry Torokhov wrote:
> On Tue, Feb 22, 2011 at 09:14:46PM +0100, pantherchen@xxxxxxxxxxx wrote:
> > On 02/22/2011 08:52 PM, Dmitry Torokhov wrote:
> > >Ewww... tty/ldisc...
> > >
> > >Does it help if you change drivers/input/serio/serio.c::serio_queue_event()
> > >from calling
> > >
> > > schedule_work(&serio_event_work);
> > >
> > >to call
> > >
> > > queue_work(system_long_wq,&serio_event_work);
> > >
> > >?
> >
> > Yes, that works: http://img.xrmb2.net/images/499337.png
> >
>
> Great!
>
> OK, so below is properly formatted patch. I am going to send it upstream
> unless somebody objects.

Ah, okay, thanks a lot for tracking this down, Dmitry. Didn't expect
flush_scheduled_work() to bite back this way. :-)

> Input: serio/gameport - use 'long' system workqueue
>
> From: Dmitry Torokhov <dmitry.torokhov@xxxxxxxxx>
>
> Commit 8ee294cd9def0004887da7f44b80563493b0a097 converted serio
> subsystem event handling from using a dedicated thread to using
> common workqueue. Unfortunately, this regressed our boot times,
> due to the fact that serio jobs take long time to execute. While
> the new concurrency managed workqueue code manages long-playing
> works just fine and schedules additional workers as needed, such
> works wreck havoc among remaining users of flush_scheduled_work().
>
> To solve this problem let's move serio/gameport works from system_wq
> to system_long_wq which nobody tries to flush.
>
> Reported-and-tested-by: Hernando Torque <pantherchen@xxxxxxxxxxx>
> Signed-off-by: Dmitry Torokhov <dtor@xxxxxxx>

Acked-by: Tejun Heo <tj@xxxxxxxxxx>

Most flush_scheduled_work() users are already gone and once all of
them are gone, system_long_wq can be removed without causing any
difference.

Thank you.

--
tejun
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/