]> git.ipfire.org Git - people/arne_f/kernel.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)
committerArne Fitzenreiter <arne_f@ipfire.org>
Mon, 12 Dec 2022 17:45:49 +0000 (18:45 +0100)
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 de1cc9e1ae57638e97d7f0d8bf8617e40036b794..abf7a9e37646bde2ff96ffe6b8270ddc36238596 100644 (file)
@@ -1364,6 +1364,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;