diff options
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/wireless/libertas/join.c | 2 | ||||
-rw-r--r-- | drivers/net/wireless/libertas/scan.c | 221 |
2 files changed, 155 insertions, 68 deletions
diff --git a/drivers/net/wireless/libertas/join.c b/drivers/net/wireless/libertas/join.c index 8dcff00574f3..dc24a05c9447 100644 --- a/drivers/net/wireless/libertas/join.c +++ b/drivers/net/wireless/libertas/join.c | |||
@@ -800,8 +800,6 @@ int libertas_ret_80211_associate(wlan_private * priv, | |||
800 | netif_wake_queue(priv->mesh_dev); | 800 | netif_wake_queue(priv->mesh_dev); |
801 | } | 801 | } |
802 | 802 | ||
803 | lbs_deb_join("ASSOC_RESP: Associated \n"); | ||
804 | |||
805 | memcpy(wrqu.ap_addr.sa_data, adapter->curbssparams.bssid, ETH_ALEN); | 803 | memcpy(wrqu.ap_addr.sa_data, adapter->curbssparams.bssid, ETH_ALEN); |
806 | wrqu.ap_addr.sa_family = ARPHRD_ETHER; | 804 | wrqu.ap_addr.sa_family = ARPHRD_ETHER; |
807 | wireless_send_event(priv->dev, SIOCGIWAP, &wrqu, NULL); | 805 | wireless_send_event(priv->dev, SIOCGIWAP, &wrqu, NULL); |
diff --git a/drivers/net/wireless/libertas/scan.c b/drivers/net/wireless/libertas/scan.c index dcce354e904c..ad1e67d984ce 100644 --- a/drivers/net/wireless/libertas/scan.c +++ b/drivers/net/wireless/libertas/scan.c | |||
@@ -65,6 +65,15 @@ | |||
65 | static const u8 zeromac[ETH_ALEN] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; | 65 | static const u8 zeromac[ETH_ALEN] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; |
66 | static const u8 bcastmac[ETH_ALEN] = { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF }; | 66 | static const u8 bcastmac[ETH_ALEN] = { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF }; |
67 | 67 | ||
68 | |||
69 | |||
70 | |||
71 | /*********************************************************************/ | ||
72 | /* */ | ||
73 | /* Misc helper functions */ | ||
74 | /* */ | ||
75 | /*********************************************************************/ | ||
76 | |||
68 | static inline void clear_bss_descriptor (struct bss_descriptor * bss) | 77 | static inline void clear_bss_descriptor (struct bss_descriptor * bss) |
69 | { | 78 | { |
70 | /* Don't blow away ->list, just BSS data */ | 79 | /* Don't blow away ->list, just BSS data */ |
@@ -165,7 +174,7 @@ static int is_network_compatible(wlan_adapter * adapter, | |||
165 | { | 174 | { |
166 | int matched = 0; | 175 | int matched = 0; |
167 | 176 | ||
168 | lbs_deb_enter(LBS_DEB_ASSOC); | 177 | lbs_deb_enter(LBS_DEB_SCAN); |
169 | 178 | ||
170 | if (bss->mode != mode) | 179 | if (bss->mode != mode) |
171 | goto done; | 180 | goto done; |
@@ -214,13 +223,41 @@ static int is_network_compatible(wlan_adapter * adapter, | |||
214 | (bss->capability & WLAN_CAPABILITY_PRIVACY)); | 223 | (bss->capability & WLAN_CAPABILITY_PRIVACY)); |
215 | 224 | ||
216 | done: | 225 | done: |
217 | lbs_deb_leave(LBS_DEB_SCAN); | 226 | lbs_deb_leave_args(LBS_DEB_SCAN, "matched: %d", matched); |
218 | return matched; | 227 | return matched; |
219 | } | 228 | } |
220 | 229 | ||
221 | /** | 230 | /** |
231 | * @brief Compare two SSIDs | ||
232 | * | ||
233 | * @param ssid1 A pointer to ssid to compare | ||
234 | * @param ssid2 A pointer to ssid to compare | ||
235 | * | ||
236 | * @return 0--ssid is same, otherwise is different | ||
237 | */ | ||
238 | int libertas_ssid_cmp(u8 *ssid1, u8 ssid1_len, u8 *ssid2, u8 ssid2_len) | ||
239 | { | ||
240 | if (ssid1_len != ssid2_len) | ||
241 | return -1; | ||
242 | |||
243 | return memcmp(ssid1, ssid2, ssid1_len); | ||
244 | } | ||
245 | |||
246 | |||
247 | |||
248 | |||
249 | /*********************************************************************/ | ||
250 | /* */ | ||
251 | /* Main scanning support */ | ||
252 | /* */ | ||
253 | /*********************************************************************/ | ||
254 | |||
255 | |||
256 | /** | ||
222 | * @brief Create a channel list for the driver to scan based on region info | 257 | * @brief Create a channel list for the driver to scan based on region info |
223 | * | 258 | * |
259 | * Only used from wlan_scan_setup_scan_config() | ||
260 | * | ||
224 | * Use the driver region/band information to construct a comprehensive list | 261 | * Use the driver region/band information to construct a comprehensive list |
225 | * of channels to scan. This routine is used for any scan that is not | 262 | * of channels to scan. This routine is used for any scan that is not |
226 | * provided a specific channel list to scan. | 263 | * provided a specific channel list to scan. |
@@ -248,6 +285,8 @@ static void wlan_scan_create_channel_list(wlan_private * priv, | |||
248 | int nextchan; | 285 | int nextchan; |
249 | u8 scantype; | 286 | u8 scantype; |
250 | 287 | ||
288 | lbs_deb_enter_args(LBS_DEB_SCAN, "filteredscan %d", filteredscan); | ||
289 | |||
251 | chanidx = 0; | 290 | chanidx = 0; |
252 | 291 | ||
253 | /* Set the default scan type to the user specified type, will later | 292 | /* Set the default scan type to the user specified type, will later |
@@ -384,6 +423,8 @@ wlan_scan_setup_scan_config(wlan_private * priv, | |||
384 | int channel; | 423 | int channel; |
385 | int radiotype; | 424 | int radiotype; |
386 | 425 | ||
426 | lbs_deb_enter(LBS_DEB_SCAN); | ||
427 | |||
387 | pscancfgout = kzalloc(MAX_SCAN_CFG_ALLOC, GFP_KERNEL); | 428 | pscancfgout = kzalloc(MAX_SCAN_CFG_ALLOC, GFP_KERNEL); |
388 | if (pscancfgout == NULL) | 429 | if (pscancfgout == NULL) |
389 | goto out; | 430 | goto out; |
@@ -481,13 +522,12 @@ wlan_scan_setup_scan_config(wlan_private * priv, | |||
481 | 522 | ||
482 | if (!puserscanin || !puserscanin->chanlist[0].channumber) { | 523 | if (!puserscanin || !puserscanin->chanlist[0].channumber) { |
483 | /* Create a default channel scan list */ | 524 | /* Create a default channel scan list */ |
484 | lbs_deb_scan("Scan: Creating full region channel list\n"); | 525 | lbs_deb_scan("creating full region channel list\n"); |
485 | wlan_scan_create_channel_list(priv, pscanchanlist, | 526 | wlan_scan_create_channel_list(priv, pscanchanlist, |
486 | *pfilteredscan); | 527 | *pfilteredscan); |
487 | goto out; | 528 | goto out; |
488 | } | 529 | } |
489 | 530 | ||
490 | lbs_deb_scan("Scan: Using supplied channel list\n"); | ||
491 | for (chanidx = 0; | 531 | for (chanidx = 0; |
492 | chanidx < WLAN_IOCTL_USER_SCAN_CHAN_MAX | 532 | chanidx < WLAN_IOCTL_USER_SCAN_CHAN_MAX |
493 | && puserscanin->chanlist[chanidx].channumber; chanidx++) { | 533 | && puserscanin->chanlist[chanidx].channumber; chanidx++) { |
@@ -529,7 +569,7 @@ wlan_scan_setup_scan_config(wlan_private * priv, | |||
529 | (puserscanin->chanlist[0].channumber == | 569 | (puserscanin->chanlist[0].channumber == |
530 | priv->adapter->curbssparams.channel)) { | 570 | priv->adapter->curbssparams.channel)) { |
531 | *pscancurrentonly = 1; | 571 | *pscancurrentonly = 1; |
532 | lbs_deb_scan("Scan: Scanning current channel only"); | 572 | lbs_deb_scan("scanning current channel only"); |
533 | } | 573 | } |
534 | 574 | ||
535 | out: | 575 | out: |
@@ -539,6 +579,8 @@ out: | |||
539 | /** | 579 | /** |
540 | * @brief Construct and send multiple scan config commands to the firmware | 580 | * @brief Construct and send multiple scan config commands to the firmware |
541 | * | 581 | * |
582 | * Only used from wlan_scan_networks() | ||
583 | * | ||
542 | * Previous routines have created a wlan_scan_cmd_config with any requested | 584 | * Previous routines have created a wlan_scan_cmd_config with any requested |
543 | * TLVs. This function splits the channel TLV into maxchanperscan lists | 585 | * TLVs. This function splits the channel TLV into maxchanperscan lists |
544 | * and sends the portion of the channel TLV along with the other TLVs | 586 | * and sends the portion of the channel TLV along with the other TLVs |
@@ -576,12 +618,14 @@ static int wlan_scan_channel_list(wlan_private * priv, | |||
576 | int scanned = 0; | 618 | int scanned = 0; |
577 | union iwreq_data wrqu; | 619 | union iwreq_data wrqu; |
578 | 620 | ||
579 | lbs_deb_enter(LBS_DEB_ASSOC); | 621 | lbs_deb_enter_args(LBS_DEB_SCAN, "maxchanperscan %d, filteredscan %d, " |
622 | "full_scan %d", maxchanperscan, filteredscan, full_scan); | ||
580 | 623 | ||
581 | if (!pscancfgout || !pchantlvout || !pscanchanlist) { | 624 | if (!pscancfgout || !pchantlvout || !pscanchanlist) { |
582 | lbs_deb_scan("Scan: Null detect: %p, %p, %p\n", | 625 | lbs_deb_scan("pscancfgout, pchantlvout or " |
583 | pscancfgout, pchantlvout, pscanchanlist); | 626 | "pscanchanlist is NULL\n"); |
584 | return -1; | 627 | ret = -1; |
628 | goto out; | ||
585 | } | 629 | } |
586 | 630 | ||
587 | pchantlvout->header.type = cpu_to_le16(TLV_TYPE_CHANLIST); | 631 | pchantlvout->header.type = cpu_to_le16(TLV_TYPE_CHANLIST); |
@@ -613,9 +657,10 @@ static int wlan_scan_channel_list(wlan_private * priv, | |||
613 | while (tlvidx < maxchanperscan && ptmpchan->channumber | 657 | while (tlvidx < maxchanperscan && ptmpchan->channumber |
614 | && !doneearly && scanned < 2) { | 658 | && !doneearly && scanned < 2) { |
615 | 659 | ||
616 | lbs_deb_scan("Scan: Chan(%3d), Radio(%d), mode(%d,%d), " | 660 | lbs_deb_scan("channel %d, radio %d, passive %d, " |
617 | "Dur(%d)\n", | 661 | "dischanflt %d, maxscantime %d\n", |
618 | ptmpchan->channumber, ptmpchan->radiotype, | 662 | ptmpchan->channumber, |
663 | ptmpchan->radiotype, | ||
619 | ptmpchan->chanscanmode.passivescan, | 664 | ptmpchan->chanscanmode.passivescan, |
620 | ptmpchan->chanscanmode.disablechanfilt, | 665 | ptmpchan->chanscanmode.disablechanfilt, |
621 | ptmpchan->maxscantime); | 666 | ptmpchan->maxscantime); |
@@ -700,20 +745,25 @@ done: | |||
700 | wireless_send_event(priv->dev, SIOCGIWSCAN, &wrqu, NULL); | 745 | wireless_send_event(priv->dev, SIOCGIWSCAN, &wrqu, NULL); |
701 | } | 746 | } |
702 | 747 | ||
748 | out: | ||
703 | lbs_deb_leave_args(LBS_DEB_SCAN, "ret %d", ret); | 749 | lbs_deb_leave_args(LBS_DEB_SCAN, "ret %d", ret); |
704 | return ret; | 750 | return ret; |
705 | } | 751 | } |
706 | 752 | ||
707 | static void | 753 | /* |
708 | clear_selected_scan_list_entries(wlan_adapter * adapter, | 754 | * Only used from wlan_scan_networks() |
709 | const struct wlan_ioctl_user_scan_cfg * scan_cfg) | 755 | */ |
756 | static void clear_selected_scan_list_entries(wlan_adapter *adapter, | ||
757 | const struct wlan_ioctl_user_scan_cfg *scan_cfg) | ||
710 | { | 758 | { |
711 | struct bss_descriptor * bss; | 759 | struct bss_descriptor *bss; |
712 | struct bss_descriptor * safe; | 760 | struct bss_descriptor *safe; |
713 | u32 clear_ssid_flag = 0, clear_bssid_flag = 0; | 761 | u32 clear_ssid_flag = 0, clear_bssid_flag = 0; |
714 | 762 | ||
763 | lbs_deb_enter(LBS_DEB_SCAN); | ||
764 | |||
715 | if (!scan_cfg) | 765 | if (!scan_cfg) |
716 | return; | 766 | goto out; |
717 | 767 | ||
718 | if (scan_cfg->clear_ssid && scan_cfg->ssid_len) | 768 | if (scan_cfg->clear_ssid && scan_cfg->ssid_len) |
719 | clear_ssid_flag = 1; | 769 | clear_ssid_flag = 1; |
@@ -725,7 +775,7 @@ clear_selected_scan_list_entries(wlan_adapter * adapter, | |||
725 | } | 775 | } |
726 | 776 | ||
727 | if (!clear_ssid_flag && !clear_bssid_flag) | 777 | if (!clear_ssid_flag && !clear_bssid_flag) |
728 | return; | 778 | goto out; |
729 | 779 | ||
730 | mutex_lock(&adapter->lock); | 780 | mutex_lock(&adapter->lock); |
731 | list_for_each_entry_safe (bss, safe, &adapter->network_list, list) { | 781 | list_for_each_entry_safe (bss, safe, &adapter->network_list, list) { |
@@ -748,12 +798,16 @@ clear_selected_scan_list_entries(wlan_adapter * adapter, | |||
748 | } | 798 | } |
749 | } | 799 | } |
750 | mutex_unlock(&adapter->lock); | 800 | mutex_unlock(&adapter->lock); |
801 | out: | ||
802 | lbs_deb_leave(LBS_DEB_SCAN); | ||
751 | } | 803 | } |
752 | 804 | ||
753 | 805 | ||
754 | /** | 806 | /** |
755 | * @brief Internal function used to start a scan based on an input config | 807 | * @brief Internal function used to start a scan based on an input config |
756 | * | 808 | * |
809 | * Also used from debugfs | ||
810 | * | ||
757 | * Use the input user scan configuration information when provided in | 811 | * Use the input user scan configuration information when provided in |
758 | * order to send the appropriate scan commands to firmware to populate or | 812 | * order to send the appropriate scan commands to firmware to populate or |
759 | * update the internal driver scan table | 813 | * update the internal driver scan table |
@@ -761,6 +815,7 @@ clear_selected_scan_list_entries(wlan_adapter * adapter, | |||
761 | * @param priv A pointer to wlan_private structure | 815 | * @param priv A pointer to wlan_private structure |
762 | * @param puserscanin Pointer to the input configuration for the requested | 816 | * @param puserscanin Pointer to the input configuration for the requested |
763 | * scan. | 817 | * scan. |
818 | * @param full_scan ??? | ||
764 | * | 819 | * |
765 | * @return 0 or < 0 if error | 820 | * @return 0 or < 0 if error |
766 | */ | 821 | */ |
@@ -782,7 +837,7 @@ int wlan_scan_networks(wlan_private * priv, | |||
782 | DECLARE_MAC_BUF(mac); | 837 | DECLARE_MAC_BUF(mac); |
783 | #endif | 838 | #endif |
784 | 839 | ||
785 | lbs_deb_enter(LBS_DEB_SCAN); | 840 | lbs_deb_enter_args(LBS_DEB_SCAN, "full_scan %d", full_scan); |
786 | 841 | ||
787 | /* Cancel any partial outstanding partial scans if this scan | 842 | /* Cancel any partial outstanding partial scans if this scan |
788 | * is a full scan. | 843 | * is a full scan. |
@@ -833,8 +888,9 @@ int wlan_scan_networks(wlan_private * priv, | |||
833 | #ifdef CONFIG_LIBERTAS_DEBUG | 888 | #ifdef CONFIG_LIBERTAS_DEBUG |
834 | /* Dump the scan table */ | 889 | /* Dump the scan table */ |
835 | mutex_lock(&adapter->lock); | 890 | mutex_lock(&adapter->lock); |
891 | lbs_deb_scan("The scan table contains:\n"); | ||
836 | list_for_each_entry (iter_bss, &adapter->network_list, list) { | 892 | list_for_each_entry (iter_bss, &adapter->network_list, list) { |
837 | lbs_deb_scan("Scan:(%02d) %s, RSSI[%03d], SSID[%s]\n", | 893 | lbs_deb_scan("scan %02d, %s, RSSI, %d, SSID '%s'\n", |
838 | i++, print_mac(mac, iter_bss->bssid), (s32) iter_bss->rssi, | 894 | i++, print_mac(mac, iter_bss->bssid), (s32) iter_bss->rssi, |
839 | escape_essid(iter_bss->ssid, iter_bss->ssid_len)); | 895 | escape_essid(iter_bss->ssid, iter_bss->ssid_len)); |
840 | } | 896 | } |
@@ -886,7 +942,7 @@ static int libertas_process_bss(struct bss_descriptor * bss, | |||
886 | u16 beaconsize = 0; | 942 | u16 beaconsize = 0; |
887 | int ret; | 943 | int ret; |
888 | 944 | ||
889 | lbs_deb_enter(LBS_DEB_ASSOC); | 945 | lbs_deb_enter(LBS_DEB_SCAN); |
890 | 946 | ||
891 | if (*bytesleft >= sizeof(beaconsize)) { | 947 | if (*bytesleft >= sizeof(beaconsize)) { |
892 | /* Extract & convert beacon size from the command buffer */ | 948 | /* Extract & convert beacon size from the command buffer */ |
@@ -898,7 +954,8 @@ static int libertas_process_bss(struct bss_descriptor * bss, | |||
898 | if (beaconsize == 0 || beaconsize > *bytesleft) { | 954 | if (beaconsize == 0 || beaconsize > *bytesleft) { |
899 | *pbeaconinfo += *bytesleft; | 955 | *pbeaconinfo += *bytesleft; |
900 | *bytesleft = 0; | 956 | *bytesleft = 0; |
901 | return -1; | 957 | ret = -1; |
958 | goto done; | ||
902 | } | 959 | } |
903 | 960 | ||
904 | /* Initialize the current working beacon pointer for this BSS iteration */ | 961 | /* Initialize the current working beacon pointer for this BSS iteration */ |
@@ -915,7 +972,8 @@ static int libertas_process_bss(struct bss_descriptor * bss, | |||
915 | 972 | ||
916 | if ((end - pos) < 12) { | 973 | if ((end - pos) < 12) { |
917 | lbs_deb_scan("process_bss: Not enough bytes left\n"); | 974 | lbs_deb_scan("process_bss: Not enough bytes left\n"); |
918 | return -1; | 975 | ret = -1; |
976 | goto done; | ||
919 | } | 977 | } |
920 | 978 | ||
921 | /* | 979 | /* |
@@ -1091,38 +1149,26 @@ done: | |||
1091 | } | 1149 | } |
1092 | 1150 | ||
1093 | /** | 1151 | /** |
1094 | * @brief Compare two SSIDs | ||
1095 | * | ||
1096 | * @param ssid1 A pointer to ssid to compare | ||
1097 | * @param ssid2 A pointer to ssid to compare | ||
1098 | * | ||
1099 | * @return 0--ssid is same, otherwise is different | ||
1100 | */ | ||
1101 | int libertas_ssid_cmp(u8 *ssid1, u8 ssid1_len, u8 *ssid2, u8 ssid2_len) | ||
1102 | { | ||
1103 | if (ssid1_len != ssid2_len) | ||
1104 | return -1; | ||
1105 | |||
1106 | return memcmp(ssid1, ssid2, ssid1_len); | ||
1107 | } | ||
1108 | |||
1109 | /** | ||
1110 | * @brief This function finds a specific compatible BSSID in the scan list | 1152 | * @brief This function finds a specific compatible BSSID in the scan list |
1111 | * | 1153 | * |
1154 | * Used in association code | ||
1155 | * | ||
1112 | * @param adapter A pointer to wlan_adapter | 1156 | * @param adapter A pointer to wlan_adapter |
1113 | * @param bssid BSSID to find in the scan list | 1157 | * @param bssid BSSID to find in the scan list |
1114 | * @param mode Network mode: Infrastructure or IBSS | 1158 | * @param mode Network mode: Infrastructure or IBSS |
1115 | * | 1159 | * |
1116 | * @return index in BSSID list, or error return code (< 0) | 1160 | * @return index in BSSID list, or error return code (< 0) |
1117 | */ | 1161 | */ |
1118 | struct bss_descriptor * libertas_find_bssid_in_list(wlan_adapter * adapter, | 1162 | struct bss_descriptor *libertas_find_bssid_in_list(wlan_adapter * adapter, |
1119 | u8 * bssid, u8 mode) | 1163 | u8 * bssid, u8 mode) |
1120 | { | 1164 | { |
1121 | struct bss_descriptor * iter_bss; | 1165 | struct bss_descriptor * iter_bss; |
1122 | struct bss_descriptor * found_bss = NULL; | 1166 | struct bss_descriptor * found_bss = NULL; |
1123 | 1167 | ||
1168 | lbs_deb_enter(LBS_DEB_SCAN); | ||
1169 | |||
1124 | if (!bssid) | 1170 | if (!bssid) |
1125 | return NULL; | 1171 | goto out; |
1126 | 1172 | ||
1127 | lbs_deb_hex(LBS_DEB_SCAN, "looking for", | 1173 | lbs_deb_hex(LBS_DEB_SCAN, "looking for", |
1128 | bssid, ETH_ALEN); | 1174 | bssid, ETH_ALEN); |
@@ -1149,12 +1195,16 @@ struct bss_descriptor * libertas_find_bssid_in_list(wlan_adapter * adapter, | |||
1149 | } | 1195 | } |
1150 | mutex_unlock(&adapter->lock); | 1196 | mutex_unlock(&adapter->lock); |
1151 | 1197 | ||
1198 | out: | ||
1199 | lbs_deb_leave_args(LBS_DEB_SCAN, "found_bss %p", found_bss); | ||
1152 | return found_bss; | 1200 | return found_bss; |
1153 | } | 1201 | } |
1154 | 1202 | ||
1155 | /** | 1203 | /** |
1156 | * @brief This function finds ssid in ssid list. | 1204 | * @brief This function finds ssid in ssid list. |
1157 | * | 1205 | * |
1206 | * Used in association code | ||
1207 | * | ||
1158 | * @param adapter A pointer to wlan_adapter | 1208 | * @param adapter A pointer to wlan_adapter |
1159 | * @param ssid SSID to find in the list | 1209 | * @param ssid SSID to find in the list |
1160 | * @param bssid BSSID to qualify the SSID selection (if provided) | 1210 | * @param bssid BSSID to qualify the SSID selection (if provided) |
@@ -1171,6 +1221,8 @@ struct bss_descriptor * libertas_find_ssid_in_list(wlan_adapter * adapter, | |||
1171 | struct bss_descriptor * found_bss = NULL; | 1221 | struct bss_descriptor * found_bss = NULL; |
1172 | struct bss_descriptor * tmp_oldest = NULL; | 1222 | struct bss_descriptor * tmp_oldest = NULL; |
1173 | 1223 | ||
1224 | lbs_deb_enter(LBS_DEB_SCAN); | ||
1225 | |||
1174 | mutex_lock(&adapter->lock); | 1226 | mutex_lock(&adapter->lock); |
1175 | 1227 | ||
1176 | list_for_each_entry (iter_bss, &adapter->network_list, list) { | 1228 | list_for_each_entry (iter_bss, &adapter->network_list, list) { |
@@ -1215,6 +1267,7 @@ struct bss_descriptor * libertas_find_ssid_in_list(wlan_adapter * adapter, | |||
1215 | 1267 | ||
1216 | out: | 1268 | out: |
1217 | mutex_unlock(&adapter->lock); | 1269 | mutex_unlock(&adapter->lock); |
1270 | lbs_deb_leave_args(LBS_DEB_SCAN, "found_bss %p", found_bss); | ||
1218 | return found_bss; | 1271 | return found_bss; |
1219 | } | 1272 | } |
1220 | 1273 | ||
@@ -1235,6 +1288,8 @@ static struct bss_descriptor * libertas_find_best_ssid_in_list(wlan_adapter * ad | |||
1235 | struct bss_descriptor * iter_bss; | 1288 | struct bss_descriptor * iter_bss; |
1236 | struct bss_descriptor * best_bss = NULL; | 1289 | struct bss_descriptor * best_bss = NULL; |
1237 | 1290 | ||
1291 | lbs_deb_enter(LBS_DEB_SCAN); | ||
1292 | |||
1238 | mutex_lock(&adapter->lock); | 1293 | mutex_lock(&adapter->lock); |
1239 | 1294 | ||
1240 | list_for_each_entry (iter_bss, &adapter->network_list, list) { | 1295 | list_for_each_entry (iter_bss, &adapter->network_list, list) { |
@@ -1259,12 +1314,15 @@ static struct bss_descriptor * libertas_find_best_ssid_in_list(wlan_adapter * ad | |||
1259 | } | 1314 | } |
1260 | 1315 | ||
1261 | mutex_unlock(&adapter->lock); | 1316 | mutex_unlock(&adapter->lock); |
1317 | lbs_deb_leave_args(LBS_DEB_SCAN, "best_bss %p", best_bss); | ||
1262 | return best_bss; | 1318 | return best_bss; |
1263 | } | 1319 | } |
1264 | 1320 | ||
1265 | /** | 1321 | /** |
1266 | * @brief Find the AP with specific ssid in the scan list | 1322 | * @brief Find the AP with specific ssid in the scan list |
1267 | * | 1323 | * |
1324 | * Used from association worker. | ||
1325 | * | ||
1268 | * @param priv A pointer to wlan_private structure | 1326 | * @param priv A pointer to wlan_private structure |
1269 | * @param pSSID A pointer to AP's ssid | 1327 | * @param pSSID A pointer to AP's ssid |
1270 | * | 1328 | * |
@@ -1277,11 +1335,11 @@ int libertas_find_best_network_ssid(wlan_private * priv, | |||
1277 | int ret = -1; | 1335 | int ret = -1; |
1278 | struct bss_descriptor * found; | 1336 | struct bss_descriptor * found; |
1279 | 1337 | ||
1280 | lbs_deb_enter(LBS_DEB_ASSOC); | 1338 | lbs_deb_enter(LBS_DEB_SCAN); |
1281 | 1339 | ||
1282 | wlan_scan_networks(priv, NULL, 1); | 1340 | wlan_scan_networks(priv, NULL, 1); |
1283 | if (adapter->surpriseremoved) | 1341 | if (adapter->surpriseremoved) |
1284 | return -1; | 1342 | goto out; |
1285 | 1343 | ||
1286 | wait_event_interruptible(adapter->cmd_pending, !adapter->nr_cmd_pending); | 1344 | wait_event_interruptible(adapter->cmd_pending, !adapter->nr_cmd_pending); |
1287 | 1345 | ||
@@ -1293,6 +1351,7 @@ int libertas_find_best_network_ssid(wlan_private * priv, | |||
1293 | ret = 0; | 1351 | ret = 0; |
1294 | } | 1352 | } |
1295 | 1353 | ||
1354 | out: | ||
1296 | lbs_deb_leave_args(LBS_DEB_SCAN, "ret %d", ret); | 1355 | lbs_deb_leave_args(LBS_DEB_SCAN, "ret %d", ret); |
1297 | return ret; | 1356 | return ret; |
1298 | } | 1357 | } |
@@ -1327,10 +1386,17 @@ int libertas_set_scan(struct net_device *dev, struct iw_request_info *info, | |||
1327 | return 0; | 1386 | return 0; |
1328 | } | 1387 | } |
1329 | 1388 | ||
1389 | |||
1330 | /** | 1390 | /** |
1331 | * @brief Send a scan command for all available channels filtered on a spec | 1391 | * @brief Send a scan command for all available channels filtered on a spec |
1332 | * | 1392 | * |
1393 | * Used in association code and from debugfs | ||
1394 | * | ||
1333 | * @param priv A pointer to wlan_private structure | 1395 | * @param priv A pointer to wlan_private structure |
1396 | * @param ssid A pointer to the SSID to scan for | ||
1397 | * @param ssid_len Length of the SSID | ||
1398 | * @param clear_ssid Should existing scan results with this SSID | ||
1399 | * be cleared? | ||
1334 | * @param prequestedssid A pointer to AP's ssid | 1400 | * @param prequestedssid A pointer to AP's ssid |
1335 | * @param keeppreviousscan Flag used to save/clear scan table before scan | 1401 | * @param keeppreviousscan Flag used to save/clear scan table before scan |
1336 | * | 1402 | * |
@@ -1343,7 +1409,8 @@ int libertas_send_specific_ssid_scan(wlan_private * priv, | |||
1343 | struct wlan_ioctl_user_scan_cfg scancfg; | 1409 | struct wlan_ioctl_user_scan_cfg scancfg; |
1344 | int ret = 0; | 1410 | int ret = 0; |
1345 | 1411 | ||
1346 | lbs_deb_enter(LBS_DEB_ASSOC); | 1412 | lbs_deb_enter_args(LBS_DEB_SCAN, "SSID '%s', clear %d", |
1413 | escape_essid(ssid, ssid_len), clear_ssid); | ||
1347 | 1414 | ||
1348 | if (!ssid_len) | 1415 | if (!ssid_len) |
1349 | goto out; | 1416 | goto out; |
@@ -1354,15 +1421,26 @@ int libertas_send_specific_ssid_scan(wlan_private * priv, | |||
1354 | scancfg.clear_ssid = clear_ssid; | 1421 | scancfg.clear_ssid = clear_ssid; |
1355 | 1422 | ||
1356 | wlan_scan_networks(priv, &scancfg, 1); | 1423 | wlan_scan_networks(priv, &scancfg, 1); |
1357 | if (adapter->surpriseremoved) | 1424 | if (adapter->surpriseremoved) { |
1358 | return -1; | 1425 | ret = -1; |
1426 | goto out; | ||
1427 | } | ||
1359 | wait_event_interruptible(adapter->cmd_pending, !adapter->nr_cmd_pending); | 1428 | wait_event_interruptible(adapter->cmd_pending, !adapter->nr_cmd_pending); |
1360 | 1429 | ||
1361 | out: | 1430 | out: |
1362 | lbs_deb_leave(LBS_DEB_ASSOC); | 1431 | lbs_deb_leave_args(LBS_DEB_SCAN, "ret %d", ret); |
1363 | return ret; | 1432 | return ret; |
1364 | } | 1433 | } |
1365 | 1434 | ||
1435 | |||
1436 | |||
1437 | |||
1438 | /*********************************************************************/ | ||
1439 | /* */ | ||
1440 | /* Support for Wireless Extensions */ | ||
1441 | /* */ | ||
1442 | /*********************************************************************/ | ||
1443 | |||
1366 | #define MAX_CUSTOM_LEN 64 | 1444 | #define MAX_CUSTOM_LEN 64 |
1367 | 1445 | ||
1368 | static inline char *libertas_translate_scan(wlan_private *priv, | 1446 | static inline char *libertas_translate_scan(wlan_private *priv, |
@@ -1379,10 +1457,13 @@ static inline char *libertas_translate_scan(wlan_private *priv, | |||
1379 | #define RSSI_DIFF ((u8)(PERFECT_RSSI - WORST_RSSI)) | 1457 | #define RSSI_DIFF ((u8)(PERFECT_RSSI - WORST_RSSI)) |
1380 | u8 rssi; | 1458 | u8 rssi; |
1381 | 1459 | ||
1460 | lbs_deb_enter(LBS_DEB_SCAN); | ||
1461 | |||
1382 | cfp = libertas_find_cfp_by_band_and_channel(adapter, 0, bss->channel); | 1462 | cfp = libertas_find_cfp_by_band_and_channel(adapter, 0, bss->channel); |
1383 | if (!cfp) { | 1463 | if (!cfp) { |
1384 | lbs_deb_scan("Invalid channel number %d\n", bss->channel); | 1464 | lbs_deb_scan("Invalid channel number %d\n", bss->channel); |
1385 | return NULL; | 1465 | start = NULL; |
1466 | goto out; | ||
1386 | } | 1467 | } |
1387 | 1468 | ||
1388 | /* First entry *MUST* be the AP BSSID */ | 1469 | /* First entry *MUST* be the AP BSSID */ |
@@ -1510,11 +1591,13 @@ static inline char *libertas_translate_scan(wlan_private *priv, | |||
1510 | start = iwe_stream_add_point(start, stop, &iwe, custom); | 1591 | start = iwe_stream_add_point(start, stop, &iwe, custom); |
1511 | } | 1592 | } |
1512 | 1593 | ||
1594 | out: | ||
1595 | lbs_deb_leave_args(LBS_DEB_SCAN, "start %p", start); | ||
1513 | return start; | 1596 | return start; |
1514 | } | 1597 | } |
1515 | 1598 | ||
1516 | /** | 1599 | /** |
1517 | * @brief Retrieve the scan table entries via wireless tools IOCTL call | 1600 | * @brief Handle Retrieve scan table ioctl |
1518 | * | 1601 | * |
1519 | * @param dev A pointer to net_device structure | 1602 | * @param dev A pointer to net_device structure |
1520 | * @param info A pointer to iw_request_info structure | 1603 | * @param info A pointer to iw_request_info structure |
@@ -1535,7 +1618,7 @@ int libertas_get_scan(struct net_device *dev, struct iw_request_info *info, | |||
1535 | struct bss_descriptor * iter_bss; | 1618 | struct bss_descriptor * iter_bss; |
1536 | struct bss_descriptor * safe; | 1619 | struct bss_descriptor * safe; |
1537 | 1620 | ||
1538 | lbs_deb_enter(LBS_DEB_ASSOC); | 1621 | lbs_deb_enter(LBS_DEB_SCAN); |
1539 | 1622 | ||
1540 | /* Update RSSI if current BSS is a locally created ad-hoc BSS */ | 1623 | /* Update RSSI if current BSS is a locally created ad-hoc BSS */ |
1541 | if ((adapter->mode == IW_MODE_ADHOC) && adapter->adhoccreate) { | 1624 | if ((adapter->mode == IW_MODE_ADHOC) && adapter->adhoccreate) { |
@@ -1577,19 +1660,27 @@ int libertas_get_scan(struct net_device *dev, struct iw_request_info *info, | |||
1577 | dwrq->length = (ev - extra); | 1660 | dwrq->length = (ev - extra); |
1578 | dwrq->flags = 0; | 1661 | dwrq->flags = 0; |
1579 | 1662 | ||
1580 | lbs_deb_leave(LBS_DEB_ASSOC); | 1663 | lbs_deb_leave_args(LBS_DEB_SCAN, "ret %d", err); |
1581 | return err; | 1664 | return err; |
1582 | } | 1665 | } |
1583 | 1666 | ||
1667 | |||
1668 | |||
1669 | |||
1670 | /*********************************************************************/ | ||
1671 | /* */ | ||
1672 | /* Command execution */ | ||
1673 | /* */ | ||
1674 | /*********************************************************************/ | ||
1675 | |||
1676 | |||
1584 | /** | 1677 | /** |
1585 | * @brief Prepare a scan command to be sent to the firmware | 1678 | * @brief Prepare a scan command to be sent to the firmware |
1586 | * | 1679 | * |
1587 | * Use the wlan_scan_cmd_config sent to the command processing module in | 1680 | * Called from libertas_prepare_and_send_command() in cmd.c |
1588 | * the libertas_prepare_and_send_command to configure a cmd_ds_802_11_scan command | ||
1589 | * struct to send to firmware. | ||
1590 | * | 1681 | * |
1591 | * The fixed fields specifying the BSS type and BSSID filters as well as a | 1682 | * Sends a fixed lenght data part (specifying the BSS type and BSSID filters) |
1592 | * variable number/length of TLVs are sent in the command to firmware. | 1683 | * as well as a variable number/length of TLVs to the firmware. |
1593 | * | 1684 | * |
1594 | * @param priv A pointer to wlan_private structure | 1685 | * @param priv A pointer to wlan_private structure |
1595 | * @param cmd A pointer to cmd_ds_command structure to be sent to | 1686 | * @param cmd A pointer to cmd_ds_command structure to be sent to |
@@ -1598,18 +1689,14 @@ int libertas_get_scan(struct net_device *dev, struct iw_request_info *info, | |||
1598 | * to set the fields/TLVs for the command sent to firmware | 1689 | * to set the fields/TLVs for the command sent to firmware |
1599 | * | 1690 | * |
1600 | * @return 0 or -1 | 1691 | * @return 0 or -1 |
1601 | * | ||
1602 | * @sa wlan_scan_create_channel_list | ||
1603 | */ | 1692 | */ |
1604 | int libertas_cmd_80211_scan(wlan_private * priv, | 1693 | int libertas_cmd_80211_scan(wlan_private * priv, |
1605 | struct cmd_ds_command *cmd, void *pdata_buf) | 1694 | struct cmd_ds_command *cmd, void *pdata_buf) |
1606 | { | 1695 | { |
1607 | struct cmd_ds_802_11_scan *pscan = &cmd->params.scan; | 1696 | struct cmd_ds_802_11_scan *pscan = &cmd->params.scan; |
1608 | struct wlan_scan_cmd_config *pscancfg; | 1697 | struct wlan_scan_cmd_config *pscancfg = pdata_buf; |
1609 | |||
1610 | lbs_deb_enter(LBS_DEB_ASSOC); | ||
1611 | 1698 | ||
1612 | pscancfg = pdata_buf; | 1699 | lbs_deb_enter(LBS_DEB_SCAN); |
1613 | 1700 | ||
1614 | /* Set fixed field variables in scan command */ | 1701 | /* Set fixed field variables in scan command */ |
1615 | pscan->bsstype = pscancfg->bsstype; | 1702 | pscan->bsstype = pscancfg->bsstype; |
@@ -1622,11 +1709,11 @@ int libertas_cmd_80211_scan(wlan_private * priv, | |||
1622 | cmd->size = cpu_to_le16(sizeof(pscan->bsstype) + ETH_ALEN | 1709 | cmd->size = cpu_to_le16(sizeof(pscan->bsstype) + ETH_ALEN |
1623 | + pscancfg->tlvbufferlen + S_DS_GEN); | 1710 | + pscancfg->tlvbufferlen + S_DS_GEN); |
1624 | 1711 | ||
1625 | lbs_deb_scan("SCAN_CMD: command=%x, size=%x, seqnum=%x\n", | 1712 | lbs_deb_scan("SCAN_CMD: command 0x%04x, size %d, seqnum %d\n", |
1626 | le16_to_cpu(cmd->command), le16_to_cpu(cmd->size), | 1713 | le16_to_cpu(cmd->command), le16_to_cpu(cmd->size), |
1627 | le16_to_cpu(cmd->seqnum)); | 1714 | le16_to_cpu(cmd->seqnum)); |
1628 | 1715 | ||
1629 | lbs_deb_leave(LBS_DEB_ASSOC); | 1716 | lbs_deb_leave(LBS_DEB_SCAN); |
1630 | return 0; | 1717 | return 0; |
1631 | } | 1718 | } |
1632 | 1719 | ||
@@ -1645,6 +1732,8 @@ static inline int is_same_network(struct bss_descriptor *src, | |||
1645 | /** | 1732 | /** |
1646 | * @brief This function handles the command response of scan | 1733 | * @brief This function handles the command response of scan |
1647 | * | 1734 | * |
1735 | * Called from handle_cmd_response() in cmdrespc. | ||
1736 | * | ||
1648 | * The response buffer for the scan command has the following | 1737 | * The response buffer for the scan command has the following |
1649 | * memory layout: | 1738 | * memory layout: |
1650 | * | 1739 | * |
@@ -1679,7 +1768,7 @@ int libertas_ret_80211_scan(wlan_private * priv, struct cmd_ds_command *resp) | |||
1679 | int tlvbufsize; | 1768 | int tlvbufsize; |
1680 | int ret; | 1769 | int ret; |
1681 | 1770 | ||
1682 | lbs_deb_enter(LBS_DEB_ASSOC); | 1771 | lbs_deb_enter(LBS_DEB_SCAN); |
1683 | 1772 | ||
1684 | /* Prune old entries from scan table */ | 1773 | /* Prune old entries from scan table */ |
1685 | list_for_each_entry_safe (iter_bss, safe, &adapter->network_list, list) { | 1774 | list_for_each_entry_safe (iter_bss, safe, &adapter->network_list, list) { |