Author: cem
Date: Tue Jul 12 21:56:34 2016
New Revision: 302678
URL: https://svnweb.freebsd.org/changeset/base/302678

Log:
  ioat(4): Don't shrink ring if active

Modified:
  head/sys/dev/ioat/ioat.c

Modified: head/sys/dev/ioat/ioat.c
==============================================================================
--- head/sys/dev/ioat/ioat.c    Tue Jul 12 21:52:26 2016        (r302677)
+++ head/sys/dev/ioat/ioat.c    Tue Jul 12 21:56:34 2016        (r302678)
@@ -1682,7 +1682,8 @@ ioat_shrink_timer_callback(void *arg)
        }
 
        order = ioat->ring_size_order;
-       if (ioat->is_resize_pending || order == IOAT_MIN_ORDER) {
+       if (ioat->is_completion_pending || ioat->is_resize_pending ||
+           order == IOAT_MIN_ORDER) {
                mtx_unlock(&ioat->submit_lock);
                goto out;
        }
@@ -1696,8 +1697,10 @@ ioat_shrink_timer_callback(void *arg)
        KASSERT(ioat->ring_size_order == order,
            ("resize_pending protects order"));
 
-       if (newring != NULL)
+       if (newring != NULL && !ioat->is_completion_pending)
                ring_shrink(ioat, order, newring);
+       else if (newring != NULL)
+               ioat_free_ring(ioat, (1 << (order - 1)), newring);
 
        ioat->is_resize_pending = FALSE;
        mtx_unlock(&ioat->submit_lock);
_______________________________________________
svn-src-head@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to