AP MLD: MLD address conversion for hostapd_drv_send_action_addr3_ap()
Commit 31e025c033
("AP: When sending Action frames, use the AP MLD MAC
address if needed") added this for hostapd_drv_send_action(), but the
A3=BSSID variant of that function needs similar changes for GAS to work
correctly with STAs that are currently associated with MLO.
Signed-off-by: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
febb51bf87
commit
9ccfc0d516
1 changed files with 14 additions and 10 deletions
|
@ -882,9 +882,9 @@ int hostapd_drv_wnm_oper(struct hostapd_data *hapd, enum wnm_oper oper,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int hostapd_drv_send_action(struct hostapd_data *hapd, unsigned int freq,
|
static int hapd_drv_send_action(struct hostapd_data *hapd, unsigned int freq,
|
||||||
unsigned int wait, const u8 *dst, const u8 *data,
|
unsigned int wait, const u8 *dst,
|
||||||
size_t len)
|
const u8 *data, size_t len, bool addr3_ap)
|
||||||
{
|
{
|
||||||
const u8 *own_addr = hapd->own_addr;
|
const u8 *own_addr = hapd->own_addr;
|
||||||
const u8 *bssid;
|
const u8 *bssid;
|
||||||
|
@ -896,7 +896,7 @@ int hostapd_drv_send_action(struct hostapd_data *hapd, unsigned int freq,
|
||||||
if (!hapd->driver || !hapd->driver->send_action || !hapd->drv_priv)
|
if (!hapd->driver || !hapd->driver->send_action || !hapd->drv_priv)
|
||||||
return 0;
|
return 0;
|
||||||
bssid = hapd->own_addr;
|
bssid = hapd->own_addr;
|
||||||
if (!is_multicast_ether_addr(dst) &&
|
if (!addr3_ap && !is_multicast_ether_addr(dst) &&
|
||||||
len > 0 && data[0] == WLAN_ACTION_PUBLIC) {
|
len > 0 && data[0] == WLAN_ACTION_PUBLIC) {
|
||||||
/*
|
/*
|
||||||
* Public Action frames to a STA that is not a member of the BSS
|
* Public Action frames to a STA that is not a member of the BSS
|
||||||
|
@ -905,7 +905,7 @@ int hostapd_drv_send_action(struct hostapd_data *hapd, unsigned int freq,
|
||||||
sta = ap_get_sta(hapd, dst);
|
sta = ap_get_sta(hapd, dst);
|
||||||
if (!sta || !(sta->flags & WLAN_STA_ASSOC))
|
if (!sta || !(sta->flags & WLAN_STA_ASSOC))
|
||||||
bssid = wildcard_bssid;
|
bssid = wildcard_bssid;
|
||||||
} else if (is_broadcast_ether_addr(dst) &&
|
} else if (!addr3_ap && is_broadcast_ether_addr(dst) &&
|
||||||
len > 0 && data[0] == WLAN_ACTION_PUBLIC) {
|
len > 0 && data[0] == WLAN_ACTION_PUBLIC) {
|
||||||
/*
|
/*
|
||||||
* The only current use case of Public Action frames with
|
* The only current use case of Public Action frames with
|
||||||
|
@ -930,16 +930,20 @@ int hostapd_drv_send_action(struct hostapd_data *hapd, unsigned int freq,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int hostapd_drv_send_action(struct hostapd_data *hapd, unsigned int freq,
|
||||||
|
unsigned int wait, const u8 *dst, const u8 *data,
|
||||||
|
size_t len)
|
||||||
|
{
|
||||||
|
return hapd_drv_send_action(hapd, freq, wait, dst, data, len, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int hostapd_drv_send_action_addr3_ap(struct hostapd_data *hapd,
|
int hostapd_drv_send_action_addr3_ap(struct hostapd_data *hapd,
|
||||||
unsigned int freq,
|
unsigned int freq,
|
||||||
unsigned int wait, const u8 *dst,
|
unsigned int wait, const u8 *dst,
|
||||||
const u8 *data, size_t len)
|
const u8 *data, size_t len)
|
||||||
{
|
{
|
||||||
if (hapd->driver == NULL || hapd->driver->send_action == NULL)
|
return hapd_drv_send_action(hapd, freq, wait, dst, data, len, true);
|
||||||
return 0;
|
|
||||||
return hapd->driver->send_action(hapd->drv_priv, freq, wait, dst,
|
|
||||||
hapd->own_addr, hapd->own_addr, data,
|
|
||||||
len, 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue