Re: plug problem in linux-2.4.0-test11

From: Linus Torvalds (torvalds@transmeta.com)
Date: Wed Nov 29 2000 - 12:52:01 EST


On Wed, 29 Nov 2000, Jens Axboe wrote:
>
> I agree with your reasoning, even if the s390 behaviour is a bit
> "non-standard" wrt block devices. Linus, could you apply?
>
> --- drivers/block/ll_rw_blk.c~ Wed Nov 29 15:17:33 2000
> +++ drivers/block/ll_rw_blk.c Wed Nov 29 15:18:43 2000
> @@ -347,10 +347,9 @@
> */
> static inline void __generic_unplug_device(request_queue_t *q)
> {
> - if (!list_empty(&q->queue_head)) {
> - q->plugged = 0;
> + q->plugged = 0;
> + if (!list_empty(&q->queue_head))
> q->request_fn(q);
> - }
> }

I would much rather actually go back to the original setup, which did
nothing at all if the queue wasn't plugged in the first place.

I think that we should strive for a setup that calls "request_fn" only to
start new IO, and that expects the low-level driver to be able to do the
whole request queue until it is empty. Then we re-start it the next time
around.

                        Linus

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
Please read the FAQ at http://www.tux.org/lkml/



This archive was generated by hypermail 2b29 : Thu Nov 30 2000 - 21:00:22 EST