rk: restore file mode
[firefly-linux-kernel-4.4.55.git] / drivers / mmc / core / bus.c
index 704bf66f58733a036bf79bfc4ef585f29acb7626..0669ed0d73b425d25053a9f5cb8fbdaa4e548ed4 100644 (file)
@@ -127,17 +127,18 @@ static void mmc_bus_shutdown(struct device *dev)
        struct mmc_driver *drv = to_mmc_driver(dev->driver);
        struct mmc_card *card = mmc_dev_to_card(dev);
        struct mmc_host *host = card->host;
-       int ret;
+       int ret = 0;
 
        if (dev->driver && drv->shutdown)
-               drv->shutdown(card);
+           drv->shutdown(card);
 
-       if (host->bus_ops->shutdown) {
-               ret = host->bus_ops->shutdown(host);
-               if (ret)
-                       pr_warn("%s: error %d during shutdown\n",
-                               mmc_hostname(host), ret);
+    if (host->bus_ops->shutdown) {
+        ret = host->bus_ops->shutdown(host);
+
+        if (ret)
+            pr_warn("%s: error %d during shutdown\n",mmc_hostname(host), ret);
        }
+
 }
 
 #ifdef CONFIG_PM_SLEEP
@@ -146,15 +147,16 @@ static int mmc_bus_suspend(struct device *dev)
        struct mmc_driver *drv = to_mmc_driver(dev->driver);
        struct mmc_card *card = mmc_dev_to_card(dev);
        struct mmc_host *host = card->host;
-       int ret;
+       int ret = 0;
 
        if (dev->driver && drv->suspend) {
                ret = drv->suspend(card);
                if (ret)
                        return ret;
        }
-
-       ret = host->bus_ops->suspend(host);
+       
+    if(host->bus_ops->suspend)
+           ret = host->bus_ops->suspend(host);
        return ret;
 }
 
@@ -163,13 +165,15 @@ static int mmc_bus_resume(struct device *dev)
        struct mmc_driver *drv = to_mmc_driver(dev->driver);
        struct mmc_card *card = mmc_dev_to_card(dev);
        struct mmc_host *host = card->host;
-       int ret;
-
-       ret = host->bus_ops->resume(host);
-       if (ret)
-               pr_warn("%s: error %d during resume (card was removed?)\n",
-                       mmc_hostname(host), ret);
+       int ret = 0;
 
+    if(host->bus_ops->resume){
+           ret = host->bus_ops->resume(host);
+           if (ret)
+                   pr_warn("%s: error %d during resume (card was removed?)\n",
+                           mmc_hostname(host), ret);
+    }
+    
        if (dev->driver && drv->resume)
                ret = drv->resume(card);
 
@@ -340,7 +344,7 @@ int mmc_add_card(struct mmc_card *card)
                break;
        }
 
-       if (mmc_sd_card_uhs(card) &&
+       if (mmc_card_uhs(card) &&
                (card->sd_bus_speed < ARRAY_SIZE(uhs_speeds)))
                uhs_bus_speed_mode = uhs_speeds[card->sd_bus_speed];