Skip to content

Commit

Permalink
Block: use round_jiffies_up()
Browse files Browse the repository at this point in the history
This patch (as1159b) changes the timeout routines in the block core to
use round_jiffies_up().  There's no point in rounding the timer
deadline down, since if it expires too early we will have to restart
it.

The patch also removes some unnecessary tests when a request is
removed from the queue's timer list.

Signed-off-by: Alan Stern <[email protected]>
Signed-off-by: Jens Axboe <[email protected]>
  • Loading branch information
AlanStern authored and Jens Axboe committed Nov 6, 2008
1 parent 9c133c4 commit 7838c15
Showing 1 changed file with 3 additions and 17 deletions.
20 changes: 3 additions & 17 deletions block/blk-timeout.c
Original file line number Diff line number Diff line change
Expand Up @@ -75,14 +75,7 @@ void blk_delete_timer(struct request *req)
{
struct request_queue *q = req->q;

/*
* Nothing to detach
*/
if (!q->rq_timed_out_fn || !req->deadline)
return;

list_del_init(&req->timeout_list);

if (list_empty(&q->timeout_list))
del_timer(&q->timeout);
}
Expand Down Expand Up @@ -142,7 +135,7 @@ void blk_rq_timed_out_timer(unsigned long data)
}

if (next_set && !list_empty(&q->timeout_list))
mod_timer(&q->timeout, round_jiffies(next));
mod_timer(&q->timeout, round_jiffies_up(next));

spin_unlock_irqrestore(q->queue_lock, flags);
}
Expand Down Expand Up @@ -198,17 +191,10 @@ void blk_add_timer(struct request *req)

/*
* If the timer isn't already pending or this timeout is earlier
* than an existing one, modify the timer. Round to next nearest
* than an existing one, modify the timer. Round up to next nearest
* second.
*/
expiry = round_jiffies(req->deadline);

/*
* We use ->deadline == 0 to detect whether a timer was added or
* not, so just increase to next jiffy for that specific case
*/
if (unlikely(!req->deadline))
req->deadline = 1;
expiry = round_jiffies_up(req->deadline);

if (!timer_pending(&q->timeout) ||
time_before(expiry, q->timeout.expires))
Expand Down

0 comments on commit 7838c15

Please sign in to comment.