mmc: dw_mmc: allow probe to succeed even if one slot is initialized
authorThomas Abraham <thomas.abraham@linaro.org>
Mon, 17 Sep 2012 18:16:37 +0000 (18:16 +0000)
committerChris Ball <cjb@laptop.org>
Wed, 3 Oct 2012 14:05:15 +0000 (10:05 -0400)
Instead of aborting the probe when a slot initialization fails, allow
initialization of as many slots as possible. If there is at least one
instance of a slot that is successfully initialized, allow the driver
probe to succeed.

Signed-off-by: Thomas Abraham <thomas.abraham@linaro.org>
Acked-by: Will Newton <will.newton@imgtec.com>
Signed-off-by: Chris Ball <cjb@laptop.org>
drivers/mmc/host/dw_mmc.c

index a18e73c7305ea3075d5d47786b095d9a4df199b1..227c42ef18c5d818f1cef80cb728ce220f5e1718 100644 (file)
@@ -1946,6 +1946,7 @@ int dw_mci_probe(struct dw_mci *host)
 {
        int width, i, ret = 0;
        u32 fifo_size;
+       int init_slots = 0;
 
        if (!host->pdata || !host->pdata->init) {
                dev_err(host->dev,
@@ -2054,10 +2055,18 @@ int dw_mci_probe(struct dw_mci *host)
        /* We need at least one slot to succeed */
        for (i = 0; i < host->num_slots; i++) {
                ret = dw_mci_init_slot(host, i);
-               if (ret) {
-                       ret = -ENODEV;
-                       goto err_init_slot;
-               }
+               if (ret)
+                       dev_dbg(host->dev, "slot %d init failed\n", i);
+               else
+                       init_slots++;
+       }
+
+       if (init_slots) {
+               dev_info(host->dev, "%d slots initialized\n", init_slots);
+       } else {
+               dev_dbg(host->dev, "attempted to initialize %d slots, "
+                                       "but failed on all\n", host->num_slots);
+               goto err_init_slot;
        }
 
        /*
@@ -2092,12 +2101,6 @@ int dw_mci_probe(struct dw_mci *host)
        return 0;
 
 err_init_slot:
-       /* De-init any initialized slots */
-       while (i > 0) {
-               if (host->slot[i])
-                       dw_mci_cleanup_slot(host->slot[i], i);
-               i--;
-       }
        free_irq(host->irq, host);
 
 err_workqueue: