Author: jhb
Date: Thu Aug 30 17:47:39 2012
New Revision: 239913
URL: http://svn.freebsd.org/changeset/base/239913

Log:
  Attach interrupt handlers during attach instead of during the first time
  the interface is brought up.  Without this, the boot time interrupt
  round-robin assignment does not think the allocated interrupt resources
  are active and leaves them assigned to CPU 0.
  
  While here, add descriptive tags to each interrupt handler when MSI-X
  is used.
  
  Reviewed by:  np
  MFC after:    1 week

Modified:
  head/sys/dev/cxgb/cxgb_main.c

Modified: head/sys/dev/cxgb/cxgb_main.c
==============================================================================
--- head/sys/dev/cxgb/cxgb_main.c       Thu Aug 30 17:37:01 2012        
(r239912)
+++ head/sys/dev/cxgb/cxgb_main.c       Thu Aug 30 17:47:39 2012        
(r239913)
@@ -675,6 +675,9 @@ cxgb_controller_attach(device_t dev)
        for (i = 0; i < NUM_CPL_HANDLERS; i++)
                sc->cpl_handler[i] = cpl_not_handled;
 #endif
+
+       t3_intr_clear(sc);
+       error = cxgb_setup_interrupts(sc);
 out:
        if (error)
                cxgb_free(sc);
@@ -922,6 +925,7 @@ cxgb_setup_interrupts(adapter_t *sc)
        if (!(intr_flag & USING_MSIX) || err)
                return (err);
 
+       bus_describe_intr(sc->dev, sc->irq_res, sc->intr_tag, "err");
        for (i = 0; i < sc->msi_count - 1; i++) {
                rid = i + 2;
                res = bus_alloc_resource_any(sc->dev, SYS_RES_IRQ, &rid,
@@ -945,6 +949,7 @@ cxgb_setup_interrupts(adapter_t *sc)
                sc->msix_irq_rid[i] = rid;
                sc->msix_irq_res[i] = res;
                sc->msix_intr_tag[i] = tag;
+               bus_describe_intr(sc->dev, res, tag, "qs%d", i);
        }
 
        if (err)
@@ -1611,11 +1616,6 @@ cxgb_up(struct adapter *sc)
                alloc_filters(sc);
                setup_rss(sc);
 
-               t3_intr_clear(sc);
-               err = cxgb_setup_interrupts(sc);
-               if (err)
-                       goto out;
-
                t3_add_configured_sysctls(sc);
                sc->flags |= FULL_INIT_DONE;
        }
_______________________________________________
[email protected] mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "[email protected]"

Reply via email to