mmc: sdio: Fix enable_hs and enable_wide in sdio_reset_comm()
authorDmitry Shmidt <dimitrysh@google.com>
Thu, 7 Oct 2010 00:25:02 +0000 (17:25 -0700)
committerJohn Stultz <john.stultz@linaro.org>
Tue, 16 Feb 2016 21:51:07 +0000 (13:51 -0800)
Signed-off-by: Dmitry Shmidt <dimitrysh@google.com>
drivers/mmc/core/sdio.c

index dbee1606b2fba9167006e8a9400d680ac4ce492a..915ff424669a2cc9071c9c3bd6d52a6900259931 100644 (file)
@@ -1248,7 +1248,7 @@ int sdio_reset_comm(struct mmc_card *card)
        if (mmc_host_is_spi(host)) {
                err = mmc_spi_set_crc(host, use_spi_crc);
                if (err)
-               goto err;
+                       goto err;
        }
 
        if (!mmc_host_is_spi(host)) {
@@ -1267,27 +1267,22 @@ int sdio_reset_comm(struct mmc_card *card)
         * Switch to high-speed (if supported).
         */
        err = sdio_enable_hs(card);
-       if (err)
+       if (err > 0)
+               mmc_sd_go_highspeed(card);
+       else if (err)
                goto err;
 
        /*
         * Change to the card's maximum speed.
         */
-       if (mmc_card_highspeed(card)) {
-               /*
-                * The SDIO specification doesn't mention how
-                * the CIS transfer speed register relates to
-                * high-speed, but it seems that 50 MHz is
-                * mandatory.
-                */
-               mmc_set_clock(host, 50000000);
-       } else {
-               mmc_set_clock(host, card->cis.max_dtr);
-       }
+       mmc_set_clock(host, mmc_sdio_get_max_clock(card));
 
-       err = sdio_enable_wide(card);
-       if (err)
+       err = sdio_enable_4bit_bus(card);
+       if (err > 0)
+               mmc_set_bus_width(host, MMC_BUS_WIDTH_4);
+       else if (err)
                goto err;
+
        mmc_release_host(host);
        return 0;
 err: