Source-Changes-HG archive

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

[src/trunk]: src/sys/dev/usb More __BITS. NFCI.



details:   https://anonhg.NetBSD.org/src/rev/b2559a9062ca
branches:  trunk
changeset: 972742:b2559a9062ca
user:      skrll <skrll%NetBSD.org@localhost>
date:      Sat Jun 06 08:56:30 2020 +0000

description:
More __BITS.  NFCI.

diffstat:

 sys/dev/usb/xhci.c    |  10 +++---
 sys/dev/usb/xhcireg.h |  73 ++++++++++++++++++++++++++++++++------------------
 2 files changed, 51 insertions(+), 32 deletions(-)

diffs (182 lines):

diff -r 1dcac130cdad -r b2559a9062ca sys/dev/usb/xhci.c
--- a/sys/dev/usb/xhci.c        Sat Jun 06 07:03:21 2020 +0000
+++ b/sys/dev/usb/xhci.c        Sat Jun 06 08:56:30 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: xhci.c,v 1.131 2020/06/04 20:54:37 skrll Exp $ */
+/*     $NetBSD: xhci.c,v 1.132 2020/06/06 08:56:30 skrll Exp $ */
 
 /*
  * Copyright (c) 2013 Jonathan A. Kollasch
@@ -34,7 +34,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: xhci.c,v 1.131 2020/06/04 20:54:37 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: xhci.c,v 1.132 2020/06/06 08:56:30 skrll Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_usb.h"
@@ -645,7 +645,7 @@
 
        xhci_rt_write_4(sc, XHCI_ERSTSZ(0), 0);
        xhci_rt_write_8(sc, XHCI_ERSTBA(0), 0);
-       xhci_rt_write_8(sc, XHCI_ERDP(0), 0|XHCI_ERDP_LO_BUSY);
+       xhci_rt_write_8(sc, XHCI_ERDP(0), 0 | XHCI_ERDP_BUSY);
        xhci_ring_free(sc, &sc->sc_er);
 
        usb_freemem(&sc->sc_bus, &sc->sc_eventst_dma);
@@ -1211,7 +1211,7 @@
        xhci_rt_write_4(sc, XHCI_ERSTSZ(0), XHCI_EVENT_RING_SEGMENTS);
        xhci_rt_write_8(sc, XHCI_ERSTBA(0), DMAADDR(&sc->sc_eventst_dma, 0));
        xhci_rt_write_8(sc, XHCI_ERDP(0), xhci_ring_trbp(sc->sc_er, 0) |
-           XHCI_ERDP_LO_BUSY);
+           XHCI_ERDP_BUSY);
 
        xhci_op_write_8(sc, XHCI_DCBAAP, DMAADDR(&sc->sc_dcbaa_dma, 0));
        xhci_op_write_8(sc, XHCI_CRCR, xhci_ring_trbp(sc->sc_cr, 0) |
@@ -2225,7 +2225,7 @@
        er->xr_cs = j;
 
        xhci_rt_write_8(sc, XHCI_ERDP(0), xhci_ring_trbp(er, er->xr_ep) |
-           XHCI_ERDP_LO_BUSY);
+           XHCI_ERDP_BUSY);
 
        DPRINTFN(16, "ends", 0, 0, 0, 0);
 
diff -r 1dcac130cdad -r b2559a9062ca sys/dev/usb/xhcireg.h
--- a/sys/dev/usb/xhcireg.h     Sat Jun 06 07:03:21 2020 +0000
+++ b/sys/dev/usb/xhcireg.h     Sat Jun 06 08:56:30 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: xhcireg.h,v 1.17 2020/06/04 20:54:37 skrll Exp $ */
+/* $NetBSD: xhcireg.h,v 1.18 2020/06/06 08:56:30 skrll Exp $ */
 
 /*-
  * Copyright (c) 2010 Hans Petter Selasky. All rights reserved.
@@ -51,6 +51,7 @@
 #define         XHCI_HCIVERSION_0_96   0x0096  /* xHCI version 0.96 */
 #define         XHCI_HCIVERSION_1_0    0x0100  /* xHCI version 1.0 */
 #define         XHCI_HCIVERSION_1_1    0x0110  /* xHCI version 1.1 */
+#define         XHCI_HCIVERSION_1_2    0x0120  /* xHCI version 1.2 */
 
 #define        XHCI_HCSPARAMS1         0x04    /* RO structual parameters 1 */
 #define         XHCI_HCS1_MAXSLOTS_MASK        __BITS(7, 0)
@@ -129,7 +130,6 @@
 #define         XHCI_CMD_TSC_EN        __BIT(15)       /* RW Extended TBC TRB Status Enable */
 #define         XHCI_CMD_VTIOE         __BIT(16)       /* RW VTIO Enable */
 
-
 #define        XHCI_WAIT_CNR           100             /* in 1ms */
 #define        XHCI_WAIT_HCRST         100             /* in 1ms */
 
