Author: mav
Date: Wed Dec 30 17:23:27 2009
New Revision: 201264
URL: http://svn.freebsd.org/changeset/base/201264

Log:
  Call wakeup() only for the first request on the queue.

Modified:
  head/sys/geom/geom_io.c

Modified: head/sys/geom/geom_io.c
==============================================================================
--- head/sys/geom/geom_io.c     Wed Dec 30 17:22:00 2009        (r201263)
+++ head/sys/geom/geom_io.c     Wed Dec 30 17:23:27 2009        (r201264)
@@ -391,6 +391,7 @@ void
 g_io_request(struct bio *bp, struct g_consumer *cp)
 {
        struct g_provider *pp;
+       int first;
 
        KASSERT(cp != NULL, ("NULL cp in g_io_request"));
        KASSERT(bp != NULL, ("NULL bp in g_io_request"));
@@ -463,12 +464,14 @@ g_io_request(struct bio *bp, struct g_co
 
        pp->nstart++;
        cp->nstart++;
+       first = TAILQ_EMPTY(&g_bio_run_down.bio_queue);
        TAILQ_INSERT_TAIL(&g_bio_run_down.bio_queue, bp, bio_queue);
        g_bio_run_down.bio_queue_length++;
        g_bioq_unlock(&g_bio_run_down);
 
        /* Pass it on down. */
-       wakeup(&g_wait_down);
+       if (first)
+               wakeup(&g_wait_down);
 }
 
 void
@@ -476,6 +479,7 @@ g_io_deliver(struct bio *bp, int error)
 {
        struct g_consumer *cp;
        struct g_provider *pp;
+       int first;
 
        KASSERT(bp != NULL, ("NULL bp in g_io_deliver"));
        pp = bp->bio_to;
@@ -536,11 +540,13 @@ g_io_deliver(struct bio *bp, int error)
        pp->nend++;
        if (error != ENOMEM) {
                bp->bio_error = error;
+               first = TAILQ_EMPTY(&g_bio_run_up.bio_queue);
                TAILQ_INSERT_TAIL(&g_bio_run_up.bio_queue, bp, bio_queue);
                bp->bio_flags |= BIO_ONQUEUE;
                g_bio_run_up.bio_queue_length++;
                g_bioq_unlock(&g_bio_run_up);
-               wakeup(&g_wait_up);
+               if (first)
+                       wakeup(&g_wait_up);
                return;
        }
        g_bioq_unlock(&g_bio_run_up);
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to