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 flags SDHC_FLAG_NO_AUTO_STOP and SDHC_FLAG...



details:   https://anonhg.NetBSD.org/src/rev/6e0a3f2a1fa8
branches:  trunk
changeset: 820331:6e0a3f2a1fa8
user:      kiyohara <kiyohara%NetBSD.org@localhost>
date:      Sat Jan 07 15:05:08 2017 +0000

description:
Add flags SDHC_FLAG_NO_AUTO_STOP and SDHC_FLAG_NO_BUSY_INTR.

diffstat:

 sys/dev/sdmmc/sdhc.c    |  18 +++++++++++++-----
 sys/dev/sdmmc/sdhcvar.h |   4 +++-
 2 files changed, 16 insertions(+), 6 deletions(-)

diffs (78 lines):

diff -r ddbcf052a197 -r 6e0a3f2a1fa8 sys/dev/sdmmc/sdhc.c
--- a/sys/dev/sdmmc/sdhc.c      Sat Jan 07 15:00:38 2017 +0000
+++ b/sys/dev/sdmmc/sdhc.c      Sat Jan 07 15:05:08 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sdhc.c,v 1.96 2017/01/07 15:00:38 kiyohara Exp $       */
+/*     $NetBSD: sdhc.c,v 1.97 2017/01/07 15:05:08 kiyohara 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.96 2017/01/07 15:00:38 kiyohara Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sdhc.c,v 1.97 2017/01/07 15:05:08 kiyohara Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_sdmmc.h"
@@ -595,7 +595,9 @@
                saa.saa_clkmin = hp->clkbase / 0x3ff;
        else
                saa.saa_clkmin = hp->clkbase / 256;
-       saa.saa_caps = SMC_CAPS_4BIT_MODE|SMC_CAPS_AUTO_STOP;
+       if (!ISSET(sc->sc_flags, SDHC_FLAG_NO_AUTO_STOP))
+               saa.saa_caps |= SMC_CAPS_AUTO_STOP;
+       saa.saa_caps |= SMC_CAPS_4BIT_MODE;
        if (ISSET(sc->sc_flags, SDHC_FLAG_8BIT_MODE))
                saa.saa_caps |= SMC_CAPS_8BIT_MODE;
        if (ISSET(caps, SDHC_HIGH_SPEED_SUPP))
@@ -1572,7 +1574,8 @@
        if (cmd->c_error == 0 && cmd->c_data != NULL)
                sdhc_transfer_data(hp, cmd);
        else if (ISSET(cmd->c_flags, SCF_RSP_BSY)) {
-               if (!sdhc_wait_intr(hp, SDHC_TRANSFER_COMPLETE, hz * 10, false)) {
+               if (!ISSET(hp->sc->sc_flags, SDHC_FLAG_NO_BUSY_INTR) &&
+                   !sdhc_wait_intr(hp, SDHC_TRANSFER_COMPLETE, hz * 10, false)) {
                        DPRINTF(1,("%s: sdhc_exec_command: RSP_BSY\n",
                            HDEVNAME(hp)));
                        cmd->c_error = ETIMEDOUT;
@@ -1588,6 +1591,10 @@
        }
        SET(cmd->c_flags, SCF_ITSDONE);
 
+       if (ISSET(hp->sc->sc_flags, SDHC_FLAG_NO_AUTO_STOP) &&
+           cmd->c_opcode == MMC_STOP_TRANSMISSION)
+               (void)sdhc_soft_reset(hp, SDHC_RESET_CMD|SDHC_RESET_DAT);
+
        mutex_exit(&hp->intr_lock);
 
        DPRINTF(1,("%s: cmd %d %s (flags=%08x error=%d)\n", HDEVNAME(hp),
@@ -1642,7 +1649,8 @@
        if (blkcount > 1) {
                mode |= SDHC_MULTI_BLOCK_MODE;
                /* XXX only for memory commands? */
-               mode |= SDHC_AUTO_CMD12_ENABLE;
+               if (!ISSET(sc->sc_flags, SDHC_FLAG_NO_AUTO_STOP))
+                       mode |= SDHC_AUTO_CMD12_ENABLE;
        }
        if (cmd->c_dmamap != NULL && cmd->c_datalen > 0 &&
            ISSET(hp->flags,  SHF_MODE_DMAEN)) {
diff -r ddbcf052a197 -r 6e0a3f2a1fa8 sys/dev/sdmmc/sdhcvar.h
--- a/sys/dev/sdmmc/sdhcvar.h   Sat Jan 07 15:00:38 2017 +0000
+++ b/sys/dev/sdmmc/sdhcvar.h   Sat Jan 07 15:05:08 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sdhcvar.h,v 1.26 2015/12/31 11:53:19 ryo Exp $ */
+/*     $NetBSD: sdhcvar.h,v 1.27 2017/01/07 15:05:08 kiyohara Exp $    */
 /*     $OpenBSD: sdhcvar.h,v 1.3 2007/09/06 08:01:01 jsg Exp $ */
 
 /*
@@ -59,6 +59,8 @@
 #define        SDHC_FLAG_POLL_CARD_DET 0x00200000 /* polling card detect */
 #define        SDHC_FLAG_SLOW_SDR50    0x00400000 /* reduce SDR50 speed */
 #define        SDHC_FLAG_USDHC         0x00800000 /* Freescale uSDHC */
+#define        SDHC_FLAG_NO_AUTO_STOP  0x01000000 /* No auto CMD12 */
+#define        SDHC_FLAG_NO_BUSY_INTR  0x02000000 /* No intr when RESP_BUSY */
 
        uint32_t                sc_clkbase;
        int                     sc_clkmsk;      /* Mask for SDCLK */



Home | Main Index | Thread Index | Old Index