Source-Changes-HG archive

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

[src/trunk]: src/sys/dev/sdmmc Add SDHC flags.



details:   https://anonhg.NetBSD.org/src/rev/c4e872a99edc
branches:  trunk
changeset: 1004312:c4e872a99edc
user:      hkenken <hkenken%NetBSD.org@localhost>
date:      Wed Oct 23 05:20:52 2019 +0000

description:
Add SDHC flags.

+ SDHC_FLAG_BROKEN_ADMA2_ZEROLEN
  Broken ADMA2 Zero length descriptor.
  Can't 64K Byte data transfer.
+ SDHC_FLAG_NO_1_8_V
  Support no 1.8V Supply.
  Disable UHS-I bus speed mode (SDR50, DDR50, SDR104).

diffstat:

 sys/arch/arm/imx/fdt/imx6_sdhc.c |   9 ++++--
 sys/dev/sdmmc/sdhc.c             |  49 +++++++++++++++++++++------------------
 sys/dev/sdmmc/sdhcreg.h          |   4 ++-
 sys/dev/sdmmc/sdhcvar.h          |   7 ++++-
 sys/dev/sdmmc/sdmmc.c            |   7 +++--
 sys/dev/sdmmc/sdmmcchip.h        |   3 +-
 sys/dev/sdmmc/sdmmcvar.h         |   4 ++-
 7 files changed, 50 insertions(+), 33 deletions(-)

diffs (229 lines):

diff -r 4265f5c08a17 -r c4e872a99edc sys/arch/arm/imx/fdt/imx6_sdhc.c
--- a/sys/arch/arm/imx/fdt/imx6_sdhc.c  Wed Oct 23 02:34:43 2019 +0000
+++ b/sys/arch/arm/imx/fdt/imx6_sdhc.c  Wed Oct 23 05:20:52 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: imx6_sdhc.c,v 1.3 2019/09/27 02:54:57 hkenken Exp $    */
+/*     $NetBSD: imx6_sdhc.c,v 1.4 2019/10/23 05:20:52 hkenken Exp $    */
 /*-
  * Copyright (c) 2019 Genetec Corporation.  All rights reserved.
  * Written by Hashimoto Kenichi for Genetec Corporation.
@@ -25,7 +25,7 @@
  * SUCH DAMAGE.
  */
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: imx6_sdhc.c,v 1.3 2019/09/27 02:54:57 hkenken Exp $");
+__KERNEL_RCSID(0, "$NetBSD: imx6_sdhc.c,v 1.4 2019/10/23 05:20:52 hkenken Exp $");
 
 #include "opt_fdt.h"
 
@@ -120,10 +120,13 @@
            SDHC_FLAG_32BIT_ACCESS |
            SDHC_FLAG_USE_ADMA2 |
            SDHC_FLAG_USDHC |
-           SDHC_FLAG_NO_BUSY_INTR;
+           SDHC_FLAG_NO_BUSY_INTR |
+           SDHC_FLAG_BROKEN_ADMA2_ZEROLEN;
 
        if (bus_width == 8)
                sc->sc_sdhc.sc_flags |= SDHC_FLAG_8BIT_MODE;
+       if (of_hasprop(faa->faa_phandle, "no-1-8-v"))
+               sc->sc_sdhc.sc_flags |= SDHC_FLAG_NO_1_8_V;
 
        sc->sc_sdhc.sc_host = &sc->sc_host;
 
