Explorar o código

[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: Tejun Heo <htejun@gmail.com>
Signed-off-by: Jens Axboe <axboe@suse.de>
Tejun Heo %!s(int64=20) %!d(string=hai) anos
pai
achega
3beb207712
Modificáronse 1 ficheiros con 0 adicións e 14 borrados
  1. 0 14
      block/elevator.c

+ 0 - 14
block/elevator.c

@@ -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;
 }
 }