aboutsummaryrefslogtreecommitdiffstats
path: root/block/blk-timeout.c
diff options
context:
space:
mode:
authorHannes Reinecke <hare@suse.de>2013-01-30 04:26:17 -0500
committerMartin Schwidefsky <schwidefsky@de.ibm.com>2013-07-01 11:31:23 -0400
commit80bd7181b036c7b4118eb19cfff3b555889596e6 (patch)
tree455e4df7bef9ebc9cfbddb1a5936fa1f1cfeeee5 /block/blk-timeout.c
parentd1ffc1f8660e749a2683f19ee7cfdd837568b37a (diff)
block: check for timeout function in blk_rq_timed_out()
rq_timed_out_fn might have been unset while the request was in flight, so we need to check for it in blk_rq_timed_out(). Acked-by: Jens Axboe <axboe@kernel.dk> Signed-off-by: Hannes Reinecke <hare@suse.de> Signed-off-by: Stefan Weinhuber <wein@de.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'block/blk-timeout.c')
-rw-r--r--block/blk-timeout.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/block/blk-timeout.c b/block/blk-timeout.c
index 6e4744cbfb56..65f103563969 100644
--- a/block/blk-timeout.c
+++ b/block/blk-timeout.c
@@ -82,9 +82,10 @@ void blk_delete_timer(struct request *req)
82static void blk_rq_timed_out(struct request *req) 82static void blk_rq_timed_out(struct request *req)
83{ 83{
84 struct request_queue *q = req->q; 84 struct request_queue *q = req->q;
85 enum blk_eh_timer_return ret; 85 enum blk_eh_timer_return ret = BLK_EH_RESET_TIMER;
86 86
87 ret = q->rq_timed_out_fn(req); 87 if (q->rq_timed_out_fn)
88 ret = q->rq_timed_out_fn(req);
88 switch (ret) { 89 switch (ret) {
89 case BLK_EH_HANDLED: 90 case BLK_EH_HANDLED:
90 __blk_complete_request(req); 91 __blk_complete_request(req);