diff -r 4265f5c08a17 -r c4e872a99edc sys/dev/sdmmc/sdhc.c
--- a/sys/dev/sdmmc/sdhc.c      Wed Oct 23 02:34:43 2019 +0000
+++ b/sys/dev/sdmmc/sdhc.c      Wed Oct 23 05:20:52 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sdhc.c,v 1.103 2019/07/03 23:10:08 jmcneill Exp $      */
+/*     $NetBSD: sdhc.c,v 1.104 2019/10/23 05:20:52 hkenken Exp $       */
 /*     $OpenBSD: sdhc.c,v 1.25 2009/01/13 19:44:20 grange Exp $        */
 
 /*
@@ -23,7 +23,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sdhc.c,v 1.103 2019/07/03 23:10:08 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sdhc.c,v 1.104 2019/10/23 05:20:52 hkenken Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_sdmmc.h"
@@ -476,21 +476,23 @@
                SET(hp->ocr, MMC_OCR_HCS);
                aprint_normal(" HS");
        }
-       if (ISSET(caps2, SDHC_SDR50_SUPP)) {
-               SET(hp->ocr, MMC_OCR_S18A);
-               aprint_normal(" SDR50");
-       }
-       if (ISSET(caps2, SDHC_DDR50_SUPP)) {
-               SET(hp->ocr, MMC_OCR_S18A);
-               aprint_normal(" DDR50");
-       }
-       if (ISSET(caps2, SDHC_SDR104_SUPP)) {
-               SET(hp->ocr, MMC_OCR_S18A);
-               aprint_normal(" SDR104 HS200");
-       }
-       if (ISSET(caps, SDHC_VOLTAGE_SUPP_1_8V)) {
-               SET(hp->ocr, MMC_OCR_1_65V_1_95V);
-               aprint_normal(" 1.8V");
+       if (!ISSET(hp->sc->sc_flags, SDHC_FLAG_NO_1_8_V)) {
+               if (ISSET(caps2, SDHC_SDR50_SUPP)) {
+                       SET(hp->ocr, MMC_OCR_S18A);
+                       aprint_normal(" SDR50");
+               }
+               if (ISSET(caps2, SDHC_DDR50_SUPP)) {
+                       SET(hp->ocr, MMC_OCR_S18A);
+                       aprint_normal(" DDR50");
+               }
+               if (ISSET(caps2, SDHC_SDR104_SUPP)) {
+                       SET(hp->ocr, MMC_OCR_S18A);
+                       aprint_normal(" SDR104 HS200");
+               }
+               if (ISSET(caps, SDHC_VOLTAGE_SUPP_1_8V)) {
+                       SET(hp->ocr, MMC_OCR_1_65V_1_95V);
+                       aprint_normal(" 1.8V");
+               }
        }
        if (ISSET(caps, SDHC_VOLTAGE_SUPP_3_0V)) {
                SET(hp->ocr, MMC_OCR_2_9V_3_0V | MMC_OCR_3_0V_3_1V);
@@ -620,6 +622,10 @@
                saa.saa_caps |= SMC_CAPS_SINGLE_ONLY;
        if (ISSET(sc->sc_flags, SDHC_FLAG_POLL_CARD_DET))
                saa.saa_caps |= SMC_CAPS_POLL_CARD_DET;
+
+       if (ISSET(sc->sc_flags, SDHC_FLAG_BROKEN_ADMA2_ZEROLEN))
+               saa.saa_max_seg = 65535;
+
        hp->sdmmc = config_found(sc->sc_dev, &saa, sdhc_cfprint);
 
        return 0;
@@ -1818,12 +1824,9 @@
                if (ISSET(hp->sc->sc_flags, SDHC_FLAG_USDHC)) {
                        /* mode bits is in MIX_CTRL register on uSDHC */
                        HWRITE4(hp, SDHC_MIX_CTRL, mode |
-                           (HREAD4(hp, SDHC_MIX_CTRL) &
-                           ~(SDHC_MULTI_BLOCK_MODE |
-                           SDHC_READ_MODE |
-                           SDHC_AUTO_CMD12_ENABLE |
-                           SDHC_BLOCK_COUNT_ENABLE |
-                           SDHC_DMA_ENABLE)));
+                           (HREAD4(hp, SDHC_MIX_CTRL) & ~SDHC_TRANSFER_MODE_MASK));
+                       if (cmd->c_opcode == MMC_STOP_TRANSMISSION)
+                               command |= SDHC_COMMAND_TYPE_ABORT;
                        HWRITE4(hp, SDHC_TRANSFER_MODE, command << 16);
                } else {
                        HWRITE4(hp, SDHC_TRANSFER_MODE, mode | (command << 16));
diff -r 4265f5c08a17 -r c4e872a99edc sys/dev/sdmmc/sdhcreg.h
--- a/sys/dev/sdmmc/sdhcreg.h   Wed Oct 23 02:34:43 2019 +0000
+++ b/sys/dev/sdmmc/sdhcreg.h   Wed Oct 23 05:20:52 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sdhcreg.h,v 1.19 2017/06/23 08:43:59 ryo Exp $ */
+/*     $NetBSD: sdhcreg.h,v 1.20 2019/10/23 05:20:52 hkenken Exp $     */
 /*     $OpenBSD: sdhcreg.h,v 1.4 2006/07/30 17:20:40 fgsch Exp $       */
 
 /*
@@ -29,6 +29,7 @@
 #define  SDHC_BLOCK_COUNT_MAX          512
 #define SDHC_ARGUMENT                  0x08
 #define SDHC_TRANSFER_MODE             0x0c
+#define  SDHC_TRANSFER_MODE_MASK       0xb7
 #define  SDHC_MULTI_BLOCK_MODE         (1<<5)
 #define  SDHC_READ_MODE                        (1<<4)
 #define  SDHC_AUTO_CMD12_ENABLE                (1<<2)
@@ -228,6 +229,7 @@
 #define SDHC_DMA_CTL                   0x40c   /* eSDHC */
 #define  SDHC_DMA_SNOOP                        0x40
 #define SDHC_MIX_CTRL                  0x48    /* uSDHC */
+#define  SDHC_USDHC_NIBBLE_POS                 (1<<6)
 #define  SDHC_USDHC_DDR_EN                     (1<<3)
 #define SDHC_VEND_SPEC                 0xc0    /* uSDHC */
 #define  SDHC_VEND_SPEC_MBO                    (1<<29)
diff -r 4265f5c08a17 -r c4e872a99edc sys/dev/sdmmc/sdhcvar.h
--- a/sys/dev/sdmmc/sdhcvar.h   Wed Oct 23 02:34:43 2019 +0000
+++ b/sys/dev/sdmmc/sdhcvar.h   Wed Oct 23 05:20:52 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sdhcvar.h,v 1.30 2019/03/13 12:16:49 jmcneill Exp $    */
+/*     $NetBSD: sdhcvar.h,v 1.31 2019/10/23 05:20:52 hkenken Exp $     */
 /*     $OpenBSD: sdhcvar.h,v 1.3 2007/09/06 08:01:01 jsg Exp $ */
 
 /*
@@ -62,6 +62,11 @@
 #define        SDHC_FLAG_NO_AUTO_STOP  0x01000000 /* No auto CMD12 */
 #define        SDHC_FLAG_NO_BUSY_INTR  0x02000000 /* No intr when RESP_BUSY */
 #define        SDHC_FLAG_STOP_WITH_TC  0x04000000 /* CMD12 can set xfer complete w/o SCF_RSP_BSY */
+#define        SDHC_FLAG_BROKEN_ADMA2_ZEROLEN 0x08000000 /*
+                                                  * Broken ADMA2 zero length descriptor
+                                                  * Can't 64K Byte data transfer
+                                                  */
+#define        SDHC_FLAG_NO_1_8_V      0x10000000 /* No 1.8V supply */
 
        uint32_t                sc_clkbase;
        int                     sc_clkmsk;      /* Mask for SDCLK */
diff -r 4265f5c08a17 -r c4e872a99edc sys/dev/sdmmc/sdmmc.c
--- a/sys/dev/sdmmc/sdmmc.c     Wed Oct 23 02:34:43 2019 +0000
+++ b/sys/dev/sdmmc/sdmmc.c     Wed Oct 23 05:20:52 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sdmmc.c,v 1.37 2019/09/01 05:45:42 mlelstv Exp $       */
+/*     $NetBSD: sdmmc.c,v 1.38 2019/10/23 05:20:52 hkenken Exp $       */
 /*     $OpenBSD: sdmmc.c,v 1.18 2009/01/09 10:58:38 jsg Exp $  */
 
 /*
@@ -49,7 +49,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sdmmc.c,v 1.37 2019/09/01 05:45:42 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sdmmc.c,v 1.38 2019/10/23 05:20:52 hkenken Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_sdmmc.h"
@@ -130,10 +130,11 @@
        sc->sc_busclk = sc->sc_clkmax;
        sc->sc_buswidth = 1;
        sc->sc_caps = saa->saa_caps;
+       sc->sc_max_seg = saa->saa_max_seg ? saa->saa_max_seg : MAXPHYS;
 
        if (ISSET(sc->sc_caps, SMC_CAPS_DMA)) {
                error = bus_dmamap_create(sc->sc_dmat, MAXPHYS, SDMMC_MAXNSEGS,
-                   MAXPHYS, 0, BUS_DMA_NOWAIT|BUS_DMA_ALLOCNOW, &sc->sc_dmap);
+                   sc->sc_max_seg, 0, BUS_DMA_NOWAIT|BUS_DMA_ALLOCNOW, &sc->sc_dmap);
                if (error) {
                        aprint_error_dev(sc->sc_dev,
                            "couldn't create dma map. (error=%d)\n", error);
diff -r 4265f5c08a17 -r c4e872a99edc sys/dev/sdmmc/sdmmcchip.h
--- a/sys/dev/sdmmc/sdmmcchip.h Wed Oct 23 02:34:43 2019 +0000
+++ b/sys/dev/sdmmc/sdmmcchip.h Wed Oct 23 05:20:52 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sdmmcchip.h,v 1.9 2017/02/17 10:51:48 nonaka Exp $     */
+/*     $NetBSD: sdmmcchip.h,v 1.10 2019/10/23 05:20:52 hkenken Exp $   */
 /*     $OpenBSD: sdmmcchip.h,v 1.3 2007/05/31 10:09:01 uwe Exp $       */
 
 /*
@@ -137,6 +137,7 @@
        u_int                   saa_clkmin;
        u_int                   saa_clkmax;
        uint32_t                saa_caps;       /* see sdmmc_softc.sc_caps */
+       uint32_t                saa_max_seg;
 };
 
 void   sdmmc_needs_discover(device_t);
diff -r 4265f5c08a17 -r c4e872a99edc sys/dev/sdmmc/sdmmcvar.h
--- a/sys/dev/sdmmc/sdmmcvar.h  Wed Oct 23 02:34:43 2019 +0000
+++ b/sys/dev/sdmmc/sdmmcvar.h  Wed Oct 23 05:20:52 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sdmmcvar.h,v 1.31 2019/09/01 05:45:42 mlelstv Exp $    */
+/*     $NetBSD: sdmmcvar.h,v 1.32 2019/10/23 05:20:52 hkenken Exp $    */
 /*     $OpenBSD: sdmmcvar.h,v 1.13 2009/01/09 10:55:22 jsg Exp $       */
 
 /*
@@ -291,6 +291,8 @@
        struct evcnt sc_ev_xfer_aligned[8]; /* aligned xfer counts */
        struct evcnt sc_ev_xfer_unaligned; /* unaligned xfer count */
        struct evcnt sc_ev_xfer_error;  /* error xfer count */
+
+       uint32_t sc_max_seg;            /* maximum segment size */
 };
 
 /*



Home | Main Index | Thread Index | Old Index