summaryrefslogtreecommitdiffstats
path: root/package/hostapd
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2010-09-15 03:14:48 +0000
committerFelix Fietkau <nbd@openwrt.org>2010-09-15 03:14:48 +0000
commit7fb38706717f34fd2ccc41f2860cff43d3c91898 (patch)
treeb784968634073e6293a793c1b9a97b950496e745 /package/hostapd
parent7557011cb170afb8f737c19b1e3b30290428edfd (diff)
downloadmaster-31e0f0ae-7fb38706717f34fd2ccc41f2860cff43d3c91898.tar.gz
master-31e0f0ae-7fb38706717f34fd2ccc41f2860cff43d3c91898.tar.bz2
master-31e0f0ae-7fb38706717f34fd2ccc41f2860cff43d3c91898.zip
hostapd: fix wpa_supplicant crash issues in WDS STA mode
SVN-Revision: 23067
Diffstat (limited to 'package/hostapd')
-rw-r--r--package/hostapd/patches/430-supplicant_bridge_fix.patch43
1 files changed, 43 insertions, 0 deletions
diff --git a/package/hostapd/patches/430-supplicant_bridge_fix.patch b/package/hostapd/patches/430-supplicant_bridge_fix.patch
new file mode 100644
index 0000000000..483c53f9d1
--- /dev/null
+++ b/package/hostapd/patches/430-supplicant_bridge_fix.patch
@@ -0,0 +1,43 @@
+--- a/src/drivers/driver_nl80211.c
++++ b/src/drivers/driver_nl80211.c
+@@ -410,6 +410,10 @@ static void wpa_driver_nl80211_event_rtm
+ 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,
+@@ -481,6 +485,10 @@ static void wpa_driver_nl80211_event_rtm
+ 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) {
+@@ -1347,6 +1355,9 @@ static int wpa_driver_nl80211_init_nl(st
+ eloop_register_read_sock(nl_socket_get_fd(drv->nl_handle_event),
+ wpa_driver_nl80211_event_receive, drv, ctx);
+
++ drv->num_if_indices = sizeof(drv->default_if_indices) / sizeof(int);
++ drv->if_indices = drv->default_if_indices;
++
+ return 0;
+
+ err4:
+@@ -4867,8 +4878,6 @@ static void *i802_init(struct hostapd_da
+ 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]);