@@ -282,44 +282,63 @@
 #define        XHCI_PLMC3_LSEC_MASK    __BITS(15, 0)   /* RW - Link Soft Error Count */
 #define        XHCI_PLMC3_LSEC_GET(x)  __SHIFTOUT((x), XHCI_PLMC3_LSEC_MASK)
 
+/* 5.5.1 */
 /* XHCI runtime registers.  Offset given by XHCI_CAPLENGTH + XHCI_RTSOFF registers */
-#define        XHCI_MFINDEX            0x0000          /* RO - microframe index */
-#define         XHCI_MFINDEX_GET(x)    ((x) & 0x3FFF)
+#define        XHCI_MFINDEX            0x0000
+#define         XHCI_MFINDEX_MASK      __BITS(13, 0)   /* RO - microframe index */
+#define         XHCI_MFINDEX_GET(x)    __SHIFTOUT((x), XHCI_MFINDEX_MASK)
 
-#define        XHCI_IMAN(n)            (0x0020 + (0x20 * (n))) /* XHCI interrupt management */
+/* 5.5.2 Interrupter Register set */
+/* 5.5.2.1 interrupt management */
+#define        XHCI_IMAN(n)            (0x0020 + (0x20 * (n)))
 #define         XHCI_IMAN_INTR_PEND    __BIT(0)        /* RW - interrupt pending */
 #define         XHCI_IMAN_INTR_ENA     __BIT(1)        /* RW - interrupt enable */
 
+/* 5.5.2.2 Interrupter Moderation */
 #define        XHCI_IMOD(n)            (0x0024 + (0x20 * (n))) /* XHCI interrupt moderation */
-#define         XHCI_IMOD_IVAL_GET(x)  (((x) >> 0) & 0xFFFF)   /* 250ns unit */
-#define         XHCI_IMOD_IVAL_SET(x)  (((x) & 0xFFFF) << 0)   /* 250ns unit */
-#define         XHCI_IMOD_ICNT_GET(x)  (((x) >> 16) & 0xFFFF)  /* 250ns unit */
-#define         XHCI_IMOD_ICNT_SET(x)  (((x) & 0xFFFF) << 16)  /* 250ns unit */
+#define         XHCI_IMOD_IVAL_MASK    __BITS(15,0)    /* 250ns unit */
+#define         XHCI_IMOD_IVAL_GET(x)  __SHIFTOUT((x), XHCI_IMOD_IVAL_MASK)
+#define         XHCI_IMOD_IVAL_SET(x)  __SHIFTIN((x), XHCI_IMOD_IVAL_MASK)
+#define         XHCI_IMOD_ICNT_MASK    __BITS(31, 16)  /* 250ns unit */
+#define         XHCI_IMOD_ICNT_GET(x)  __SHIFTOUT((x), XHCI_IMOD_ICNT_MASK)
+#define         XHCI_IMOD_ICNT_SET(x)  __SHIFTIN((x), XHCI_IMOD_ICNT_MASK)
 #define         XHCI_IMOD_DEFAULT      0x000001F4U     /* 8000 IRQ/second */
 #define         XHCI_IMOD_DEFAULT_LP   0x000003E8U     /* 4000 IRQ/sec for LynxPoint */
 
-#define        XHCI_ERSTSZ(n)          (0x0028 + (0x20 * (n))) /* XHCI event ring segment table size */
-#define         XHCI_ERSTS_GET(x)      ((x) & 0xFFFF)
-#define         XHCI_ERSTS_SET(x)      ((x) & 0xFFFF)
+/* 5.5.2.3 Event Ring */
+/* 5.5.2.3.1 Event Ring Segment Table Size */
+#define        XHCI_ERSTSZ(n)          (0x0028 + (0x20 * (n)))
+#define         XHCI_ERSTS_MASK        __BITS(15, 0)   /* Event Ring Segment Table Size */
+#define         XHCI_ERSTS_GET(x)      __SHIFTOUT((x), XHCI_ERSTS_MASK)
+#define         XHCI_ERSTS_SET(x)      __SHIFTIN((x), XHCI_ERSTS_MASK)
 
-#define        XHCI_ERSTBA(n)          (0x0030 + (0x20 * (n))) /* XHCI event ring segment table BA */
-#define        XHCI_ERSTBA_HI(n)       (0x0034 + (0x20 * (n))) /* XHCI event ring segment table BA */
+/* 5.5.2.3.2 Event Ring Segment Table Base Address Register */
+#define        XHCI_ERSTBA(n)          (0x0030 + (0x20 * (n)))
+#define         XHCI_ERSTBA_MASK       __BIT(31,6)     /* RW - segment base address (low) */
+#define        XHCI_ERSTBA_HI(n)       (0x0034 + (0x20 * (n)))
 
