add the patch for #497771
This commit is contained in:
parent
dd8912773d
commit
cff725b80d
59
wpa_supplicant-0.6.8-disconnect-fixes.patch
Normal file
59
wpa_supplicant-0.6.8-disconnect-fixes.patch
Normal file
@ -0,0 +1,59 @@
|
||||
diff --git a/src/drivers/driver_wext.c b/src/drivers/driver_wext.c
|
||||
index e6242da..698e4f3 100644
|
||||
--- a/src/drivers/driver_wext.c
|
||||
+++ b/src/drivers/driver_wext.c
|
||||
@@ -1923,21 +1923,35 @@ static int wpa_driver_wext_mlme(struct wpa_driver_wext_data *drv,
|
||||
|
||||
static void wpa_driver_wext_disconnect(struct wpa_driver_wext_data *drv)
|
||||
{
|
||||
+ struct iwreq iwr;
|
||||
const u8 null_bssid[ETH_ALEN] = { 0, 0, 0, 0, 0, 0 };
|
||||
u8 ssid[32];
|
||||
int i;
|
||||
|
||||
- /*
|
||||
- * Clear the BSSID selection and set a random SSID to make sure the
|
||||
- * driver will not be trying to associate with something even if it
|
||||
- * does not understand SIOCSIWMLME commands (or tries to associate
|
||||
- * automatically after deauth/disassoc).
|
||||
+ /* Only force-disconnect when the card is in infrastructure mode,
|
||||
+ * otherwise the driver might interpret the cleared BSSID and random
|
||||
+ * SSID as an attempt to create a new ad-hoc network.
|
||||
*/
|
||||
- wpa_driver_wext_set_bssid(drv, null_bssid);
|
||||
+ os_memset(&iwr, 0, sizeof(iwr));
|
||||
+ os_strlcpy(iwr.ifr_name, drv->ifname, IFNAMSIZ);
|
||||
+ if (ioctl(drv->ioctl_sock, SIOCGIWMODE, &iwr) < 0) {
|
||||
+ perror("ioctl[SIOCGIWMODE]");
|
||||
+ iwr.u.mode = IW_MODE_INFRA;
|
||||
+ }
|
||||
|
||||
- for (i = 0; i < 32; i++)
|
||||
- ssid[i] = rand() & 0xFF;
|
||||
- wpa_driver_wext_set_ssid(drv, ssid, 32);
|
||||
+ if (iwr.u.mode == IW_MODE_INFRA) {
|
||||
+ /*
|
||||
+ * Clear the BSSID selection and set a random SSID to make sure
|
||||
+ * the driver will not be trying to associate with something
|
||||
+ * even if it does not understand SIOCSIWMLME commands (or tries
|
||||
+ * to associate automatically after deauth/disassoc).
|
||||
+ */
|
||||
+ wpa_driver_wext_set_bssid(drv, null_bssid);
|
||||
+
|
||||
+ for (i = 0; i < 32; i++)
|
||||
+ ssid[i] = rand() & 0xFF;
|
||||
+ wpa_driver_wext_set_ssid(drv, ssid, 32);
|
||||
+ }
|
||||
}
|
||||
|
||||
|
||||
@@ -1947,8 +1961,8 @@ static int wpa_driver_wext_deauthenticate(void *priv, const u8 *addr,
|
||||
struct wpa_driver_wext_data *drv = priv;
|
||||
int ret;
|
||||
wpa_printf(MSG_DEBUG, "%s", __FUNCTION__);
|
||||
- wpa_driver_wext_disconnect(drv);
|
||||
ret = wpa_driver_wext_mlme(drv, addr, IW_MLME_DEAUTH, reason_code);
|
||||
+ wpa_driver_wext_disconnect(drv);
|
||||
return ret;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user