Author: np
Date: Sat Jun  8 07:23:26 2013
New Revision: 251518
URL: http://svnweb.freebsd.org/changeset/base/251518

Log:
  cxgbe/tom: Fix bad signed/unsigned mixup in the stid allocator.  This
  fixes a panic when allocating a mixture of IPv6 and IPv4 stids.
  
  MFC after:    1 week

Modified:
  head/sys/dev/cxgbe/offload.h
  head/sys/dev/cxgbe/tom/t4_listen.c

Modified: head/sys/dev/cxgbe/offload.h
==============================================================================
--- head/sys/dev/cxgbe/offload.h        Sat Jun  8 07:16:22 2013        
(r251517)
+++ head/sys/dev/cxgbe/offload.h        Sat Jun  8 07:23:26 2013        
(r251518)
@@ -59,8 +59,8 @@ struct listen_ctx;
 
 struct stid_region {
        TAILQ_ENTRY(stid_region) link;
-       int used;       /* # of stids used by this region */
-       int free;       /* # of contiguous stids free right after this region */
+       u_int used;     /* # of stids used by this region */
+       u_int free;     /* # of contiguous stids free right after this region */
 };
 
 /*

Modified: head/sys/dev/cxgbe/tom/t4_listen.c
==============================================================================
--- head/sys/dev/cxgbe/tom/t4_listen.c  Sat Jun  8 07:16:22 2013        
(r251517)
+++ head/sys/dev/cxgbe/tom/t4_listen.c  Sat Jun  8 07:23:26 2013        
(r251518)
@@ -125,7 +125,7 @@ alloc_stid(struct adapter *sc, struct li
                TAILQ_FOREACH(s, &t->stids, link) {
                        stid += s->used + s->free;
                        f = stid & mask;
-                       if (n <= s->free - f) {
+                       if (s->free >= n + f) {
                                stid -= n + f;
                                s->free -= n + f;
                                TAILQ_INSERT_AFTER(&t->stids, s, sr, link);
_______________________________________________
svn-src-head@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to