-#define        XHCI_ERDP(n)            (0x0038 + (0x20 * (n))) /* XHCI event ring dequeue pointer */
-#define        XHCI_ERDP_HI(n)         (0x003C + (0x20 * (n))) /* XHCI event ring dequeue pointer */
-#define         XHCI_ERDP_LO_SINDEX(x) ((x) & 0x7)     /* RO - dequeue segment index */
-#define         XHCI_ERDP_LO_BUSY      __BIT(3)        /* RW - event handler busy */
+/* 5.5.2.3.3 Event Ring Dequeue Pointer */
+#define        XHCI_ERDP(n)            (0x0038 + (0x20 * (n)))
+#define         XHCI_ERDP_DESI_MASK    __BITS(2,0)     /* RO - dequeue segment index */
+#define         XHCI_ERDP_GET_DESI(x)  __SHIFTOUT(x), XHCI_ERDP_DESI_MASK)
+#define         XHCI_ERDP_BUSY         __BIT(3)        /* RW - event handler busy */
+#define         XHCI_ERDP_PTRLO_MASK   __BIT(31,4)     /* RW - dequeue pointer (low) */
+#define        XHCI_ERDP_HI(n)         (0x003C + (0x20 * (n)))
 
-/* XHCI doorbell registers. Offset given by XHCI_CAPLENGTH + XHCI_DBOFF registers */
+/* 5.6 XHCI doorbell registers. Offset given by XHCI_CAPLENGTH + XHCI_DBOFF registers */
 #define        XHCI_DOORBELL(n)        (0x0000 + (4 * (n)))
-#define         XHCI_DB_TARGET_GET(x)  ((x) & 0xFF)            /* RW - doorbell target */
-#define         XHCI_DB_TARGET_SET(x)  ((x) & 0xFF)            /* RW - doorbell target */
-#define         XHCI_DB_SID_GET(x)     (((x) >> 16) & 0xFFFF)  /* RW - doorbell stream ID */
-#define         XHCI_DB_SID_SET(x)     (((x) & 0xFFFF) << 16)  /* RW - doorbell stream ID */
+#define         XHCI_DB_TARGET_MASK    __BITS(7, 0)    /* RW - doorbell target */
+#define         XHCI_DB_TARGET_GET(x)  __SHIFTOUT((x), XHCI_DB_TARGET_MASK)
+#define         XHCI_DB_TARGET_SET(x)  __SHIFTIN((x), XHCI_DB_TARGET_MASK)
+#define         XHCI_DB_SID_MASK       __BITS(31, 16)  /* RW - doorbell stream ID */
+#define         XHCI_DB_SID_GET(x)     __SHIFTOUT((x), XHCI_DB_SID_MASK)
+#define         XHCI_DB_SID_SET(x)     __SHIFTIN((x), XHCI_DB_SID_MASK)
 
 /* 7 xHCI Extendeded capabilities */
-#define        XHCI_XECP_ID(x)         ((x) & 0xFF)
-#define        XHCI_XECP_NEXT(x)       (((x) >> 8) & 0xFF)
+#define        XHCI_XECP_ID_MASK       __BITS(7, 0)
+#define        XHCI_XECP_ID(x)         __SHIFTOUT((x), XHCI_XECP_ID_MASK)
+#define        XHCI_XECP_NEXT_MASK     __BITS(15, 8)
+#define        XHCI_XECP_NEXT(x)       __SHIFTOUT((x), XHCI_XECP_NEXT_MASK)
 
 /* XHCI extended capability ID's */
 #define        XHCI_ID_USB_LEGACY      0x0001  /* USB Legacy Support */
@@ -338,7 +357,7 @@
 #define        XHCI_XECP_OS_SEM        0x0003
 
 /* 7.2 xHCI Supported Protocol Capability */
-#define        XHCI_XECP_USBID         0x20425355
+#define        XHCI_XECP_USBID         0x20425355
 
 #define        XHCI_XECP_SP_W0_MINOR_MASK      __BITS(23, 16)
 #define        XHCI_XECP_SP_W0_MINOR(x)        __SHIFTOUT((x), XHCI_XECP_SP_W0_MINOR_MASK)
@@ -440,7 +459,6 @@
 #define XHCI_TRB_3_SLOT_GET(x)         __SHIFTOUT((x), XHCI_TRB_3_SLOT_MASK)
 #define XHCI_TRB_3_SLOT_SET(x)         __SHIFTIN((x), XHCI_TRB_3_SLOT_MASK)
 
-
        /* Commands */
 #define XHCI_TRB_TYPE_RESERVED          0x00
 #define XHCI_TRB_TYPE_NORMAL            0x01
@@ -570,6 +588,7 @@
 #define XHCI_SLOTSTATE_DEFAULT                 1
 #define XHCI_SLOTSTATE_ADDRESSED               2
 #define XHCI_SLOTSTATE_CONFIGURED              3
+
 /*
  * 6.2.3 Endpoint Context
  * */



Home | Main Index | Thread Index | Old Index