diff options
author | Jens Axboe <axboe@fb.com> | 2014-05-30 15:41:39 -0600 |
---|---|---|
committer | Jens Axboe <axboe@fb.com> | 2014-05-30 15:41:39 -0600 |
commit | c7bca4183f73f9d013ea8ae572528b48b5e1ee42 (patch) | |
tree | 31ec2e1c9250ca2af53a86c3c120cc61bd043c39 | |
parent | ee3c5db0896d85187b5f31b5482ed8fd308d31ee (diff) | |
download | op-kernel-dev-c7bca4183f73f9d013ea8ae572528b48b5e1ee42.zip op-kernel-dev-c7bca4183f73f9d013ea8ae572528b48b5e1ee42.tar.gz |
block: ensure that the timer is always added
Commit f793aa537866 relaxed the timer addition a little too much.
If the timer isn't pending, we always need to add it.
Signed-off-by: Jens Axboe <axboe@fb.com>
-rw-r--r-- | block/blk-timeout.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/block/blk-timeout.c b/block/blk-timeout.c index 43e8b51..95a0959 100644 --- a/block/blk-timeout.c +++ b/block/blk-timeout.c @@ -224,7 +224,7 @@ void blk_add_timer(struct request *req) * modifying the timer because expires for value X * will be X + something. */ - if (diff >= HZ / 2) + if (!timer_pending(&q->timeout) || (diff >= HZ / 2)) mod_timer(&q->timeout, expiry); } |