Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/pci Add an XHCI_DISABLE_MSI option



details:   https://anonhg.NetBSD.org/src/rev/9469a9c29025
branches:  trunk
changeset: 356140:9469a9c29025
user:      skrll <skrll%NetBSD.org@localhost>
date:      Tue Sep 05 08:01:43 2017 +0000

description:
Add an XHCI_DISABLE_MSI option

diffstat:

 sys/dev/pci/files.pci  |   3 ++-
 sys/dev/pci/xhci_pci.c |  18 +++++++++++++++---
 2 files changed, 17 insertions(+), 4 deletions(-)

diffs (57 lines):

diff -r ab41fc96b679 -r 9469a9c29025 sys/dev/pci/files.pci
--- a/sys/dev/pci/files.pci     Tue Sep 05 05:03:02 2017 +0000
+++ b/sys/dev/pci/files.pci     Tue Sep 05 08:01:43 2017 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: files.pci,v 1.390 2017/08/30 08:49:18 msaitoh Exp $
+#      $NetBSD: files.pci,v 1.391 2017/09/05 08:01:43 skrll Exp $
 #
 # Config file and device description for machine-independent PCI code.
 # Included by ports that need it.  Requires that the SCSI files be
@@ -635,6 +635,7 @@
 # xHCI USB controller
 attach xhci at pci with xhci_pci
 file   dev/pci/xhci_pci.c              xhci_pci
+defflag        opt_xhci_pci.h                  XHCI_DISABLE_MSI
 
 # OHCI IEEE 1394 controller
 attach fwohci at pci with fwohci_pci
diff -r ab41fc96b679 -r 9469a9c29025 sys/dev/pci/xhci_pci.c
--- a/sys/dev/pci/xhci_pci.c    Tue Sep 05 05:03:02 2017 +0000
+++ b/sys/dev/pci/xhci_pci.c    Tue Sep 05 08:01:43 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: xhci_pci.c,v 1.8 2017/01/19 16:05:00 skrll Exp $       */
+/*     $NetBSD: xhci_pci.c,v 1.9 2017/09/05 08:01:43 skrll Exp $       */
 /*     OpenBSD: xhci_pci.c,v 1.4 2014/07/12 17:38:51 yuo Exp   */
 
 /*
@@ -32,7 +32,11 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: xhci_pci.c,v 1.8 2017/01/19 16:05:00 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: xhci_pci.c,v 1.9 2017/09/05 08:01:43 skrll Exp $");
+
+#ifdef _KERNEL_OPT
+#include "opt_xhci_pci.h"
+#endif
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -173,8 +177,16 @@
        pci_conf_write(pc, tag, PCI_COMMAND_STATUS_REG,
                       csr | PCI_COMMAND_MASTER_ENABLE);
 
+       /* Allocation settings */
+       int counts[PCI_INTR_TYPE_SIZE] = {
+               [PCI_INTR_TYPE_INTX] = 1,
+#ifndef XHCI_DISABLE_MSI
+               [PCI_INTR_TYPE_MSI] = 1,
+#endif
+       };
+
        /* Allocate and establish the interrupt. */
-       if (pci_intr_alloc(pa, &psc->sc_pihp, NULL, 0)) {
+       if (pci_intr_alloc(pa, &psc->sc_pihp, counts, PCI_INTR_TYPE_MSIX)) {
                aprint_error_dev(self, "can't allocate handler\n");
                goto fail;
        }



Home | Main Index | Thread Index | Old Index