mmc: core: Share internal function to set initial signal voltage
authorUlf Hansson <ulf.hansson@linaro.org>
Thu, 5 Apr 2018 19:24:15 +0000 (21:24 +0200)
committerUlf Hansson <ulf.hansson@linaro.org>
Tue, 8 May 2018 07:33:50 +0000 (09:33 +0200)
Move the corresponding code for setting the initial signal voltage, from
mmc_power_up() into a new function, mmc_set_initial_signal_voltage().

Make the function internally available to the mmc core, as to allow the
following changes to make use of it.

Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
Tested-by: Quentin Schulz <quentin.schulz@bootlin.com>
Reviewed-by: Shawn Lin <shawn.lin@rock-chips.com>
drivers/mmc/core/core.c
drivers/mmc/core/core.h

index 7a79dc1599e5bd0ef45f314a6dd0e3b9287ef954..2c1a220531c4b0f6152065687ab3306188c34cae 100644 (file)
@@ -1484,6 +1484,17 @@ int mmc_set_signal_voltage(struct mmc_host *host, int signal_voltage)
 
 }
 
+void mmc_set_initial_signal_voltage(struct mmc_host *host)
+{
+       /* Try to set signal voltage to 3.3V but fall back to 1.8v or 1.2v */
+       if (!mmc_set_signal_voltage(host, MMC_SIGNAL_VOLTAGE_330))
+               dev_dbg(mmc_dev(host), "Initial signal voltage of 3.3v\n");
+       else if (!mmc_set_signal_voltage(host, MMC_SIGNAL_VOLTAGE_180))
+               dev_dbg(mmc_dev(host), "Initial signal voltage of 1.8v\n");
+       else if (!mmc_set_signal_voltage(host, MMC_SIGNAL_VOLTAGE_120))
+               dev_dbg(mmc_dev(host), "Initial signal voltage of 1.2v\n");
+}
+
 int mmc_host_set_uhs_voltage(struct mmc_host *host)
 {
        u32 clock;
@@ -1646,13 +1657,7 @@ void mmc_power_up(struct mmc_host *host, u32 ocr)
        /* Set initial state and call mmc_set_ios */
        mmc_set_initial_state(host);
 
-       /* Try to set signal voltage to 3.3V but fall back to 1.8v or 1.2v */
-       if (!mmc_set_signal_voltage(host, MMC_SIGNAL_VOLTAGE_330))
-               dev_dbg(mmc_dev(host), "Initial signal voltage of 3.3v\n");
-       else if (!mmc_set_signal_voltage(host, MMC_SIGNAL_VOLTAGE_180))
-               dev_dbg(mmc_dev(host), "Initial signal voltage of 1.8v\n");
-       else if (!mmc_set_signal_voltage(host, MMC_SIGNAL_VOLTAGE_120))
-               dev_dbg(mmc_dev(host), "Initial signal voltage of 1.2v\n");
+       mmc_set_initial_signal_voltage(host);
 
        /*
         * This delay should be sufficient to allow the power supply
index a141ec0e1ccc58ed96d05b49a3f4efc999a28e40..9d8f09ac0821ad7cd112880a6fc1587fda7c08e5 100644 (file)
@@ -52,6 +52,7 @@ u32 mmc_select_voltage(struct mmc_host *host, u32 ocr);
 int mmc_set_uhs_voltage(struct mmc_host *host, u32 ocr);
 int mmc_host_set_uhs_voltage(struct mmc_host *host);
 int mmc_set_signal_voltage(struct mmc_host *host, int signal_voltage);
+void mmc_set_initial_signal_voltage(struct mmc_host *host);
 void mmc_set_timing(struct mmc_host *host, unsigned int timing);
 void mmc_set_driver_type(struct mmc_host *host, unsigned int drv_type);
 int mmc_select_drive_strength(struct mmc_card *card, unsigned int max_dtr,