73949dd386f669db762d1b5dac1d89b6a27cc897
[openwrt/openwrt.git] / package / network / services / hostapd / patches / 100-pending_work.patch
1 --- a/src/ap/ieee802_11.c
2 +++ b/src/ap/ieee802_11.c
3 @@ -1506,13 +1506,6 @@ static void handle_assoc_cb(struct hosta
4 int new_assoc = 1;
5 struct ieee80211_ht_capabilities ht_cap;
6
7 - if (!ok) {
8 - hostapd_logger(hapd, mgmt->da, HOSTAPD_MODULE_IEEE80211,
9 - HOSTAPD_LEVEL_DEBUG,
10 - "did not acknowledge association response");
11 - return;
12 - }
13 -
14 if (len < IEEE80211_HDRLEN + (reassoc ? sizeof(mgmt->u.reassoc_resp) :
15 sizeof(mgmt->u.assoc_resp))) {
16 printf("handle_assoc_cb(reassoc=%d) - too short payload "
17 @@ -1520,11 +1513,6 @@ static void handle_assoc_cb(struct hosta
18 return;
19 }
20
21 - if (reassoc)
22 - status = le_to_host16(mgmt->u.reassoc_resp.status_code);
23 - else
24 - status = le_to_host16(mgmt->u.assoc_resp.status_code);
25 -
26 sta = ap_get_sta(hapd, mgmt->da);
27 if (!sta) {
28 printf("handle_assoc_cb: STA " MACSTR " not found\n",
29 @@ -1532,6 +1520,19 @@ static void handle_assoc_cb(struct hosta
30 return;
31 }
32
33 + if (!ok) {
34 + hostapd_logger(hapd, mgmt->da, HOSTAPD_MODULE_IEEE80211,
35 + HOSTAPD_LEVEL_DEBUG,
36 + "did not acknowledge association response");
37 + sta->flags &= ~WLAN_STA_ASSOC_REQ_OK;
38 + return;
39 + }
40 +
41 + if (reassoc)
42 + status = le_to_host16(mgmt->u.reassoc_resp.status_code);
43 + else
44 + status = le_to_host16(mgmt->u.assoc_resp.status_code);
45 +
46 if (status != WLAN_STATUS_SUCCESS)
47 goto fail;
48
49 @@ -1830,6 +1831,9 @@ void ieee802_11_rx_from_unknown(struct h
50
51 sta = ap_get_sta(hapd, src);
52 if (sta && (sta->flags & WLAN_STA_ASSOC)) {
53 + if (!hapd->conf->wds_sta)
54 + return;
55 +
56 if (wds && !(sta->flags & WLAN_STA_WDS)) {
57 wpa_printf(MSG_DEBUG, "Enable 4-address WDS mode for "
58 "STA " MACSTR " (aid %u)",
59 --- a/src/drivers/driver_nl80211.c
60 +++ b/src/drivers/driver_nl80211.c
61 @@ -2661,10 +2661,10 @@ static int wpa_driver_nl80211_capa(struc
62 drv->data_tx_status = info.data_tx_status;
63
64 /*
65 - * If poll command is supported mac80211 is new enough to
66 - * have everything we need to not need monitor interfaces.
67 + * If poll command and tx status are supported, mac80211 is new enough
68 + * to have everything we need to not need monitor interfaces.
69 */
70 - drv->use_monitor = !info.poll_command_supported;
71 + drv->use_monitor = !info.poll_command_supported || !info.data_tx_status;
72
73 if (drv->device_ap_sme && drv->use_monitor) {
74 /*
75 @@ -6392,8 +6392,8 @@ static int wpa_driver_nl80211_hapd_send_
76 pos = (u8 *) (hdr + 1);
77
78 if (qos) {
79 - /* add an empty QoS header if needed */
80 - pos[0] = 0;
81 + /* Set highest priority in QoS header */
82 + pos[0] = 7;
83 pos[1] = 0;
84 pos += 2;
85 }
86 @@ -7698,6 +7698,10 @@ static int i802_set_wds_sta(void *priv,
87 }
88 return i802_set_sta_vlan(priv, addr, name, 0);
89 } else {
90 + if (bridge_ifname)
91 + linux_br_del_if(drv->global->ioctl_sock, bridge_ifname,
92 + name);
93 +
94 i802_set_sta_vlan(priv, addr, bss->ifname, 0);
95 return wpa_driver_nl80211_if_remove(priv, WPA_IF_AP_VLAN,
96 name);
97 @@ -8065,7 +8069,12 @@ static int wpa_driver_nl80211_if_remove(
98 if (ifindex <= 0)
99 return -1;
100
101 + nl80211_remove_iface(drv, ifindex);
102 +
103 #ifdef HOSTAPD
104 + if (type != WPA_IF_AP_BSS)
105 + return 0;
106 +
107 if (bss->added_if_into_bridge) {
108 if (linux_br_del_if(drv->global->ioctl_sock, bss->brname,
109 bss->ifname) < 0)
110 @@ -8079,13 +8088,6 @@ static int wpa_driver_nl80211_if_remove(
111 "bridge %s: %s",
112 bss->brname, strerror(errno));
113 }
114 -#endif /* HOSTAPD */
115 -
116 - nl80211_remove_iface(drv, ifindex);
117 -
118 -#ifdef HOSTAPD
119 - if (type != WPA_IF_AP_BSS)
120 - return 0;
121
122 if (bss != &drv->first_bss) {
123 struct i802_bss *tbss;
124 --- a/src/ap/drv_callbacks.c
125 +++ b/src/ap/drv_callbacks.c
126 @@ -672,12 +672,15 @@ static void hostapd_event_eapol_rx(struc
127 const u8 *data, size_t data_len)
128 {
129 struct hostapd_iface *iface = hapd->iface;
130 + struct sta_info *sta;
131 size_t j;
132
133 for (j = 0; j < iface->num_bss; j++) {
134 - if (ap_get_sta(iface->bss[j], src)) {
135 - hapd = iface->bss[j];
136 - break;
137 + if ((sta = ap_get_sta(iface->bss[j], src))) {
138 + if (sta->flags & WLAN_STA_ASSOC) {
139 + hapd = iface->bss[j];
140 + break;
141 + }
142 }
143 }
144
145 --- a/src/eap_peer/eap.c
146 +++ b/src/eap_peer/eap.c
147 @@ -348,6 +348,7 @@ SM_STATE(EAP, METHOD)
148 {
149 struct wpabuf *eapReqData;
150 struct eap_method_ret ret;
151 + int min_len = 1;
152
153 SM_ENTRY(EAP, METHOD);
154 if (sm->m == NULL) {
155 @@ -356,7 +357,9 @@ SM_STATE(EAP, METHOD)
156 }
157
158 eapReqData = eapol_get_eapReqData(sm);
159 - if (!eap_hdr_len_valid(eapReqData, 1))
160 + if (sm->m->vendor == EAP_VENDOR_IETF && sm->m->method == EAP_TYPE_LEAP)
161 + min_len = 0; /* LEAP uses EAP-Success without payload */
162 + if (!eap_hdr_len_valid(eapReqData, min_len))
163 return;
164
165 /*