aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArik Nemtsov <arik@wizery.com>2013-03-12 11:19:45 -0400
committerLuciano Coelho <coelho@ti.com>2013-03-25 06:33:13 -0400
commit75592be5e35b31eb28dacf578cfe82f0e9bc0ac0 (patch)
treeae3e76a49dc4e6907ab2c71c60011774c51ea59b
parent0e752df6fda25993acc30e1162808fbb2543be03 (diff)
wlcore: correctly check state before regdomain conf
The wlcore state was checked without the mutex being taken. This leads to WARN_ONs sometimes if a notification arrives when the driver is on, but the mutex is only taken after it is off. This usually happens if stopping the driver while connected to a network. Signed-off-by: Arik Nemtsov <arik@wizery.com> Signed-off-by: Luciano Coelho <coelho@ti.com>
-rw-r--r--drivers/net/wireless/ti/wlcore/main.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/net/wireless/ti/wlcore/main.c b/drivers/net/wireless/ti/wlcore/main.c
index 43865d1348ec..248daa9bb5fe 100644
--- a/drivers/net/wireless/ti/wlcore/main.c
+++ b/drivers/net/wireless/ti/wlcore/main.c
@@ -108,8 +108,7 @@ static void wl1271_reg_notify(struct wiphy *wiphy,
108 108
109 } 109 }
110 110
111 if (likely(wl->state == WLCORE_STATE_ON)) 111 wlcore_regdomain_config(wl);
112 wlcore_regdomain_config(wl);
113} 112}
114 113
115static int wl1271_set_rx_streaming(struct wl1271 *wl, struct wl12xx_vif *wlvif, 114static int wl1271_set_rx_streaming(struct wl1271 *wl, struct wl12xx_vif *wlvif,
@@ -3364,6 +3363,10 @@ void wlcore_regdomain_config(struct wl1271 *wl)
3364 return; 3363 return;
3365 3364
3366 mutex_lock(&wl->mutex); 3365 mutex_lock(&wl->mutex);
3366
3367 if (unlikely(wl->state != WLCORE_STATE_ON))
3368 goto out;
3369
3367 ret = wl1271_ps_elp_wakeup(wl); 3370 ret = wl1271_ps_elp_wakeup(wl);
3368 if (ret < 0) 3371 if (ret < 0)
3369 goto out; 3372 goto out;