2010-09-15 03:14:48 +00:00
|
|
|
--- a/src/drivers/driver_nl80211.c
|
|
|
|
+++ b/src/drivers/driver_nl80211.c
|
2012-03-27 10:42:47 +00:00
|
|
|
@@ -886,6 +886,10 @@ static void wpa_driver_nl80211_event_rtm
|
2010-09-15 03:14:48 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
+ if (ifi->ifi_family == AF_BRIDGE &&
|
|
|
|
+ drv->nlmode != NL80211_IFTYPE_AP)
|
|
|
|
+ return;
|
|
|
|
+
|
|
|
|
wpa_printf(MSG_DEBUG, "RTM_NEWLINK: operstate=%d ifi_flags=0x%x "
|
|
|
|
"(%s%s%s%s)",
|
|
|
|
drv->operstate, ifi->ifi_flags,
|
2012-03-27 10:42:47 +00:00
|
|
|
@@ -993,6 +997,10 @@ static void wpa_driver_nl80211_event_rtm
|
2010-09-15 03:14:48 +00:00
|
|
|
attrlen = len;
|
|
|
|
attr = (struct rtattr *) buf;
|
|
|
|
|
|
|
|
+ if (ifi->ifi_family == AF_BRIDGE &&
|
|
|
|
+ drv->nlmode != NL80211_IFTYPE_AP)
|
|
|
|
+ return;
|
|
|
|
+
|
|
|
|
rta_len = RTA_ALIGN(sizeof(struct rtattr));
|
|
|
|
while (RTA_OK(attr, attrlen)) {
|
|
|
|
if (attr->rta_type == IFLA_IFNAME) {
|
2012-03-27 10:42:47 +00:00
|
|
|
@@ -2920,6 +2928,11 @@ static void * wpa_driver_nl80211_init(vo
|
2011-11-04 01:05:26 +00:00
|
|
|
drv->ap_scan_as_station = NL80211_IFTYPE_UNSPECIFIED;
|
|
|
|
drv->nlmode = NL80211_IFTYPE_STATION;
|
2010-09-15 03:14:48 +00:00
|
|
|
|
2010-09-15 17:51:06 +00:00
|
|
|
+#ifdef HOSTAPD
|
2010-09-15 03:14:48 +00:00
|
|
|
+ drv->num_if_indices = sizeof(drv->default_if_indices) / sizeof(int);
|
|
|
|
+ drv->if_indices = drv->default_if_indices;
|
2010-09-15 17:51:06 +00:00
|
|
|
+#endif
|
2010-09-15 03:14:48 +00:00
|
|
|
+
|
2011-11-04 01:05:26 +00:00
|
|
|
if (wpa_driver_nl80211_init_nl(drv)) {
|
|
|
|
os_free(drv);
|
|
|
|
return NULL;
|
2012-03-27 10:42:47 +00:00
|
|
|
@@ -7654,8 +7667,6 @@ static void *i802_init(struct hostapd_da
|
2010-09-15 03:14:48 +00:00
|
|
|
br_ifindex = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
- drv->num_if_indices = sizeof(drv->default_if_indices) / sizeof(int);
|
|
|
|
- drv->if_indices = drv->default_if_indices;
|
|
|
|
for (i = 0; i < params->num_bridge; i++) {
|
|
|
|
if (params->bridge[i]) {
|
|
|
|
ifindex = if_nametoindex(params->bridge[i]);
|