提交 1d64b655 编写于 作者: D Dmitry Torokhov

Input: serio/gameport - use 'long' system workqueue

Commit 8ee294cd 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: NHernando Torque <pantherchen@versanet.de>
Acked-by: NTejun Heo <tj@kernel.org>
Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
上级 9bb794ae
...@@ -360,7 +360,7 @@ static int gameport_queue_event(void *object, struct module *owner, ...@@ -360,7 +360,7 @@ static int gameport_queue_event(void *object, struct module *owner,
event->owner = owner; event->owner = owner;
list_add_tail(&event->node, &gameport_event_list); list_add_tail(&event->node, &gameport_event_list);
schedule_work(&gameport_event_work); queue_work(system_long_wq, &gameport_event_work);
out: out:
spin_unlock_irqrestore(&gameport_event_lock, flags); spin_unlock_irqrestore(&gameport_event_lock, flags);
......
...@@ -299,7 +299,7 @@ static int serio_queue_event(void *object, struct module *owner, ...@@ -299,7 +299,7 @@ static int serio_queue_event(void *object, struct module *owner,
event->owner = owner; event->owner = owner;
list_add_tail(&event->node, &serio_event_list); list_add_tail(&event->node, &serio_event_list);
schedule_work(&serio_event_work); queue_work(system_long_wq, &serio_event_work);
out: out:
spin_unlock_irqrestore(&serio_event_lock, flags); spin_unlock_irqrestore(&serio_event_lock, flags);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册