diff options
-rw-r--r-- | drivers/block/elevator.c | 33 | ||||
-rw-r--r-- | include/linux/blkdev.h | 13 | ||||
-rw-r--r-- | include/linux/elevator.h | 4 |
3 files changed, 27 insertions, 23 deletions
diff --git a/drivers/block/elevator.c b/drivers/block/elevator.c index a27555908d35..237e43d760c8 100644 --- a/drivers/block/elevator.c +++ b/drivers/block/elevator.c | |||
@@ -40,11 +40,6 @@ | |||
40 | static DEFINE_SPINLOCK(elv_list_lock); | 40 | static DEFINE_SPINLOCK(elv_list_lock); |
41 | static LIST_HEAD(elv_list); | 41 | static LIST_HEAD(elv_list); |
42 | 42 | ||
43 | static inline sector_t rq_last_sector(struct request *rq) | ||
44 | { | ||
45 | return rq->sector + rq->nr_sectors; | ||
46 | } | ||
47 | |||
48 | /* | 43 | /* |
49 | * can we safely merge with this request? | 44 | * can we safely merge with this request? |
50 | */ | 45 | */ |
@@ -148,7 +143,7 @@ static int elevator_attach(request_queue_t *q, struct elevator_type *e, | |||
148 | INIT_LIST_HEAD(&q->queue_head); | 143 | INIT_LIST_HEAD(&q->queue_head); |
149 | q->last_merge = NULL; | 144 | q->last_merge = NULL; |
150 | q->elevator = eq; | 145 | q->elevator = eq; |
151 | q->last_sector = 0; | 146 | q->end_sector = 0; |
152 | q->boundary_rq = NULL; | 147 | q->boundary_rq = NULL; |
153 | q->max_back_kb = 0; | 148 | q->max_back_kb = 0; |
154 | 149 | ||
@@ -233,29 +228,25 @@ void elevator_exit(elevator_t *e) | |||
233 | kfree(e); | 228 | kfree(e); |
234 | } | 229 | } |
235 | 230 | ||
231 | void elv_dispatch_insert_tail(request_queue_t *q, struct request *rq) | ||
232 | { | ||
233 | } | ||
234 | |||
236 | /* | 235 | /* |
237 | * Insert rq into dispatch queue of q. Queue lock must be held on | 236 | * Insert rq into dispatch queue of q. Queue lock must be held on |
238 | * entry. If sort != 0, rq is sort-inserted; otherwise, rq will be | 237 | * entry. If sort != 0, rq is sort-inserted; otherwise, rq will be |
239 | * appended to the dispatch queue. To be used by specific elevators. | 238 | * appended to the dispatch queue. To be used by specific elevators. |
240 | */ | 239 | */ |
241 | void elv_dispatch_insert(request_queue_t *q, struct request *rq, int sort) | 240 | void elv_dispatch_sort(request_queue_t *q, struct request *rq) |
242 | { | 241 | { |
243 | sector_t boundary; | 242 | sector_t boundary; |
244 | unsigned max_back; | 243 | unsigned max_back; |
245 | struct list_head *entry; | 244 | struct list_head *entry; |
246 | 245 | ||
247 | if (!sort) { | 246 | boundary = q->end_sector; |
248 | /* Specific elevator is performing sort. Step away. */ | ||
249 | q->last_sector = rq_last_sector(rq); | ||
250 | q->boundary_rq = rq; | ||
251 | list_add_tail(&rq->queuelist, &q->queue_head); | ||
252 | return; | ||
253 | } | ||
254 | |||
255 | boundary = q->last_sector; | ||
256 | max_back = q->max_back_kb * 2; | 247 | max_back = q->max_back_kb * 2; |
257 | boundary = boundary > max_back ? boundary - max_back : 0; | 248 | boundary = boundary > max_back ? boundary - max_back : 0; |
258 | 249 | ||
259 | list_for_each_prev(entry, &q->queue_head) { | 250 | list_for_each_prev(entry, &q->queue_head) { |
260 | struct request *pos = list_entry_rq(entry); | 251 | struct request *pos = list_entry_rq(entry); |
261 | 252 | ||
@@ -343,10 +334,10 @@ void __elv_add_request(request_queue_t *q, struct request *rq, int where, | |||
343 | where = ELEVATOR_INSERT_BACK; | 334 | where = ELEVATOR_INSERT_BACK; |
344 | 335 | ||
345 | /* | 336 | /* |
346 | * this request is scheduling boundary, update last_sector | 337 | * this request is scheduling boundary, update end_sector |
347 | */ | 338 | */ |
348 | if (blk_fs_request(rq)) { | 339 | if (blk_fs_request(rq)) { |
349 | q->last_sector = rq_last_sector(rq); | 340 | q->end_sector = rq_end_sector(rq); |
350 | q->boundary_rq = rq; | 341 | q->boundary_rq = rq; |
351 | } | 342 | } |
352 | } | 343 | } |
@@ -479,7 +470,7 @@ struct request *elv_next_request(request_queue_t *q) | |||
479 | q->last_merge = NULL; | 470 | q->last_merge = NULL; |
480 | 471 | ||
481 | if (!q->boundary_rq || q->boundary_rq == rq) { | 472 | if (!q->boundary_rq || q->boundary_rq == rq) { |
482 | q->last_sector = rq_last_sector(rq); | 473 | q->end_sector = rq_end_sector(rq); |
483 | q->boundary_rq = NULL; | 474 | q->boundary_rq = NULL; |
484 | } | 475 | } |
485 | 476 | ||
@@ -802,7 +793,7 @@ ssize_t elv_iosched_show(request_queue_t *q, char *name) | |||
802 | return len; | 793 | return len; |
803 | } | 794 | } |
804 | 795 | ||
805 | EXPORT_SYMBOL(elv_dispatch_insert); | 796 | EXPORT_SYMBOL(elv_dispatch_sort); |
806 | EXPORT_SYMBOL(elv_add_request); | 797 | EXPORT_SYMBOL(elv_add_request); |
807 | EXPORT_SYMBOL(__elv_add_request); | 798 | EXPORT_SYMBOL(__elv_add_request); |
808 | EXPORT_SYMBOL(elv_requeue_request); | 799 | EXPORT_SYMBOL(elv_requeue_request); |
diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h index 2c7b9154927a..a2e496f285a4 100644 --- a/include/linux/blkdev.h +++ b/include/linux/blkdev.h | |||
@@ -337,7 +337,7 @@ struct request_queue | |||
337 | /* | 337 | /* |
338 | * Dispatch queue sorting | 338 | * Dispatch queue sorting |
339 | */ | 339 | */ |
340 | sector_t last_sector; | 340 | sector_t end_sector; |
341 | struct request *boundary_rq; | 341 | struct request *boundary_rq; |
342 | unsigned int max_back_kb; | 342 | unsigned int max_back_kb; |
343 | 343 | ||
@@ -625,6 +625,17 @@ static inline void blkdev_dequeue_request(struct request *req) | |||
625 | } | 625 | } |
626 | 626 | ||
627 | /* | 627 | /* |
628 | * This should be in elevator.h, but that requires pulling in rq and q | ||
629 | */ | ||
630 | static inline void elv_dispatch_add_tail(struct request_queue *q, | ||
631 | struct request *rq) | ||
632 | { | ||
633 | q->end_sector = rq_end_sector(rq); | ||
634 | q->boundary_rq = rq; | ||
635 | list_add_tail(&rq->queuelist, &q->queue_head); | ||
636 | } | ||
637 | |||
638 | /* | ||
628 | * Access functions for manipulating queue properties | 639 | * Access functions for manipulating queue properties |
629 | */ | 640 | */ |
630 | extern request_queue_t *blk_init_queue_node(request_fn_proc *rfn, | 641 | extern request_queue_t *blk_init_queue_node(request_fn_proc *rfn, |
diff --git a/include/linux/elevator.h b/include/linux/elevator.h index 76f4f6920744..f9b5ec38121a 100644 --- a/include/linux/elevator.h +++ b/include/linux/elevator.h | |||
@@ -79,7 +79,7 @@ struct elevator_queue | |||
79 | /* | 79 | /* |
80 | * block elevator interface | 80 | * block elevator interface |
81 | */ | 81 | */ |
82 | extern void elv_dispatch_insert(request_queue_t *, struct request *, int); | 82 | extern void elv_dispatch_sort(request_queue_t *, struct request *); |
83 | extern void elv_add_request(request_queue_t *, struct request *, int, int); | 83 | extern void elv_add_request(request_queue_t *, struct request *, int, int); |
84 | extern void __elv_add_request(request_queue_t *, struct request *, int, int); | 84 | extern void __elv_add_request(request_queue_t *, struct request *, int, int); |
85 | extern int elv_merge(request_queue_t *, struct request **, struct bio *); | 85 | extern int elv_merge(request_queue_t *, struct request **, struct bio *); |
@@ -140,4 +140,6 @@ enum { | |||
140 | ELV_MQUEUE_MUST, | 140 | ELV_MQUEUE_MUST, |
141 | }; | 141 | }; |
142 | 142 | ||
143 | #define rq_end_sector(rq) ((rq)->sector + (rq)->nr_sectors) | ||
144 | |||
143 | #endif | 145 | #endif |