2005-11-10 14:23:54

by Tejun Heo

[permalink] [raw]
Subject: [PATCH] blk: elv_latter/former_request update

With generic dispatch queue update, implicit former/latter request
handling using rq->queuelist.prev/next doesn't work as expected
anymore. Also, the only iosched dependent on this feature was
noop-iosched and it has been reimplemented to have its own
latter/former methods. This patch removes implicit former/latter
handling.

Signed-off-by: Tejun Heo <[email protected]>

diff --git a/block/elevator.c b/block/elevator.c
--- a/block/elevator.c
+++ b/block/elevator.c
@@ -540,33 +540,19 @@ int elv_queue_empty(request_queue_t *q)

struct request *elv_latter_request(request_queue_t *q, struct request *rq)
{
- struct list_head *next;
-
elevator_t *e = q->elevator;

if (e->ops->elevator_latter_req_fn)
return e->ops->elevator_latter_req_fn(q, rq);
-
- next = rq->queuelist.next;
- if (next != &q->queue_head && next != &rq->queuelist)
- return list_entry_rq(next);
-
return NULL;
}

struct request *elv_former_request(request_queue_t *q, struct request *rq)
{
- struct list_head *prev;
-
elevator_t *e = q->elevator;

if (e->ops->elevator_former_req_fn)
return e->ops->elevator_former_req_fn(q, rq);
-
- prev = rq->queuelist.prev;
- if (prev != &q->queue_head && prev != &rq->queuelist)
- return list_entry_rq(prev);
-
return NULL;
}


2005-11-10 17:20:40

by Jens Axboe

[permalink] [raw]
Subject: Re: [PATCH] blk: elv_latter/former_request update

On Thu, Nov 10 2005, Tejun Heo wrote:
> With generic dispatch queue update, implicit former/latter request
> handling using rq->queuelist.prev/next doesn't work as expected
> anymore. Also, the only iosched dependent on this feature was
> noop-iosched and it has been reimplemented to have its own
> latter/former methods. This patch removes implicit former/latter
> handling.

Thanks, applied.

--
Jens Axboe