diff options
author | Arend van Spriel <arend@broadcom.com> | 2015-03-18 08:25:21 -0400 |
---|---|---|
committer | Kalle Valo <kvalo@codeaurora.org> | 2015-03-20 03:03:23 -0400 |
commit | 063d51776bd60ebf2587682eb394851c792e58d9 (patch) | |
tree | 60a976145fdb3fffe5138f239fa09a13377e4bdd /drivers/net/wireless | |
parent | bb408cc78401c53842e17b24b6433c122629f21f (diff) |
brcmfmac: avoid runtime-pm for sdio host controller
Several host controllers supporting runtime-pm are causing issues
with our sdio wireless cards because they disable the sdio interrupt
upon going into runtime suspend. This patch avoids that by doing
a pm_runtime_forbid() call during the probe. Tested with Sony Vaio
Duo 13 which uses sdhci-acpi host controller.
Reviewed-by: Hante Meuleman <meuleman@broadcom.com>
Reviewed-by: Franky (Zhenhui) Lin <frankyl@broadcom.com>
Reviewed-by: Pieter-Paul Giesberts <pieterpg@broadcom.com>
Signed-off-by: Arend van Spriel <arend@broadcom.com>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r-- | drivers/net/wireless/brcm80211/brcmfmac/bcmsdh.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/net/wireless/brcm80211/brcmfmac/bcmsdh.c b/drivers/net/wireless/brcm80211/brcmfmac/bcmsdh.c index 43995308307d..9667b6aabc00 100644 --- a/drivers/net/wireless/brcm80211/brcmfmac/bcmsdh.c +++ b/drivers/net/wireless/brcm80211/brcmfmac/bcmsdh.c | |||
@@ -29,6 +29,7 @@ | |||
29 | #include <linux/mmc/host.h> | 29 | #include <linux/mmc/host.h> |
30 | #include <linux/platform_device.h> | 30 | #include <linux/platform_device.h> |
31 | #include <linux/platform_data/brcmfmac-sdio.h> | 31 | #include <linux/platform_data/brcmfmac-sdio.h> |
32 | #include <linux/pm_runtime.h> | ||
32 | #include <linux/suspend.h> | 33 | #include <linux/suspend.h> |
33 | #include <linux/errno.h> | 34 | #include <linux/errno.h> |
34 | #include <linux/module.h> | 35 | #include <linux/module.h> |
@@ -1006,6 +1007,7 @@ static int brcmf_sdiod_remove(struct brcmf_sdio_dev *sdiodev) | |||
1006 | sg_free_table(&sdiodev->sgtable); | 1007 | sg_free_table(&sdiodev->sgtable); |
1007 | sdiodev->sbwad = 0; | 1008 | sdiodev->sbwad = 0; |
1008 | 1009 | ||
1010 | pm_runtime_allow(sdiodev->func[1]->card->host->parent); | ||
1009 | return 0; | 1011 | return 0; |
1010 | } | 1012 | } |
1011 | 1013 | ||
@@ -1074,7 +1076,7 @@ static int brcmf_sdiod_probe(struct brcmf_sdio_dev *sdiodev) | |||
1074 | ret = -ENODEV; | 1076 | ret = -ENODEV; |
1075 | goto out; | 1077 | goto out; |
1076 | } | 1078 | } |
1077 | 1079 | pm_runtime_forbid(host->parent); | |
1078 | out: | 1080 | out: |
1079 | if (ret) | 1081 | if (ret) |
1080 | brcmf_sdiod_remove(sdiodev); | 1082 | brcmf_sdiod_remove(sdiodev); |