block: move queue run on unplug to kblockd
authorJens Axboe <jaxboe@fusionio.com>
Tue, 12 Apr 2011 12:58:51 +0000 (14:58 +0200)
committerJens Axboe <jaxboe@fusionio.com>
Tue, 12 Apr 2011 12:58:51 +0000 (14:58 +0200)
There are worries that we are now consuming a lot more stack in
some cases, since we potentially call into IO dispatch from
schedule() or io_schedule(). We can reduce this problem by moving
the running of the queue to kblockd, like the old plugging scheme
did as well.

This may or may not be a good idea from a performance perspective,
depending on how many tasks have queue plugs running at the same
time. For even the slightly contended case, doing just a single
queue run from kblockd instead of multiple runs directly from the
unpluggers will be faster.

Signed-off-by: Jens Axboe <jaxboe@fusionio.com>

No differences found