mmc: Add a deferred_probe() API
authorFaiz Abbas <faiz_abbas@ti.com>
Wed, 26 Feb 2020 08:14:30 +0000 (13:44 +0530)
committerPeng Fan <peng.fan@nxp.com>
Mon, 9 Mar 2020 00:33:15 +0000 (08:33 +0800)
Add a deferred_probe() API for platforms that want to do some
configurations just before starting to enumerate the device.

Signed-off-by: Faiz Abbas <faiz_abbas@ti.com>
drivers/mmc/mmc-uclass.c
drivers/mmc/mmc.c
include/mmc.h

index 0b90a97650148da0b05a96e6c1a5c39b246210c5..c75892a72c117a22440f0fb8ee87d6265debe26f 100644 (file)
@@ -138,6 +138,21 @@ int mmc_host_power_cycle(struct mmc *mmc)
        return dm_mmc_host_power_cycle(mmc->dev);
 }
 
+int dm_mmc_deferred_probe(struct udevice *dev)
+{
+       struct dm_mmc_ops *ops = mmc_get_ops(dev);
+
+       if (ops->deferred_probe)
+               return ops->deferred_probe(dev);
+
+       return 0;
+}
+
+int mmc_deferred_probe(struct mmc *mmc)
+{
+       return dm_mmc_deferred_probe(mmc->dev);
+}
+
 int mmc_of_parse(struct udevice *dev, struct mmc_config *cfg)
 {
        int val;
index b50fcbf6cf55c66e69aea43a97ab990ead359887..a347308976fe925630253a3d71c0a718bd94ce4f 100644 (file)
@@ -2845,7 +2845,9 @@ int mmc_start_init(struct mmc *mmc)
         */
        mmc->host_caps = mmc->cfg->host_caps | MMC_CAP(SD_LEGACY) |
                         MMC_CAP(MMC_LEGACY) | MMC_MODE_1BIT;
-
+#if CONFIG_IS_ENABLED(DM_MMC)
+       mmc_deferred_probe(mmc);
+#endif
 #if !defined(CONFIG_MMC_BROKEN_CD)
        no_card = mmc_getcd(mmc) == 0;
 #else
index 8a9ea0bf9866929f35285f5a112816f0ac53c485..be59ee742b4c5392f370385ff4f8bf98455118da 100644 (file)
@@ -409,6 +409,14 @@ struct mmc;
 
 #if CONFIG_IS_ENABLED(DM_MMC)
 struct dm_mmc_ops {
+       /**
+        * deferred_probe() - Some configurations that need to be deferred
+        * to just before enumerating the device
+        *
+        * @dev:        Device to init
+        * @return 0 if Ok, -ve if error
+        */
+       int (*deferred_probe)(struct udevice *dev);
        /**
         * send_cmd() - Send a command to the MMC device
         *
@@ -492,6 +500,7 @@ int dm_mmc_get_wp(struct udevice *dev);
 int dm_mmc_execute_tuning(struct udevice *dev, uint opcode);
 int dm_mmc_wait_dat0(struct udevice *dev, int state, int timeout_us);
 int dm_mmc_host_power_cycle(struct udevice *dev);
+int dm_mmc_deferred_probe(struct udevice *dev);
 
 /* Transition functions for compatibility */
 int mmc_set_ios(struct mmc *mmc);
@@ -501,6 +510,7 @@ int mmc_execute_tuning(struct mmc *mmc, uint opcode);
 int mmc_wait_dat0(struct mmc *mmc, int state, int timeout_us);
 int mmc_set_enhanced_strobe(struct mmc *mmc);
 int mmc_host_power_cycle(struct mmc *mmc);
+int mmc_deferred_probe(struct mmc *mmc);
 
 #else
 struct mmc_ops {