提交 88b996cd 编写于 作者: C Christoph Hellwig 提交者: Jens Axboe

block: cleanup the block plug helper functions

It's a bit of a mess currently. task->plug is being cleared
and reset in __blk_finish_plug(), and blk_finish_plug() is
testing for a NULL plug which cannot happen even from schedule()
anymore since it uses blk_needs_flush_plug() to determine
whether to call into this function at all.

So get rid of some of the cruft.
Signed-off-by: NJens Axboe <jaxboe@fusionio.com>
上级 80656b67
...@@ -2671,7 +2671,7 @@ static void queue_unplugged(struct request_queue *q, unsigned int depth) ...@@ -2671,7 +2671,7 @@ static void queue_unplugged(struct request_queue *q, unsigned int depth)
q->unplugged_fn(q); q->unplugged_fn(q);
} }
static void flush_plug_list(struct blk_plug *plug) void blk_flush_plug_list(struct blk_plug *plug)
{ {
struct request_queue *q; struct request_queue *q;
unsigned long flags; unsigned long flags;
...@@ -2733,28 +2733,16 @@ static void flush_plug_list(struct blk_plug *plug) ...@@ -2733,28 +2733,16 @@ static void flush_plug_list(struct blk_plug *plug)
local_irq_restore(flags); local_irq_restore(flags);
} }
EXPORT_SYMBOL(blk_flush_plug_list);
static void __blk_finish_plug(struct task_struct *tsk, struct blk_plug *plug)
{
flush_plug_list(plug);
if (plug == tsk->plug)
tsk->plug = NULL;
}
void blk_finish_plug(struct blk_plug *plug) void blk_finish_plug(struct blk_plug *plug)
{ {
if (plug) blk_flush_plug_list(plug);
__blk_finish_plug(current, plug);
}
EXPORT_SYMBOL(blk_finish_plug);
void __blk_flush_plug(struct task_struct *tsk, struct blk_plug *plug) if (plug == current->plug)
{ current->plug = NULL;
__blk_finish_plug(tsk, plug);
tsk->plug = plug;
} }
EXPORT_SYMBOL(__blk_flush_plug); EXPORT_SYMBOL(blk_finish_plug);
int __init blk_dev_init(void) int __init blk_dev_init(void)
{ {
......
...@@ -865,14 +865,14 @@ struct blk_plug { ...@@ -865,14 +865,14 @@ struct blk_plug {
extern void blk_start_plug(struct blk_plug *); extern void blk_start_plug(struct blk_plug *);
extern void blk_finish_plug(struct blk_plug *); extern void blk_finish_plug(struct blk_plug *);
extern void __blk_flush_plug(struct task_struct *, struct blk_plug *); extern void blk_flush_plug_list(struct blk_plug *);
static inline void blk_flush_plug(struct task_struct *tsk) static inline void blk_flush_plug(struct task_struct *tsk)
{ {
struct blk_plug *plug = tsk->plug; struct blk_plug *plug = tsk->plug;
if (unlikely(plug)) if (plug)
__blk_flush_plug(tsk, plug); blk_flush_plug_list(plug);
} }
static inline bool blk_needs_flush_plug(struct task_struct *tsk) static inline bool blk_needs_flush_plug(struct task_struct *tsk)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册