AP MLD: Handle link_id in EAPOL RX handler
Add link ID support into EAPOL RX handler so that the events can be routed to the appropriate link BSSs. Signed-off-by: Sriram R <quic_srirrama@quicinc.com> Signed-off-by: Aditya Kumar Singh <quic_adisi@quicinc.com>
This commit is contained in:
parent
eea52c4b51
commit
a518810322
1 changed files with 2 additions and 53 deletions
|
@ -2023,38 +2023,6 @@ static struct hostapd_data * hostapd_find_by_sta(struct hostapd_iface *iface,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef CONFIG_IEEE80211BE
|
|
||||||
static bool search_mld_sta(struct hostapd_data **p_hapd, const u8 *src)
|
|
||||||
{
|
|
||||||
struct hostapd_data *hapd = *p_hapd;
|
|
||||||
unsigned int i;
|
|
||||||
|
|
||||||
/* Search for STA on other MLO BSSs */
|
|
||||||
for (i = 0; i < hapd->iface->interfaces->count; i++) {
|
|
||||||
struct hostapd_iface *h =
|
|
||||||
hapd->iface->interfaces->iface[i];
|
|
||||||
struct hostapd_data *h_hapd = h->bss[0];
|
|
||||||
|
|
||||||
if (!hostapd_is_ml_partner(h_hapd, hapd))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
h_hapd = hostapd_find_by_sta(h, src, false, NULL);
|
|
||||||
if (h_hapd) {
|
|
||||||
struct sta_info *sta = ap_get_sta(h_hapd, src);
|
|
||||||
|
|
||||||
if (sta && sta->mld_info.mld_sta &&
|
|
||||||
sta->mld_assoc_link_id != h_hapd->mld_link_id)
|
|
||||||
continue;
|
|
||||||
*p_hapd = h_hapd;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
#endif /* CONFIG_IEEE80211BE */
|
|
||||||
|
|
||||||
|
|
||||||
static void hostapd_event_eapol_rx(struct hostapd_data *hapd, const u8 *src,
|
static void hostapd_event_eapol_rx(struct hostapd_data *hapd, const u8 *src,
|
||||||
const u8 *data, size_t data_len,
|
const u8 *data, size_t data_len,
|
||||||
enum frame_encryption encrypted,
|
enum frame_encryption encrypted,
|
||||||
|
@ -2063,27 +2031,8 @@ static void hostapd_event_eapol_rx(struct hostapd_data *hapd, const u8 *src,
|
||||||
struct hostapd_data *orig_hapd = hapd;
|
struct hostapd_data *orig_hapd = hapd;
|
||||||
|
|
||||||
#ifdef CONFIG_IEEE80211BE
|
#ifdef CONFIG_IEEE80211BE
|
||||||
if (link_id != -1) {
|
hapd = switch_link_hapd(hapd, link_id);
|
||||||
struct hostapd_data *h_hapd;
|
hapd = hostapd_find_by_sta(hapd->iface, src, true, NULL);
|
||||||
|
|
||||||
hapd = switch_link_hapd(hapd, link_id);
|
|
||||||
h_hapd = hostapd_find_by_sta(hapd->iface, src, true, NULL);
|
|
||||||
if (!h_hapd)
|
|
||||||
h_hapd = hostapd_find_by_sta(orig_hapd->iface, src,
|
|
||||||
true, NULL);
|
|
||||||
if (!h_hapd)
|
|
||||||
h_hapd = hostapd_find_by_sta(hapd->iface, src, false,
|
|
||||||
NULL);
|
|
||||||
if (!h_hapd)
|
|
||||||
h_hapd = hostapd_find_by_sta(orig_hapd->iface, src,
|
|
||||||
false, NULL);
|
|
||||||
if (h_hapd)
|
|
||||||
hapd = h_hapd;
|
|
||||||
} else if (hapd->conf->mld_ap) {
|
|
||||||
search_mld_sta(&hapd, src);
|
|
||||||
} else {
|
|
||||||
hapd = hostapd_find_by_sta(hapd->iface, src, false, NULL);
|
|
||||||
}
|
|
||||||
#else /* CONFIG_IEEE80211BE */
|
#else /* CONFIG_IEEE80211BE */
|
||||||
hapd = hostapd_find_by_sta(hapd->iface, src, false, NULL);
|
hapd = hostapd_find_by_sta(hapd->iface, src, false, NULL);
|
||||||
#endif /* CONFIG_IEEE80211BE */
|
#endif /* CONFIG_IEEE80211BE */
|
||||||
|
|
Loading…
Reference in a new issue