aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/wireless/libertas/scan.c113
-rw-r--r--drivers/net/wireless/libertas/scan.h8
2 files changed, 49 insertions, 72 deletions
diff --git a/drivers/net/wireless/libertas/scan.c b/drivers/net/wireless/libertas/scan.c
index e18706238951..ff1270e1b694 100644
--- a/drivers/net/wireless/libertas/scan.c
+++ b/drivers/net/wireless/libertas/scan.c
@@ -95,10 +95,9 @@ static int is_network_compatible(wlan_adapter * adapter, int index, int mode)
95 if (adapter->secinfo.WEPstatus == wlan802_11WEPdisabled 95 if (adapter->secinfo.WEPstatus == wlan802_11WEPdisabled
96 && !adapter->secinfo.WPAenabled 96 && !adapter->secinfo.WPAenabled
97 && !adapter->secinfo.WPA2enabled 97 && !adapter->secinfo.WPA2enabled
98 && adapter->scantable[index].wpa_supplicant.wpa_ie[0] != 98 && adapter->scantable[index].wpa_ie[0] != WPA_IE
99 WPA_IE 99 && adapter->scantable[index].rsn_ie[0] != WPA2_IE
100 && adapter->scantable[index].wpa2_supplicant.wpa_ie[0] != 100 && adapter->secinfo.Encryptionmode == CIPHER_NONE
101 WPA2_IE && adapter->secinfo.Encryptionmode == CIPHER_NONE
102 && !adapter->scantable[index].privacy) { 101 && !adapter->scantable[index].privacy) {
103 /* no security */ 102 /* no security */
104 LEAVE(); 103 LEAVE();
@@ -113,21 +112,17 @@ static int is_network_compatible(wlan_adapter * adapter, int index, int mode)
113 } else if (adapter->secinfo.WEPstatus == wlan802_11WEPdisabled 112 } else if (adapter->secinfo.WEPstatus == wlan802_11WEPdisabled
114 && adapter->secinfo.WPAenabled 113 && adapter->secinfo.WPAenabled
115 && !adapter->secinfo.WPA2enabled 114 && !adapter->secinfo.WPA2enabled
116 && (adapter->scantable[index].wpa_supplicant. 115 && (adapter->scantable[index].wpa_ie[0] == WPA_IE)
117 wpa_ie[0]
118 == WPA_IE)
119 /* privacy bit may NOT be set in some APs like LinkSys WRT54G 116 /* privacy bit may NOT be set in some APs like LinkSys WRT54G
120 && adapter->scantable[index].privacy */ 117 && adapter->scantable[index].privacy */
121 ) { 118 ) {
122 /* WPA enabled */ 119 /* WPA enabled */
123 lbs_pr_debug(1, 120 lbs_pr_debug(1,
124 "is_network_compatible() WPA: index=%d wpa_ie=%#x " 121 "is_network_compatible() WPA: index=%d wpa_ie=%#x "
125 "wpa2_ie=%#x WEP=%s WPA=%s WPA2=%s Encmode=%#x " 122 "wpa2_ie=%#x WEP=%s WPA=%s WPA2=%s Encmode=%#x "
126 "privacy=%#x\n", index, 123 "privacy=%#x\n", index,
127 adapter->scantable[index].wpa_supplicant. 124 adapter->scantable[index].wpa_ie[0],
128 wpa_ie[0], 125 adapter->scantable[index].rsn_ie[0],
129 adapter->scantable[index].wpa2_supplicant.
130 wpa_ie[0],
131 (adapter->secinfo.WEPstatus == 126 (adapter->secinfo.WEPstatus ==
132 wlan802_11WEPenabled) ? "e" : "d", 127 wlan802_11WEPenabled) ? "e" : "d",
133 (adapter->secinfo.WPAenabled) ? "e" : "d", 128 (adapter->secinfo.WPAenabled) ? "e" : "d",
@@ -139,21 +134,17 @@ static int is_network_compatible(wlan_adapter * adapter, int index, int mode)
139 } else if (adapter->secinfo.WEPstatus == wlan802_11WEPdisabled 134 } else if (adapter->secinfo.WEPstatus == wlan802_11WEPdisabled
140 && !adapter->secinfo.WPAenabled 135 && !adapter->secinfo.WPAenabled
141 && adapter->secinfo.WPA2enabled 136 && adapter->secinfo.WPA2enabled
142 && (adapter->scantable[index].wpa2_supplicant. 137 && (adapter->scantable[index].rsn_ie[0] == WPA2_IE)
143 wpa_ie[0]
144 == WPA2_IE)
145 /* privacy bit may NOT be set in some APs like LinkSys WRT54G 138 /* privacy bit may NOT be set in some APs like LinkSys WRT54G
146 && adapter->scantable[index].privacy */ 139 && adapter->scantable[index].privacy */
147 ) { 140 ) {
148 /* WPA2 enabled */ 141 /* WPA2 enabled */
149 lbs_pr_debug(1, 142 lbs_pr_debug(1,
150 "is_network_compatible() WPA2: index=%d wpa_ie=%#x " 143 "is_network_compatible() WPA2: index=%d wpa_ie=%#x "
151 "wpa2_ie=%#x WEP=%s WPA=%s WPA2=%s Encmode=%#x " 144 "wpa2_ie=%#x WEP=%s WPA=%s WPA2=%s Encmode=%#x "
152 "privacy=%#x\n", index, 145 "privacy=%#x\n", index,
153 adapter->scantable[index].wpa_supplicant. 146 adapter->scantable[index].wpa_ie[0],
154 wpa_ie[0], 147 adapter->scantable[index].rsn_ie[0],
155 adapter->scantable[index].wpa2_supplicant.
156 wpa_ie[0],
157 (adapter->secinfo.WEPstatus == 148 (adapter->secinfo.WEPstatus ==
158 wlan802_11WEPenabled) ? "e" : "d", 149 wlan802_11WEPenabled) ? "e" : "d",
159 (adapter->secinfo.WPAenabled) ? "e" : "d", 150 (adapter->secinfo.WPAenabled) ? "e" : "d",
@@ -165,35 +156,30 @@ static int is_network_compatible(wlan_adapter * adapter, int index, int mode)
165 } else if (adapter->secinfo.WEPstatus == wlan802_11WEPdisabled 156 } else if (adapter->secinfo.WEPstatus == wlan802_11WEPdisabled
166 && !adapter->secinfo.WPAenabled 157 && !adapter->secinfo.WPAenabled
167 && !adapter->secinfo.WPA2enabled 158 && !adapter->secinfo.WPA2enabled
168 && (adapter->scantable[index].wpa_supplicant. 159 && (adapter->scantable[index].wpa_ie[0] != WPA_IE)
169 wpa_ie[0] 160 && (adapter->scantable[index].rsn_ie[0] != WPA2_IE)
170 != WPA_IE)
171 && (adapter->scantable[index].wpa2_supplicant.
172 wpa_ie[0]
173 != WPA2_IE)
174 && adapter->secinfo.Encryptionmode != CIPHER_NONE 161 && adapter->secinfo.Encryptionmode != CIPHER_NONE
175 && adapter->scantable[index].privacy) { 162 && adapter->scantable[index].privacy) {
176 /* dynamic WEP enabled */ 163 /* dynamic WEP enabled */
177 lbs_pr_debug(1, 164 lbs_pr_debug(1,
178 "is_network_compatible() dynamic WEP: index=%d " 165 "is_network_compatible() dynamic WEP: index=%d "
179 "wpa_ie=%#x wpa2_ie=%#x Encmode=%#x privacy=%#x\n", 166 "wpa_ie=%#x wpa2_ie=%#x Encmode=%#x privacy=%#x\n",
180 index, 167 index,
181 adapter->scantable[index].wpa_supplicant. 168 adapter->scantable[index].wpa_ie[0],
182 wpa_ie[0], 169 adapter->scantable[index].rsn_ie[0],
183 adapter->scantable[index].wpa2_supplicant. 170 adapter->secinfo.Encryptionmode,
184 wpa_ie[0], adapter->secinfo.Encryptionmode,
185 adapter->scantable[index].privacy); 171 adapter->scantable[index].privacy);
186 LEAVE(); 172 LEAVE();
187 return index; 173 return index;
188 } 174 }
189 175
190 /* security doesn't match */ 176 /* security doesn't match */
191 lbs_pr_debug(1, 177 lbs_pr_debug(1,
192 "is_network_compatible() FAILED: index=%d wpa_ie=%#x " 178 "is_network_compatible() FAILED: index=%d wpa_ie=%#x "
193 "wpa2_ie=%#x WEP=%s WPA=%s WPA2=%s Encmode=%#x privacy=%#x\n", 179 "wpa2_ie=%#x WEP=%s WPA=%s WPA2=%s Encmode=%#x privacy=%#x\n",
194 index, 180 index,
195 adapter->scantable[index].wpa_supplicant.wpa_ie[0], 181 adapter->scantable[index].wpa_ie[0],
196 adapter->scantable[index].wpa2_supplicant.wpa_ie[0], 182 adapter->scantable[index].rsn_ie[0],
197 (adapter->secinfo.WEPstatus == 183 (adapter->secinfo.WEPstatus ==
198 wlan802_11WEPenabled) ? "e" : "d", 184 wlan802_11WEPenabled) ? "e" : "d",
199 (adapter->secinfo.WPAenabled) ? "e" : "d", 185 (adapter->secinfo.WPAenabled) ? "e" : "d",
@@ -924,8 +910,6 @@ static int InterpretBSSDescriptionWithIE(struct bss_descriptor * pBSSEntry,
924 u8 founddatarateie; 910 u8 founddatarateie;
925 int bytesleftforcurrentbeacon; 911 int bytesleftforcurrentbeacon;
926 912
927 struct WPA_SUPPLICANT *pwpa_supplicant;
928 struct WPA_SUPPLICANT *pwpa2_supplicant;
929 struct IE_WPA *pIe; 913 struct IE_WPA *pIe;
930 const u8 oui01[4] = { 0x00, 0x50, 0xf2, 0x01 }; 914 const u8 oui01[4] = { 0x00, 0x50, 0xf2, 0x01 };
931 915
@@ -962,9 +946,6 @@ static int InterpretBSSDescriptionWithIE(struct bss_descriptor * pBSSEntry,
962 946
963 bytesleftforcurrentbeacon = beaconsize; 947 bytesleftforcurrentbeacon = beaconsize;
964 948
965 pwpa_supplicant = &pBSSEntry->wpa_supplicant;
966 pwpa2_supplicant = &pBSSEntry->wpa2_supplicant;
967
968 memcpy(pBSSEntry->macaddress, pcurrentptr, ETH_ALEN); 949 memcpy(pBSSEntry->macaddress, pcurrentptr, ETH_ALEN);
969 lbs_pr_debug(1, "InterpretIE: AP MAC Addr-%x:%x:%x:%x:%x:%x\n", 950 lbs_pr_debug(1, "InterpretIE: AP MAC Addr-%x:%x:%x:%x:%x:%x\n",
970 pBSSEntry->macaddress[0], pBSSEntry->macaddress[1], 951 pBSSEntry->macaddress[0], pBSSEntry->macaddress[1],
@@ -1160,27 +1141,27 @@ static int InterpretBSSDescriptionWithIE(struct bss_descriptor * pBSSEntry,
1160#define IE_ID_LEN_FIELDS_BYTES 2 1141#define IE_ID_LEN_FIELDS_BYTES 2
1161 pIe = (struct IE_WPA *)pcurrentptr; 1142 pIe = (struct IE_WPA *)pcurrentptr;
1162 1143
1163 if (!memcmp(pIe->oui, oui01, sizeof(oui01))) { 1144 if (memcmp(pIe->oui, oui01, sizeof(oui01)))
1164 pwpa_supplicant->wpa_ie_len 1145 break;
1165 = min_t(size_t, elemlen + IE_ID_LEN_FIELDS_BYTES, 1146
1166 sizeof(pwpa_supplicant->wpa_ie)); 1147 pBSSEntry->wpa_ie_len = min_t(size_t,
1167 memcpy(pwpa_supplicant->wpa_ie, 1148 elemlen + IE_ID_LEN_FIELDS_BYTES,
1168 pcurrentptr, 1149 sizeof(pBSSEntry->wpa_ie));
1169 pwpa_supplicant->wpa_ie_len); 1150 memcpy(pBSSEntry->wpa_ie, pcurrentptr,
1170 lbs_dbg_hex("InterpretIE: Resp WPA_IE", 1151 pBSSEntry->wpa_ie_len);
1171 pwpa_supplicant->wpa_ie, elemlen); 1152 lbs_dbg_hex("InterpretIE: Resp WPA_IE",
1172 } 1153 pBSSEntry->wpa_ie, elemlen);
1173 break; 1154 break;
1174 case WPA2_IE: 1155 case WPA2_IE:
1175 pIe = (struct IE_WPA *)pcurrentptr; 1156 pIe = (struct IE_WPA *)pcurrentptr;
1176 pwpa2_supplicant->wpa_ie_len
1177 = min_t(size_t, elemlen + IE_ID_LEN_FIELDS_BYTES,
1178 sizeof(pwpa2_supplicant->wpa_ie));
1179 memcpy(pwpa2_supplicant->wpa_ie,
1180 pcurrentptr, pwpa2_supplicant->wpa_ie_len);
1181 1157
1158 pBSSEntry->rsn_ie_len = min_t(size_t,
1159 elemlen + IE_ID_LEN_FIELDS_BYTES,
1160 sizeof(pBSSEntry->rsn_ie));
1161 memcpy(pBSSEntry->rsn_ie, pcurrentptr,
1162 pBSSEntry->rsn_ie_len);
1182 lbs_dbg_hex("InterpretIE: Resp WPA2_IE", 1163 lbs_dbg_hex("InterpretIE: Resp WPA2_IE",
1183 pwpa2_supplicant->wpa_ie, elemlen); 1164 pBSSEntry->rsn_ie, elemlen);
1184 break; 1165 break;
1185 case TIM: 1166 case TIM:
1186 break; 1167 break;
@@ -1745,30 +1726,24 @@ int libertas_get_scan(struct net_device *dev, struct iw_request_info *info,
1745 /* Add new value to event */ 1726 /* Add new value to event */
1746 current_val = current_ev + IW_EV_LCP_LEN; 1727 current_val = current_ev + IW_EV_LCP_LEN;
1747 1728
1748 if (adapter->scantable[i].wpa2_supplicant.wpa_ie[0] == WPA2_IE) { 1729 if (adapter->scantable[i].rsn_ie[0] == WPA2_IE) {
1749 memset(&iwe, 0, sizeof(iwe)); 1730 memset(&iwe, 0, sizeof(iwe));
1750 memset(buf, 0, sizeof(buf)); 1731 memset(buf, 0, sizeof(buf));
1751 memcpy(buf, adapter->scantable[i]. 1732 memcpy(buf, adapter->scantable[i].rsn_ie,
1752 wpa2_supplicant.wpa_ie, 1733 adapter->scantable[i].rsn_ie_len);
1753 adapter->scantable[i].wpa2_supplicant.
1754 wpa_ie_len);
1755 iwe.cmd = IWEVGENIE; 1734 iwe.cmd = IWEVGENIE;
1756 iwe.u.data.length = adapter->scantable[i]. 1735 iwe.u.data.length = adapter->scantable[i].rsn_ie_len;
1757 wpa2_supplicant.wpa_ie_len;
1758 iwe.len = IW_EV_POINT_LEN + iwe.u.data.length; 1736 iwe.len = IW_EV_POINT_LEN + iwe.u.data.length;
1759 current_ev = iwe_stream_add_point(current_ev, end_buf, 1737 current_ev = iwe_stream_add_point(current_ev, end_buf,
1760 &iwe, buf); 1738 &iwe, buf);
1761 } 1739 }
1762 if (adapter->scantable[i].wpa_supplicant.wpa_ie[0] == WPA_IE) { 1740 if (adapter->scantable[i].wpa_ie[0] == WPA_IE) {
1763 memset(&iwe, 0, sizeof(iwe)); 1741 memset(&iwe, 0, sizeof(iwe));
1764 memset(buf, 0, sizeof(buf)); 1742 memset(buf, 0, sizeof(buf));
1765 memcpy(buf, adapter->scantable[i]. 1743 memcpy(buf, adapter->scantable[i].wpa_ie,
1766 wpa_supplicant.wpa_ie, 1744 adapter->scantable[i].wpa_ie_len);
1767 adapter->scantable[i].wpa_supplicant.
1768 wpa_ie_len);
1769 iwe.cmd = IWEVGENIE; 1745 iwe.cmd = IWEVGENIE;
1770 iwe.u.data.length = adapter->scantable[i]. 1746 iwe.u.data.length = adapter->scantable[i].wpa_ie_len;
1771 wpa_supplicant.wpa_ie_len;
1772 iwe.len = IW_EV_POINT_LEN + iwe.u.data.length; 1747 iwe.len = IW_EV_POINT_LEN + iwe.u.data.length;
1773 current_ev = iwe_stream_add_point(current_ev, end_buf, 1748 current_ev = iwe_stream_add_point(current_ev, end_buf,
1774 &iwe, buf); 1749 &iwe, buf);
diff --git a/drivers/net/wireless/libertas/scan.h b/drivers/net/wireless/libertas/scan.h
index d93aa7fa44fd..1a8756edfeb5 100644
--- a/drivers/net/wireless/libertas/scan.h
+++ b/drivers/net/wireless/libertas/scan.h
@@ -10,6 +10,7 @@
10#ifndef _WLAN_SCAN_H 10#ifndef _WLAN_SCAN_H
11#define _WLAN_SCAN_H 11#define _WLAN_SCAN_H
12 12
13#include <net/ieee80211.h>
13#include "hostcmd.h" 14#include "hostcmd.h"
14 15
15/** 16/**
@@ -170,9 +171,10 @@ struct bss_descriptor {
170 171
171 struct ieeetypes_countryinfofullset countryinfo; 172 struct ieeetypes_countryinfofullset countryinfo;
172 173
173 struct WPA_SUPPLICANT wpa_supplicant; 174 u8 wpa_ie[MAX_WPA_IE_LEN];
174 struct WPA_SUPPLICANT wpa2_supplicant; 175 size_t wpa_ie_len;
175 176 u8 rsn_ie[MAX_WPA_IE_LEN];
177 size_t rsn_ie_len;
176}; 178};
177 179
178extern int libertas_SSID_cmp(struct WLAN_802_11_SSID *ssid1, 180extern int libertas_SSID_cmp(struct WLAN_802_11_SSID *ssid1,