Commit 1fbfdfcd authored by Jens Axboe's avatar Jens Axboe Committed by Jens Axboe
Browse files

[PATCH] elevator: introduce a way to reuse rq for internal FIFO handling



The io schedulers can use this instead of having to allocate space for
it themselves.

Signed-off-by: default avatarJens Axboe <axboe@suse.de>
parent b8aca35a
Loading
Loading
Loading
Loading
+12 −0
Original line number Diff line number Diff line
@@ -166,4 +166,16 @@ enum {
#define rq_end_sector(rq)	((rq)->sector + (rq)->nr_sectors)
#define rb_entry_rq(node)	rb_entry((node), struct request, rb_node)

/*
 * Hack to reuse the donelist list_head as the fifo time holder while
 * the request is in the io scheduler. Saves an unsigned long in rq.
 */
#define rq_fifo_time(rq)	((unsigned long) (rq)->donelist.next)
#define rq_set_fifo_time(rq,exp)	((rq)->donelist.next = (void *) (exp))
#define rq_entry_fifo(ptr)	list_entry((ptr), struct request, queuelist)
#define rq_fifo_clear(rq)	do {		\
	list_del_init(&(rq)->queuelist);	\
	INIT_LIST_HEAD(&(rq)->donelist);	\
	} while (0)

#endif