diff options
author | Saravanan Dhanabal <ext-saravanan.dhanabal@nokia.com> | 2010-04-09 04:07:27 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2010-04-09 13:43:10 -0400 |
commit | 2c10bb9cb3f9cecb71bd2cbb771778136433ebe2 (patch) | |
tree | 3847ade22a7acd9490266548fb4c6e127d587528 /drivers/net/wireless/wl12xx | |
parent | bd9dc49cd565aeb20d4f6eb2f6af4c16acce2ef5 (diff) |
wl1271: Fix mac80211 configuration requests during WL1271_STATE_OFF
mac80211 sends configuration requests even if the wl1271 interface
state is WL1271_STATE_OFF. This creates warnings from mac80211.
This patch leaves the configuration functions, if the interface is
going down.
Signed-off-by: Saravanan Dhanabal <ext-saravanan.dhanabal@nokia.com>
Reviewed-by: Juuso Oikarinen <juuso.oikarinen@nokia.com>
Signed-off-by: Luciano Coelho <luciano.coelho@nokia.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/wl12xx')
-rw-r--r-- | drivers/net/wireless/wl12xx/wl1271_main.c | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/drivers/net/wireless/wl12xx/wl1271_main.c b/drivers/net/wireless/wl12xx/wl1271_main.c index 4e9754056d45..2eb7b99ff276 100644 --- a/drivers/net/wireless/wl12xx/wl1271_main.c +++ b/drivers/net/wireless/wl12xx/wl1271_main.c | |||
@@ -1223,6 +1223,9 @@ static int wl1271_op_config(struct ieee80211_hw *hw, u32 changed) | |||
1223 | 1223 | ||
1224 | mutex_lock(&wl->mutex); | 1224 | mutex_lock(&wl->mutex); |
1225 | 1225 | ||
1226 | if (unlikely(wl->state == WL1271_STATE_OFF)) | ||
1227 | goto out; | ||
1228 | |||
1226 | ret = wl1271_ps_elp_wakeup(wl, false); | 1229 | ret = wl1271_ps_elp_wakeup(wl, false); |
1227 | if (ret < 0) | 1230 | if (ret < 0) |
1228 | goto out; | 1231 | goto out; |
@@ -1324,8 +1327,12 @@ static u64 wl1271_op_prepare_multicast(struct ieee80211_hw *hw, int mc_count, | |||
1324 | struct dev_addr_list *mc_list) | 1327 | struct dev_addr_list *mc_list) |
1325 | { | 1328 | { |
1326 | struct wl1271_filter_params *fp; | 1329 | struct wl1271_filter_params *fp; |
1330 | struct wl1271 *wl = hw->priv; | ||
1327 | int i; | 1331 | int i; |
1328 | 1332 | ||
1333 | if (unlikely(wl->state == WL1271_STATE_OFF)) | ||
1334 | return 0; | ||
1335 | |||
1329 | fp = kzalloc(sizeof(*fp), GFP_ATOMIC); | 1336 | fp = kzalloc(sizeof(*fp), GFP_ATOMIC); |
1330 | if (!fp) { | 1337 | if (!fp) { |
1331 | wl1271_error("Out of memory setting filters."); | 1338 | wl1271_error("Out of memory setting filters."); |
@@ -1372,15 +1379,16 @@ static void wl1271_op_configure_filter(struct ieee80211_hw *hw, | |||
1372 | 1379 | ||
1373 | mutex_lock(&wl->mutex); | 1380 | mutex_lock(&wl->mutex); |
1374 | 1381 | ||
1375 | if (wl->state == WL1271_STATE_OFF) | 1382 | *total &= WL1271_SUPPORTED_FILTERS; |
1383 | changed &= WL1271_SUPPORTED_FILTERS; | ||
1384 | |||
1385 | if (unlikely(wl->state == WL1271_STATE_OFF)) | ||
1376 | goto out; | 1386 | goto out; |
1377 | 1387 | ||
1378 | ret = wl1271_ps_elp_wakeup(wl, false); | 1388 | ret = wl1271_ps_elp_wakeup(wl, false); |
1379 | if (ret < 0) | 1389 | if (ret < 0) |
1380 | goto out; | 1390 | goto out; |
1381 | 1391 | ||
1382 | *total &= WL1271_SUPPORTED_FILTERS; | ||
1383 | changed &= WL1271_SUPPORTED_FILTERS; | ||
1384 | 1392 | ||
1385 | if (*total & FIF_ALLMULTI) | 1393 | if (*total & FIF_ALLMULTI) |
1386 | ret = wl1271_acx_group_address_tbl(wl, false, NULL, 0); | 1394 | ret = wl1271_acx_group_address_tbl(wl, false, NULL, 0); |