AP: Update logging related to inactivity and disassociation

Add MAC addresses for stations and use wpa_msg instead of printf
methods to make it easier to grep logs and find messages for the
station in question.

Signed-off-by: Ben Greear <greearb@candelatech.com>
This commit is contained in:
Ben Greear 2011-02-24 17:44:45 +02:00 committed by Jouni Malinen
parent 1aae01fc04
commit 24d75245bd
2 changed files with 22 additions and 16 deletions

View File

@ -1192,20 +1192,20 @@ static void handle_deauth(struct hostapd_data *hapd,
struct sta_info *sta; struct sta_info *sta;
if (len < IEEE80211_HDRLEN + sizeof(mgmt->u.deauth)) { if (len < IEEE80211_HDRLEN + sizeof(mgmt->u.deauth)) {
printf("handle_deauth - too short payload (len=%lu)\n", wpa_msg(hapd, MSG_DEBUG, "handle_deauth - too short payload "
(unsigned long) len); "(len=%lu)", (unsigned long) len);
return; return;
} }
wpa_printf(MSG_DEBUG, "deauthentication: STA=" MACSTR wpa_msg(hapd, MSG_DEBUG, "deauthentication: STA=" MACSTR
" reason_code=%d", " reason_code=%d",
MAC2STR(mgmt->sa), MAC2STR(mgmt->sa), le_to_host16(mgmt->u.deauth.reason_code));
le_to_host16(mgmt->u.deauth.reason_code));
sta = ap_get_sta(hapd, mgmt->sa); sta = ap_get_sta(hapd, mgmt->sa);
if (sta == NULL) { if (sta == NULL) {
printf("Station " MACSTR " trying to deauthenticate, but it " wpa_msg(hapd, MSG_DEBUG, "Station " MACSTR " trying to "
"is not authenticated.\n", MAC2STR(mgmt->sa)); "deauthenticate, but it is not authenticated",
MAC2STR(mgmt->sa));
return; return;
} }
@ -1561,7 +1561,7 @@ void ieee802_11_mgmt(struct hostapd_data *hapd, const u8 *buf, size_t len,
handle_disassoc(hapd, mgmt, len); handle_disassoc(hapd, mgmt, len);
break; break;
case WLAN_FC_STYPE_DEAUTH: case WLAN_FC_STYPE_DEAUTH:
wpa_printf(MSG_DEBUG, "mgmt::deauth"); wpa_msg(hapd, MSG_DEBUG, "mgmt::deauth");
handle_deauth(hapd, mgmt, len); handle_deauth(hapd, mgmt, len);
break; break;
case WLAN_FC_STYPE_ACTION: case WLAN_FC_STYPE_ACTION:

View File

@ -273,27 +273,33 @@ void ap_handle_timer(void *eloop_ctx, void *timeout_ctx)
(sta->timeout_next == STA_NULLFUNC || (sta->timeout_next == STA_NULLFUNC ||
sta->timeout_next == STA_DISASSOC)) { sta->timeout_next == STA_DISASSOC)) {
int inactive_sec; int inactive_sec;
wpa_printf(MSG_DEBUG, "Checking STA " MACSTR " inactivity:",
MAC2STR(sta->addr));
inactive_sec = hostapd_drv_get_inact_sec(hapd, sta->addr); inactive_sec = hostapd_drv_get_inact_sec(hapd, sta->addr);
if (inactive_sec == -1) { if (inactive_sec == -1) {
wpa_printf(MSG_DEBUG, "Could not get station info " wpa_msg(hapd, MSG_DEBUG, "Check inactivity: Could not "
"from kernel driver for " MACSTR ".", "get station info rom kernel driver for "
MAC2STR(sta->addr)); MACSTR, MAC2STR(sta->addr));
} else if (inactive_sec < hapd->conf->ap_max_inactivity && } else if (inactive_sec < hapd->conf->ap_max_inactivity &&
sta->flags & WLAN_STA_ASSOC) { sta->flags & WLAN_STA_ASSOC) {
/* station activity detected; reset timeout state */ /* station activity detected; reset timeout state */
wpa_printf(MSG_DEBUG, " Station has been active"); wpa_msg(hapd, MSG_DEBUG, "Station " MACSTR " has been "
"active %is ago",
MAC2STR(sta->addr), inactive_sec);
sta->timeout_next = STA_NULLFUNC; sta->timeout_next = STA_NULLFUNC;
next_time = hapd->conf->ap_max_inactivity - next_time = hapd->conf->ap_max_inactivity -
inactive_sec; inactive_sec;
} else {
wpa_msg(hapd, MSG_DEBUG, "Station " MACSTR " has been "
"inactive too long: %d sec, max allowed: %d",
MAC2STR(sta->addr), inactive_sec,
hapd->conf->ap_max_inactivity);
} }
} }
if ((sta->flags & WLAN_STA_ASSOC) && if ((sta->flags & WLAN_STA_ASSOC) &&
sta->timeout_next == STA_DISASSOC && sta->timeout_next == STA_DISASSOC &&
!(sta->flags & WLAN_STA_PENDING_POLL)) { !(sta->flags & WLAN_STA_PENDING_POLL)) {
wpa_printf(MSG_DEBUG, " Station has ACKed data poll"); wpa_msg(hapd, MSG_DEBUG, "Station " MACSTR " has ACKed data "
"poll", MAC2STR(sta->addr));
/* data nullfunc frame poll did not produce TX errors; assume /* data nullfunc frame poll did not produce TX errors; assume
* station ACKed it */ * station ACKed it */
sta->timeout_next = STA_NULLFUNC; sta->timeout_next = STA_NULLFUNC;