From e748062b58f790fe15d74201e904cf483d3362ea Mon Sep 17 00:00:00 2001 From: Jouni Malinen Date: Wed, 10 Feb 2010 11:29:53 +0200 Subject: [PATCH] nl80211: Do not try to remove non-existing STA WDS interface This removes confusing error messages from the default (no WDS) case. --- src/drivers/driver_nl80211.c | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/src/drivers/driver_nl80211.c b/src/drivers/driver_nl80211.c index 1f04779fb..25f18e498 100644 --- a/src/drivers/driver_nl80211.c +++ b/src/drivers/driver_nl80211.c @@ -2664,8 +2664,7 @@ static void nl80211_remove_iface(struct wpa_driver_nl80211_data *drv, if (send_and_recv_msgs(drv, msg, NULL, NULL) == 0) return; nla_put_failure: - wpa_printf(MSG_ERROR, "Failed to remove interface (ifidx=%d).\n", - ifidx); + wpa_printf(MSG_ERROR, "Failed to remove interface (ifidx=%d)", ifidx); } @@ -4218,9 +4217,11 @@ static int i802_set_sta_vlan(void *priv, const u8 *addr, static int i802_set_wds_sta(void *priv, const u8 *addr, int aid, int val) { struct wpa_driver_nl80211_data *drv = priv; - char name[16]; + char name[IFNAMSIZ + 1]; os_snprintf(name, sizeof(name), "%s.sta%d", drv->ifname, aid); + wpa_printf(MSG_DEBUG, "nl80211: Set WDS STA addr=" MACSTR + " aid=%d val=%d name=%s", MAC2STR(addr), aid, val, name); if (val) { if (nl80211_create_iface(priv, name, NL80211_IFTYPE_AP_VLAN, NULL, 1) < 0) @@ -4537,6 +4538,10 @@ static int wpa_driver_nl80211_if_remove(void *priv, struct wpa_driver_nl80211_data *drv = priv; int ifindex = if_nametoindex(ifname); + wpa_printf(MSG_DEBUG, "nl80211: %s(type=%d ifname=%s) ifindex=%d", + __func__, type, ifname, ifindex); + if (ifindex <= 0) + return -1; nl80211_remove_iface(drv, ifindex); #ifdef HOSTAPD