All of lore.kernel.org
 help / color / mirror / Atom feed
* [uml-devel] patch: use elv_queue_empty
@ 2004-02-08 21:11 Werner Almesberger
  2004-02-12 15:55 ` [uml-devel] " Jeff Dike
  2004-02-22 18:33 ` [uml-devel] " BlaisorBlade
  0 siblings, 2 replies; 3+ messages in thread
From: Werner Almesberger @ 2004-02-08 21:11 UTC (permalink / raw)
  To: jdike; +Cc: user-mode-linux-devel

This patch makes UBD a little more compatible with alternative
elevators that may not use a single request queue.

It's for 2.6.1 with uml-patch-2.6.1-1.

- Werner

--- linux-2.6.1/arch/um/drivers/ubd_kern.c.orig	Sun Feb  8 17:16:51 2004
+++ linux-2.6.1/arch/um/drivers/ubd_kern.c	Sun Feb  8 17:17:32 2004
@@ -1034,7 +1034,7 @@
 	int err, n;
 
 	if(thread_fd == -1){
-		while(!list_empty(&q->queue_head)){
+		while(!elv_queue_empty(q)){
 			req = elv_next_request(q);
 			err = prepare_request(req, &io_req);
 			if(!err){
@@ -1044,7 +1044,7 @@
 		}
 	}
 	else {
-		if(do_ubd || list_empty(&q->queue_head)) return;
+		if(do_ubd || elv_queue_empty(q)) return;
 		req = elv_next_request(q);
 		err = prepare_request(req, &io_req);
 		if(!err){

-- 
  _________________________________________________________________________
 / Werner Almesberger, Buenos Aires, Argentina     werner@almesberger.net /
/_http://www.almesberger.net/____________________________________________/


-------------------------------------------------------
The SF.Net email is sponsored by EclipseCon 2004
Premiere Conference on Open Tools Development and Integration
See the breadth of Eclipse activity. February 3-5 in Anaheim, CA.
http://www.eclipsecon.org/osdn
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel

^ permalink raw reply	[flat|nested] 3+ messages in thread

* [uml-devel] Re: patch: use elv_queue_empty
  2004-02-08 21:11 [uml-devel] patch: use elv_queue_empty Werner Almesberger
@ 2004-02-12 15:55 ` Jeff Dike
  2004-02-22 18:33 ` [uml-devel] " BlaisorBlade
  1 sibling, 0 replies; 3+ messages in thread
From: Jeff Dike @ 2004-02-12 15:55 UTC (permalink / raw)
  To: Werner Almesberger; +Cc: user-mode-linux-devel

On Sun, Feb 08, 2004 at 06:11:09PM -0300, Werner Almesberger wrote:
> This patch makes UBD a little more compatible with alternative
> elevators that may not use a single request queue.

Applied, thanks.

		Jeff


-------------------------------------------------------
SF.Net is sponsored by: Speed Start Your Linux Apps Now.
Build and deploy apps & Web services for Linux with
a free DVD software kit from IBM. Click Now!
http://ads.osdn.com/?ad_id=1356&alloc_id=3438&op=click
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [uml-devel] patch: use elv_queue_empty
  2004-02-08 21:11 [uml-devel] patch: use elv_queue_empty Werner Almesberger
  2004-02-12 15:55 ` [uml-devel] " Jeff Dike
@ 2004-02-22 18:33 ` BlaisorBlade
  1 sibling, 0 replies; 3+ messages in thread
From: BlaisorBlade @ 2004-02-22 18:33 UTC (permalink / raw)
  To: Werner Almesberger, jdike; +Cc: user-mode-linux-devel

Alle 22:11, domenica 8 febbraio 2004, Werner Almesberger ha scritto:
> This patch makes UBD a little more compatible with alternative
> elevators that may not use a single request queue.

> --- linux-2.6.1/arch/um/drivers/ubd_kern.c.orig	Sun Feb  8 17:16:51 2004
> +++ linux-2.6.1/arch/um/drivers/ubd_kern.c	Sun Feb  8 17:17:32 2004
> @@ -1034,7 +1034,7 @@
>  	int err, n;
>
>  	if(thread_fd == -1){
> -		while(!list_empty(&q->queue_head)){
> +		while(!elv_queue_empty(q)){
>  			req = elv_next_request(q);
>  			err = prepare_request(req, &io_req);
>  			if(!err){
> @@ -1044,7 +1044,7 @@
>  		}
>  	}
>  	else {
> -		if(do_ubd || list_empty(&q->queue_head)) return;
> +		if(do_ubd || elv_queue_empty(q)) return;
>  		req = elv_next_request(q);
>  		err = prepare_request(req, &io_req);
>  		if(!err){

The old code was basically wrong - but Documentation/block/biodoc.txt 
recommends using just elv_next_request - i.e. instead of looping until 
elv_queue_empty(q) is true, just loop until elv_next_request returns NULL.
Calling elv_queue_empty is meaningless to just check if queues are empty if we 
must not get a request right now, since that can save us the cost of 
dispatching pending requests. But this is not the case. So the code could 
become:

while (1) {
  req = elv_next_request(q);
  if (!req) break;
...}

and 

if(do_ubd) return;
req = elv_next_request(q);
if (!req) return;

Any idea against / in favour of this?
Bye
-- 
Paolo Giarrusso, aka Blaisorblade
Linux registered user n. 292729



-------------------------------------------------------
SF.Net is sponsored by: Speed Start Your Linux Apps Now.
Build and deploy apps & Web services for Linux with
a free DVD software kit from IBM. Click Now!
http://ads.osdn.com/?ad_id=1356&alloc_id=3438&op=click
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2004-02-22 19:53 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2004-02-08 21:11 [uml-devel] patch: use elv_queue_empty Werner Almesberger
2004-02-12 15:55 ` [uml-devel] " Jeff Dike
2004-02-22 18:33 ` [uml-devel] " BlaisorBlade

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.