From d567479153b9db89213ecd9c42188abfc37c79ba Mon Sep 17 00:00:00 2001 From: Jouni Malinen Date: Mon, 2 Jan 2012 21:27:06 +0200 Subject: [PATCH] Do not disconnect STA based on inactivity on driver failure Now that we can use driver_nl80211.c with non-mac80211 drivers that implement SME/MLME internally, we may not get inactivity time from the driver. If that is the case, we need to skip disconnection based on maximum inactivity timeout. This fixes some unexpected disconnection cases with ath6kl in AP mode. Signed-hostap: Jouni Malinen --- src/ap/sta_info.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/ap/sta_info.c b/src/ap/sta_info.c index 972a72367..0366e40fb 100644 --- a/src/ap/sta_info.c +++ b/src/ap/sta_info.c @@ -284,8 +284,14 @@ void ap_handle_timer(void *eloop_ctx, void *timeout_ctx) if (inactive_sec == -1) { wpa_msg(hapd->msg_ctx, MSG_DEBUG, "Check inactivity: Could not " - "get station info rom kernel driver for " + "get station info from kernel driver for " MACSTR, MAC2STR(sta->addr)); + /* + * The driver may not support this functionality. + * Anyway, try again after the next inactivity timeout, + * but do not disconnect the station now. + */ + next_time = hapd->conf->ap_max_inactivity; } else if (inactive_sec < hapd->conf->ap_max_inactivity && sta->flags & WLAN_STA_ASSOC) { /* station activity detected; reset timeout state */