aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/brcm80211/brcmfmac
diff options
context:
space:
mode:
authorHante Meuleman <meuleman@broadcom.com>2012-11-14 21:46:19 -0500
committerJohn W. Linville <linville@tuxdriver.com>2012-11-16 14:29:00 -0500
commit2def5c10d2f8f81c8089b2c1b63fdc278e7d86f0 (patch)
tree598428a6153ef0b21b7b85849f60fb380ecc013a /drivers/net/wireless/brcm80211/brcmfmac
parent37ac5780e08e4e3ce67e8355e52d71324e9c11cd (diff)
brcmfmac: sdio unload fix.
on sdio remove the bus_if should be configured for close, so new data from higher layers will be blocked. Also the access to bus_if in the watchdog should be checked for null pointer access on sdio remove. Reviewed-by: Arend Van Spriel <arend@broadcom.com> Reviewed-by: Pieter-Paul Giesberts <pieterpg@broadcom.com> Signed-off-by: Hante Meuleman <meuleman@broadcom.com> Signed-off-by: Franky Lin <frankyl@broadcom.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/brcm80211/brcmfmac')
-rw-r--r--drivers/net/wireless/brcm80211/brcmfmac/bcmsdh.c2
-rw-r--r--drivers/net/wireless/brcm80211/brcmfmac/dhd_sdio.c2
2 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 1aec4342875..b924ed7d3e0 100644
--- a/drivers/net/wireless/brcm80211/brcmfmac/bcmsdh.c
+++ b/drivers/net/wireless/brcm80211/brcmfmac/bcmsdh.c
@@ -535,6 +535,8 @@ EXPORT_SYMBOL(brcmf_sdio_probe);
535 535
536int brcmf_sdio_remove(struct brcmf_sdio_dev *sdiodev) 536int brcmf_sdio_remove(struct brcmf_sdio_dev *sdiodev)
537{ 537{
538 sdiodev->bus_if->state = BRCMF_BUS_DOWN;
539
538 if (sdiodev->bus) { 540 if (sdiodev->bus) {
539 brcmf_sdbrcm_disconnect(sdiodev->bus); 541 brcmf_sdbrcm_disconnect(sdiodev->bus);
540 sdiodev->bus = NULL; 542 sdiodev->bus = NULL;
diff --git a/drivers/net/wireless/brcm80211/brcmfmac/dhd_sdio.c b/drivers/net/wireless/brcm80211/brcmfmac/dhd_sdio.c
index 40a37ac0497..45725454714 100644
--- a/drivers/net/wireless/brcm80211/brcmfmac/dhd_sdio.c
+++ b/drivers/net/wireless/brcm80211/brcmfmac/dhd_sdio.c
@@ -3576,7 +3576,7 @@ static bool brcmf_sdbrcm_bus_watchdog(struct brcmf_sdio *bus)
3576 } 3576 }
3577#ifdef DEBUG 3577#ifdef DEBUG
3578 /* Poll for console output periodically */ 3578 /* Poll for console output periodically */
3579 if (bus_if->state == BRCMF_BUS_DATA && 3579 if (bus_if && bus_if->state == BRCMF_BUS_DATA &&
3580 bus->console_interval != 0) { 3580 bus->console_interval != 0) {
3581 bus->console.count += BRCMF_WD_POLL_MS; 3581 bus->console.count += BRCMF_WD_POLL_MS;
3582 if (bus->console.count >= bus->console_interval) { 3582 if (bus->console.count >= bus->console_interval) {