diff options
author | Hante Meuleman <meuleman@broadcom.com> | 2012-11-14 21:46:19 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2012-11-16 14:29:00 -0500 |
commit | 2def5c10d2f8f81c8089b2c1b63fdc278e7d86f0 (patch) | |
tree | 598428a6153ef0b21b7b85849f60fb380ecc013a | |
parent | 37ac5780e08e4e3ce67e8355e52d71324e9c11cd (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>
-rw-r--r-- | drivers/net/wireless/brcm80211/brcmfmac/bcmsdh.c | 2 | ||||
-rw-r--r-- | drivers/net/wireless/brcm80211/brcmfmac/dhd_sdio.c | 2 |
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 1aec4342875d..b924ed7d3e01 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 | ||
536 | int brcmf_sdio_remove(struct brcmf_sdio_dev *sdiodev) | 536 | int 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 40a37ac04970..45725454714d 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) { |