linux-2.6-npiggin/drivers/block/as-iosched.c | 23 +++++++++++++++++++++++ 1 files changed, 23 insertions(+) diff -puN drivers/block/as-iosched.c~as-warn-fix drivers/block/as-iosched.c --- linux-2.6/drivers/block/as-iosched.c~as-warn-fix 2003-09-09 13:01:04.000000000 +1000 +++ linux-2.6-npiggin/drivers/block/as-iosched.c 2003-09-09 13:21:12.000000000 +1000 @@ -381,8 +381,14 @@ static void as_add_arq_rb(struct as_data arq->rb_key = rq_rb_key(rq); /* This can be caused by direct IO */ +#if 0 while ((alias = __as_add_arq_rb(ad, arq))) as_move_to_dispatch(ad, alias); +#endif + if ((alias = __as_add_arq_rb(ad, arq))) { + list_add_tail(&arq->request->queuelist, + &alias->request->queuelist); + } rb_insert_color(&arq->rb_node, ARQ_RB_ROOT(ad, arq)); } @@ -1131,7 +1137,24 @@ static void as_move_to_dispatch(struct a * take it off the sort and fifo list, add to dispatch queue */ as_remove_queued_request(ad->q, arq->request); + + for (;;) { + struct list_head *alias = &arq->request->queuelist; + + if (!list_empty(alias)) { + struct request *rq; + rq = list_entry_rq(alias->next); + list_del(&rq->queuelist); + list_add_tail(&rq->queuelist, ad->dispatch); + + if (arq->io_context && arq->io_context->aic) + atomic_inc(&arq->io_context->aic->nr_dispatched); + } else + break; + } + list_add_tail(&arq->request->queuelist, ad->dispatch); + if (arq->io_context && arq->io_context->aic) atomic_inc(&arq->io_context->aic->nr_dispatched); _