From 0cdb93fe9ffe2bfb125f6f758f837a09e7762155 Mon Sep 17 00:00:00 2001 From: Jouni Malinen Date: Sun, 12 May 2013 19:12:29 +0300 Subject: [PATCH] Do not add BSS to blacklist on local disconnection request There is no point in marking a BSS temporarily blacklisted based on a connection failure or disconnection case if that happens as a result of a local request to disconnect. The blacklist entry could result on unexpected BSS getting selected on the next connection attempt. In addition, the code to try to find another BSS within the ESS could result in scanning a single channel on the next attempt. Fix these issues by handling the connection failure events only if we are not in disconnected state (i.e., would try to reconnect after this automatically). Signed-hostap: Jouni Malinen --- wpa_supplicant/wpa_supplicant.c | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/wpa_supplicant/wpa_supplicant.c b/wpa_supplicant/wpa_supplicant.c index c9ad4caf8..f0e1d4e45 100644 --- a/wpa_supplicant/wpa_supplicant.c +++ b/wpa_supplicant/wpa_supplicant.c @@ -3525,6 +3525,17 @@ void wpas_connection_failed(struct wpa_supplicant *wpa_s, const u8 *bssid) */ eloop_cancel_timeout(wpa_supplicant_timeout, wpa_s, NULL); + if (wpa_s->disconnected) { + /* + * There is no point in blacklisting the AP if this event is + * generated based on local request to disconnect. + */ + wpa_dbg(wpa_s, MSG_DEBUG, "Ignore connection failure " + "indication since interface has been put into " + "disconnected state"); + return; + } + /* * Add the failed BSSID into the blacklist and speed up next scan * attempt if there could be other APs that could accept association.