* [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.