|
@@ -29,6 +29,7 @@
|
|
|
#include <linux/mmc/host.h>
|
|
|
#include <linux/platform_device.h>
|
|
|
#include <linux/platform_data/brcmfmac-sdio.h>
|
|
|
+#include <linux/pm_runtime.h>
|
|
|
#include <linux/suspend.h>
|
|
|
#include <linux/errno.h>
|
|
|
#include <linux/module.h>
|
|
@@ -1006,6 +1007,7 @@ static int brcmf_sdiod_remove(struct brcmf_sdio_dev *sdiodev)
|
|
|
sg_free_table(&sdiodev->sgtable);
|
|
|
sdiodev->sbwad = 0;
|
|
|
|
|
|
+ pm_runtime_allow(sdiodev->func[1]->card->host->parent);
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
@@ -1074,7 +1076,7 @@ static int brcmf_sdiod_probe(struct brcmf_sdio_dev *sdiodev)
|
|
|
ret = -ENODEV;
|
|
|
goto out;
|
|
|
}
|
|
|
-
|
|
|
+ pm_runtime_forbid(host->parent);
|
|
|
out:
|
|
|
if (ret)
|
|
|
brcmf_sdiod_remove(sdiodev);
|