summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTeemu Paasikivi <ext-teemu.3.paasikivi@nokia.com>2010-02-22 08:38:29 +0200
committerJohn W. Linville <linville@tuxdriver.com>2010-03-09 15:03:01 -0500
commit49d7f6d8113a04abacdf99525db9c17d872c1efa (patch)
tree6424c532360d92db32e309062fbad312342c3fca
parent09a9c2b3f464e757b6597f621cc3bedb6f040a27 (diff)
wl1271: Fixed unloading of the wl1271_sdio module
Fixed two bugs causing problems when unloding wl1271 module. First was missing sdio_set_drvdata call from the probe function, second was order of function calls in the remove function. Signed-off-by: Teemu Paasikivi <ext-teemu.3.paasikivi@nokia.com> Reviewed-by: Juuso Oikarinen <juuso.oikarinen@nokia.com> Signed-off-by: Juuso Oikarinen <juuso.oikarinen@nokia.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r--drivers/net/wireless/wl12xx/wl1271_sdio.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/net/wireless/wl12xx/wl1271_sdio.c b/drivers/net/wireless/wl12xx/wl1271_sdio.c
index be5c14935bc..7d7c8504185 100644
--- a/drivers/net/wireless/wl12xx/wl1271_sdio.c
+++ b/drivers/net/wireless/wl12xx/wl1271_sdio.c
@@ -219,6 +219,8 @@ static int __devinit wl1271_probe(struct sdio_func *func,
goto out_irq;
sdio_claim_host(func);
+ sdio_set_drvdata(func, wl);
+
ret = sdio_enable_func(func);
if (ret)
goto out_release;
@@ -246,10 +248,11 @@ static void __devexit wl1271_remove(struct sdio_func *func)
{
struct wl1271 *wl = sdio_get_drvdata(func);
+ ieee80211_unregister_hw(wl->hw);
+
sdio_claim_host(func);
sdio_disable_func(func);
sdio_release_host(func);
- ieee80211_unregister_hw(wl->hw);
free_irq(wl->irq, wl);