aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/wl12xx
diff options
context:
space:
mode:
authorKalle Valo <kalle.valo@nokia.com>2009-06-12 07:16:32 -0400
committerJohn W. Linville <linville@tuxdriver.com>2009-07-10 14:57:47 -0400
commitc5483b71936333ba9474f57d0f3a7a7abf9b87a0 (patch)
tree599a485034698c38a2071528a0c57f5f547d152a /drivers/net/wireless/wl12xx
parent01d9cfbdaadc64a46b57437c989bbad241074135 (diff)
wl12xx: check if elp wakeup failed
Check the return call from wl12xx_ps_elp_wakeup() and bail out if it fails. This shouldn't happen, but if does there's a fundamental low level issue. Signed-off-by: Kalle Valo <kalle.valo@nokia.com> Reviewed-by: Luciano Coelho <luciano.coelho@nokia.com> Reviewed-by: Vidhya Govindan <vidhya.govindan@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/debugfs.c7
-rw-r--r--drivers/net/wireless/wl12xx/main.c66
-rw-r--r--drivers/net/wireless/wl12xx/wl1251.c6
-rw-r--r--drivers/net/wireless/wl12xx/wl1251_tx.c4
4 files changed, 59 insertions, 24 deletions
diff --git a/drivers/net/wireless/wl12xx/debugfs.c b/drivers/net/wireless/wl12xx/debugfs.c
index 3cc5460c11f3..94ad99485651 100644
--- a/drivers/net/wireless/wl12xx/debugfs.c
+++ b/drivers/net/wireless/wl12xx/debugfs.c
@@ -95,9 +95,13 @@ static const struct file_operations sub## _ ##name## _ops = { \
95 95
96static void wl12xx_debugfs_update_stats(struct wl12xx *wl) 96static void wl12xx_debugfs_update_stats(struct wl12xx *wl)
97{ 97{
98 int ret;
99
98 mutex_lock(&wl->mutex); 100 mutex_lock(&wl->mutex);
99 101
100 wl12xx_ps_elp_wakeup(wl); 102 ret = wl12xx_ps_elp_wakeup(wl);
103 if (ret < 0)
104 goto out;
101 105
102 if (wl->state == WL12XX_STATE_ON && 106 if (wl->state == WL12XX_STATE_ON &&
103 time_after(jiffies, wl->stats.fw_stats_update + 107 time_after(jiffies, wl->stats.fw_stats_update +
@@ -108,6 +112,7 @@ static void wl12xx_debugfs_update_stats(struct wl12xx *wl)
108 112
109 wl12xx_ps_elp_sleep(wl); 113 wl12xx_ps_elp_sleep(wl);
110 114
115out:
111 mutex_unlock(&wl->mutex); 116 mutex_unlock(&wl->mutex);
112} 117}
113 118
diff --git a/drivers/net/wireless/wl12xx/main.c b/drivers/net/wireless/wl12xx/main.c
index 894d5cc43d25..245544e6434c 100644
--- a/drivers/net/wireless/wl12xx/main.c
+++ b/drivers/net/wireless/wl12xx/main.c
@@ -239,14 +239,18 @@ static void wl12xx_filter_work(struct work_struct *work)
239 if (wl->state == WL12XX_STATE_OFF) 239 if (wl->state == WL12XX_STATE_OFF)
240 goto out; 240 goto out;
241 241
242 wl12xx_ps_elp_wakeup(wl); 242 ret = wl12xx_ps_elp_wakeup(wl);
243 if (ret < 0)
244 goto out;
243 245
244 ret = wl12xx_cmd_join(wl, wl->bss_type, 1, 100, 0); 246 ret = wl12xx_cmd_join(wl, wl->bss_type, 1, 100, 0);
245 if (ret < 0) 247 if (ret < 0)
246 goto out; 248 goto out_sleep;
247 249
248out: 250out_sleep:
249 wl12xx_ps_elp_sleep(wl); 251 wl12xx_ps_elp_sleep(wl);
252
253out:
250 mutex_unlock(&wl->mutex); 254 mutex_unlock(&wl->mutex);
251} 255}
252 256
@@ -524,20 +528,22 @@ static int wl12xx_op_config(struct ieee80211_hw *hw, u32 changed)
524 528
525 mutex_lock(&wl->mutex); 529 mutex_lock(&wl->mutex);
526 530
527 wl12xx_ps_elp_wakeup(wl); 531 ret = wl12xx_ps_elp_wakeup(wl);
532 if (ret < 0)
533 goto out;
528 534
529 if (channel != wl->channel) { 535 if (channel != wl->channel) {
530 /* FIXME: use beacon interval provided by mac80211 */ 536 /* FIXME: use beacon interval provided by mac80211 */
531 ret = wl12xx_cmd_join(wl, wl->bss_type, 1, 100, 0); 537 ret = wl12xx_cmd_join(wl, wl->bss_type, 1, 100, 0);
532 if (ret < 0) 538 if (ret < 0)
533 goto out; 539 goto out_sleep;
534 540
535 wl->channel = channel; 541 wl->channel = channel;
536 } 542 }
537 543
538 ret = wl12xx_build_null_data(wl); 544 ret = wl12xx_build_null_data(wl);
539 if (ret < 0) 545 if (ret < 0)
540 goto out; 546 goto out_sleep;
541 547
542 if (conf->flags & IEEE80211_CONF_PS && !wl->psm_requested) { 548 if (conf->flags & IEEE80211_CONF_PS && !wl->psm_requested) {
543 wl12xx_info("psm enabled"); 549 wl12xx_info("psm enabled");
@@ -568,9 +574,12 @@ static int wl12xx_op_config(struct ieee80211_hw *hw, u32 changed)
568 wl->power_level = conf->power_level; 574 wl->power_level = conf->power_level;
569 } 575 }
570 576
571out: 577out_sleep:
572 wl12xx_ps_elp_sleep(wl); 578 wl12xx_ps_elp_sleep(wl);
579
580out:
573 mutex_unlock(&wl->mutex); 581 mutex_unlock(&wl->mutex);
582
574 return ret; 583 return ret;
575} 584}
576 585
@@ -708,7 +717,9 @@ static int wl12xx_op_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
708 717
709 mutex_lock(&wl->mutex); 718 mutex_lock(&wl->mutex);
710 719
711 wl12xx_ps_elp_wakeup(wl); 720 ret = wl12xx_ps_elp_wakeup(wl);
721 if (ret < 0)
722 goto out_unlock;
712 723
713 switch (cmd) { 724 switch (cmd) {
714 case SET_KEY: 725 case SET_KEY:
@@ -725,7 +736,7 @@ static int wl12xx_op_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
725 ret = wl12xx_set_key_type(wl, wl_cmd, cmd, key, addr); 736 ret = wl12xx_set_key_type(wl, wl_cmd, cmd, key, addr);
726 if (ret < 0) { 737 if (ret < 0) {
727 wl12xx_error("Set KEY type failed"); 738 wl12xx_error("Set KEY type failed");
728 goto out_unlock; 739 goto out_sleep;
729 } 740 }
730 741
731 if (wl_cmd->key_type != KEY_WEP_DEFAULT) 742 if (wl_cmd->key_type != KEY_WEP_DEFAULT)
@@ -756,11 +767,13 @@ static int wl12xx_op_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
756 ret = wl12xx_cmd_send(wl, CMD_SET_KEYS, wl_cmd, sizeof(*wl_cmd)); 767 ret = wl12xx_cmd_send(wl, CMD_SET_KEYS, wl_cmd, sizeof(*wl_cmd));
757 if (ret < 0) { 768 if (ret < 0) {
758 wl12xx_warning("could not set keys"); 769 wl12xx_warning("could not set keys");
759 goto out_unlock; 770 goto out_sleep;
760 } 771 }
761 772
762out_unlock: 773out_sleep:
763 wl12xx_ps_elp_sleep(wl); 774 wl12xx_ps_elp_sleep(wl);
775
776out_unlock:
764 mutex_unlock(&wl->mutex); 777 mutex_unlock(&wl->mutex);
765 778
766out: 779out:
@@ -955,11 +968,16 @@ static int wl12xx_op_hw_scan(struct ieee80211_hw *hw,
955 } 968 }
956 969
957 mutex_lock(&wl->mutex); 970 mutex_lock(&wl->mutex);
958 wl12xx_ps_elp_wakeup(wl); 971
972 ret = wl12xx_ps_elp_wakeup(wl);
973 if (ret < 0)
974 goto out;
959 975
960 ret = wl12xx_hw_scan(hw->priv, ssid, ssid_len, 1, 0, 13, 3); 976 ret = wl12xx_hw_scan(hw->priv, ssid, ssid_len, 1, 0, 13, 3);
961 977
962 wl12xx_ps_elp_sleep(wl); 978 wl12xx_ps_elp_sleep(wl);
979
980out:
963 mutex_unlock(&wl->mutex); 981 mutex_unlock(&wl->mutex);
964 982
965 return ret; 983 return ret;
@@ -972,15 +990,17 @@ static int wl12xx_op_set_rts_threshold(struct ieee80211_hw *hw, u32 value)
972 990
973 mutex_lock(&wl->mutex); 991 mutex_lock(&wl->mutex);
974 992
975 wl12xx_ps_elp_wakeup(wl); 993 ret = wl12xx_ps_elp_wakeup(wl);
994 if (ret < 0)
995 goto out;
976 996
977 ret = wl12xx_acx_rts_threshold(wl, (u16) value); 997 ret = wl12xx_acx_rts_threshold(wl, (u16) value);
978
979 if (ret < 0) 998 if (ret < 0)
980 wl12xx_warning("wl12xx_op_set_rts_threshold failed: %d", ret); 999 wl12xx_warning("wl12xx_op_set_rts_threshold failed: %d", ret);
981 1000
982 wl12xx_ps_elp_sleep(wl); 1001 wl12xx_ps_elp_sleep(wl);
983 1002
1003out:
984 mutex_unlock(&wl->mutex); 1004 mutex_unlock(&wl->mutex);
985 1005
986 return ret; 1006 return ret;
@@ -1000,7 +1020,9 @@ static void wl12xx_op_bss_info_changed(struct ieee80211_hw *hw,
1000 1020
1001 mutex_lock(&wl->mutex); 1021 mutex_lock(&wl->mutex);
1002 1022
1003 wl12xx_ps_elp_wakeup(wl); 1023 ret = wl12xx_ps_elp_wakeup(wl);
1024 if (ret < 0)
1025 goto out;
1004 1026
1005 if (changed & BSS_CHANGED_ASSOC) { 1027 if (changed & BSS_CHANGED_ASSOC) {
1006 if (bss_conf->assoc) { 1028 if (bss_conf->assoc) {
@@ -1008,18 +1030,18 @@ static void wl12xx_op_bss_info_changed(struct ieee80211_hw *hw,
1008 1030
1009 ret = wl12xx_build_ps_poll(wl, wl->aid); 1031 ret = wl12xx_build_ps_poll(wl, wl->aid);
1010 if (ret < 0) 1032 if (ret < 0)
1011 goto out; 1033 goto out_sleep;
1012 1034
1013 ret = wl12xx_acx_aid(wl, wl->aid); 1035 ret = wl12xx_acx_aid(wl, wl->aid);
1014 if (ret < 0) 1036 if (ret < 0)
1015 goto out; 1037 goto out_sleep;
1016 1038
1017 /* If we want to go in PSM but we're not there yet */ 1039 /* If we want to go in PSM but we're not there yet */
1018 if (wl->psm_requested && !wl->psm) { 1040 if (wl->psm_requested && !wl->psm) {
1019 mode = STATION_POWER_SAVE_MODE; 1041 mode = STATION_POWER_SAVE_MODE;
1020 ret = wl12xx_ps_set_mode(wl, mode); 1042 ret = wl12xx_ps_set_mode(wl, mode);
1021 if (ret < 0) 1043 if (ret < 0)
1022 goto out; 1044 goto out_sleep;
1023 } 1045 }
1024 } 1046 }
1025 } 1047 }
@@ -1030,7 +1052,7 @@ static void wl12xx_op_bss_info_changed(struct ieee80211_hw *hw,
1030 ret = wl12xx_acx_slot(wl, SLOT_TIME_LONG); 1052 ret = wl12xx_acx_slot(wl, SLOT_TIME_LONG);
1031 if (ret < 0) { 1053 if (ret < 0) {
1032 wl12xx_warning("Set slot time failed %d", ret); 1054 wl12xx_warning("Set slot time failed %d", ret);
1033 goto out; 1055 goto out_sleep;
1034 } 1056 }
1035 } 1057 }
1036 1058
@@ -1048,7 +1070,7 @@ static void wl12xx_op_bss_info_changed(struct ieee80211_hw *hw,
1048 ret = wl12xx_acx_cts_protect(wl, CTSPROTECT_DISABLE); 1070 ret = wl12xx_acx_cts_protect(wl, CTSPROTECT_DISABLE);
1049 if (ret < 0) { 1071 if (ret < 0) {
1050 wl12xx_warning("Set ctsprotect failed %d", ret); 1072 wl12xx_warning("Set ctsprotect failed %d", ret);
1051 goto out; 1073 goto out_sleep;
1052 } 1074 }
1053 } 1075 }
1054 1076
@@ -1090,8 +1112,10 @@ static void wl12xx_op_bss_info_changed(struct ieee80211_hw *hw,
1090 goto out; 1112 goto out;
1091 } 1113 }
1092 1114
1093out: 1115out_sleep:
1094 wl12xx_ps_elp_sleep(wl); 1116 wl12xx_ps_elp_sleep(wl);
1117
1118out:
1095 mutex_unlock(&wl->mutex); 1119 mutex_unlock(&wl->mutex);
1096} 1120}
1097 1121
diff --git a/drivers/net/wireless/wl12xx/wl1251.c b/drivers/net/wireless/wl12xx/wl1251.c
index 903624a540a3..5f6e75c61128 100644
--- a/drivers/net/wireless/wl12xx/wl1251.c
+++ b/drivers/net/wireless/wl12xx/wl1251.c
@@ -401,6 +401,7 @@ static void wl1251_irq_work(struct work_struct *work)
401 u32 intr; 401 u32 intr;
402 struct wl12xx *wl = 402 struct wl12xx *wl =
403 container_of(work, struct wl12xx, irq_work); 403 container_of(work, struct wl12xx, irq_work);
404 int ret;
404 405
405 mutex_lock(&wl->mutex); 406 mutex_lock(&wl->mutex);
406 407
@@ -409,7 +410,9 @@ static void wl1251_irq_work(struct work_struct *work)
409 if (wl->state == WL12XX_STATE_OFF) 410 if (wl->state == WL12XX_STATE_OFF)
410 goto out; 411 goto out;
411 412
412 wl12xx_ps_elp_wakeup(wl); 413 ret = wl12xx_ps_elp_wakeup(wl);
414 if (ret < 0)
415 goto out;
413 416
414 wl12xx_reg_write32(wl, ACX_REG_INTERRUPT_MASK, WL1251_ACX_INTR_ALL); 417 wl12xx_reg_write32(wl, ACX_REG_INTERRUPT_MASK, WL1251_ACX_INTR_ALL);
415 418
@@ -489,6 +492,7 @@ static void wl1251_irq_work(struct work_struct *work)
489 492
490out_sleep: 493out_sleep:
491 wl12xx_ps_elp_sleep(wl); 494 wl12xx_ps_elp_sleep(wl);
495
492out: 496out:
493 mutex_unlock(&wl->mutex); 497 mutex_unlock(&wl->mutex);
494} 498}
diff --git a/drivers/net/wireless/wl12xx/wl1251_tx.c b/drivers/net/wireless/wl12xx/wl1251_tx.c
index c42c43de657e..10023fce1031 100644
--- a/drivers/net/wireless/wl12xx/wl1251_tx.c
+++ b/drivers/net/wireless/wl12xx/wl1251_tx.c
@@ -311,7 +311,9 @@ void wl1251_tx_work(struct work_struct *work)
311 311
312 while ((skb = skb_dequeue(&wl->tx_queue))) { 312 while ((skb = skb_dequeue(&wl->tx_queue))) {
313 if (!woken_up) { 313 if (!woken_up) {
314 wl12xx_ps_elp_wakeup(wl); 314 ret = wl12xx_ps_elp_wakeup(wl);
315 if (ret < 0)
316 goto out;
315 woken_up = true; 317 woken_up = true;
316 } 318 }
317 319