aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless
diff options
context:
space:
mode:
authorArend van Spriel <arend@broadcom.com>2015-03-18 08:25:21 -0400
committerKalle Valo <kvalo@codeaurora.org>2015-03-20 03:03:23 -0400
commit063d51776bd60ebf2587682eb394851c792e58d9 (patch)
tree60a976145fdb3fffe5138f239fa09a13377e4bdd /drivers/net/wireless
parentbb408cc78401c53842e17b24b6433c122629f21f (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.c4
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);
1078out: 1080out:
1079 if (ret) 1081 if (ret)
1080 brcmf_sdiod_remove(sdiodev); 1082 brcmf_sdiod_remove(sdiodev);