|
@@ -122,10 +122,8 @@ void blk_rq_timed_out_timer(unsigned long data)
|
|
if (blk_mark_rq_complete(rq))
|
|
if (blk_mark_rq_complete(rq))
|
|
continue;
|
|
continue;
|
|
blk_rq_timed_out(rq);
|
|
blk_rq_timed_out(rq);
|
|
- } else {
|
|
|
|
- if (!next || time_after(next, rq->deadline))
|
|
|
|
- next = rq->deadline;
|
|
|
|
- }
|
|
|
|
|
|
+ } else if (!next || time_after(next, rq->deadline))
|
|
|
|
+ next = rq->deadline;
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
/*
|
|
@@ -176,16 +174,14 @@ void blk_add_timer(struct request *req)
|
|
BUG_ON(!list_empty(&req->timeout_list));
|
|
BUG_ON(!list_empty(&req->timeout_list));
|
|
BUG_ON(test_bit(REQ_ATOM_COMPLETE, &req->atomic_flags));
|
|
BUG_ON(test_bit(REQ_ATOM_COMPLETE, &req->atomic_flags));
|
|
|
|
|
|
- if (req->timeout)
|
|
|
|
- req->deadline = jiffies + req->timeout;
|
|
|
|
- else {
|
|
|
|
- req->deadline = jiffies + q->rq_timeout;
|
|
|
|
- /*
|
|
|
|
- * Some LLDs, like scsi, peek at the timeout to prevent
|
|
|
|
- * a command from being retried forever.
|
|
|
|
- */
|
|
|
|
|
|
+ /*
|
|
|
|
+ * Some LLDs, like scsi, peek at the timeout to prevent a
|
|
|
|
+ * command from being retried forever.
|
|
|
|
+ */
|
|
|
|
+ if (!req->timeout)
|
|
req->timeout = q->rq_timeout;
|
|
req->timeout = q->rq_timeout;
|
|
- }
|
|
|
|
|
|
+
|
|
|
|
+ req->deadline = jiffies + req->timeout;
|
|
list_add_tail(&req->timeout_list, &q->timeout_list);
|
|
list_add_tail(&req->timeout_list, &q->timeout_list);
|
|
|
|
|
|
/*
|
|
/*
|