提交 3beb2077 编写于 作者: T Tejun Heo 提交者: Jens Axboe

[BLOCK] elevator: 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: NTejun Heo <htejun@gmail.com>
Signed-off-by: NJens Axboe <axboe@suse.de>
上级 5a7c47ee
...@@ -541,33 +541,19 @@ int elv_queue_empty(request_queue_t *q) ...@@ -541,33 +541,19 @@ int elv_queue_empty(request_queue_t *q)
struct request *elv_latter_request(request_queue_t *q, struct request *rq) struct request *elv_latter_request(request_queue_t *q, struct request *rq)
{ {
struct list_head *next;
elevator_t *e = q->elevator; elevator_t *e = q->elevator;
if (e->ops->elevator_latter_req_fn) if (e->ops->elevator_latter_req_fn)
return e->ops->elevator_latter_req_fn(q, rq); 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; return NULL;
} }
struct request *elv_former_request(request_queue_t *q, struct request *rq) struct request *elv_former_request(request_queue_t *q, struct request *rq)
{ {
struct list_head *prev;
elevator_t *e = q->elevator; elevator_t *e = q->elevator;
if (e->ops->elevator_former_req_fn) if (e->ops->elevator_former_req_fn)
return e->ops->elevator_former_req_fn(q, rq); 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; return NULL;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册