]> git.ipfire.org Git - people/ms/linux.git/commitdiff
mmc: core: set initial signal voltage on power off
authorJonas Karlman <jonas@kwiboo.se>
Sun, 17 Feb 2019 22:14:38 +0000 (22:14 +0000)
committerMichael Tremer <michael.tremer@ipfire.org>
Wed, 28 Sep 2022 09:40:03 +0000 (09:40 +0000)
Some boards have SD card connectors where the power rail cannot be switched
off by the driver. If the card has not been power cycled, it may still be
using 1.8V signaling after a warm re-boot. Bootroms expecting 3.3V signaling
will fail to boot from a UHS card that continue to use 1.8V signaling.

Set initial signal voltage in mmc_power_off() to allow re-boot to function.

This fixes re-boot with UHS cards on Asus Tinker Board (Rockchip RK3288),
same issue have been seen on some Rockchip RK3399 boards.

I am sending this as a RFC because I have no insights into SD/MMC subsystem,
this change fix a re-boot issue on my boards and does not break emmc/sdio.
Is this an acceptable workaround? Any advice is appreciated.

Signed-off-by: Jonas Karlman <jonas@kwiboo.se>
drivers/mmc/core/core.c

index ef53a25788248ed6d57472f7a9cf26ee979f254e..d4c53074154a51ca68538c4e1da824263fd22ff9 100644 (file)
@@ -1358,6 +1358,14 @@ void mmc_power_off(struct mmc_host *host)
        if (host->ios.power_mode == MMC_POWER_OFF)
                return;
 
+       mmc_set_initial_signal_voltage(host);
+
+       /*
+        * This delay should be sufficient to allow the power supply
+        * to reach the minimum voltage.
+        */
+       mmc_delay(host->ios.power_delay_ms);
+
        mmc_pwrseq_power_off(host);
 
        host->ios.clock = 0;