mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-02 20:16:59 +00:00
hostapd: fix wpa_supplicant mac address allocation on ap+sta
If the full interface is restarted while bringing up an AP, it can trigger a
wpa_supplicant interface start before wpa_supplicant is notified of the
allocated mac addresses.
Fix this by moving the iface_update_supplicant_macaddr call to just after
the point where mac addresses are allocated.
Reported-by: Michael-cy Lee (李峻宇) <Michael-cy.Lee@mediatek.com>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
(cherry picked from commit abceef120d
)
This commit is contained in:
parent
186747a169
commit
02ed2b0271
@ -122,6 +122,14 @@ function iface_config_macaddr_list(config)
|
|||||||
return macaddr_list;
|
return macaddr_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function iface_update_supplicant_macaddr(phy, config)
|
||||||
|
{
|
||||||
|
let macaddr_list = [];
|
||||||
|
for (let i = 0; i < length(config.bss); i++)
|
||||||
|
push(macaddr_list, config.bss[i].bssid);
|
||||||
|
ubus.call("wpa_supplicant", "phy_set_macaddr_list", { phy: phy, macaddr: macaddr_list });
|
||||||
|
}
|
||||||
|
|
||||||
function iface_restart(phydev, config, old_config)
|
function iface_restart(phydev, config, old_config)
|
||||||
{
|
{
|
||||||
let phy = phydev.name;
|
let phy = phydev.name;
|
||||||
@ -142,6 +150,8 @@ function iface_restart(phydev, config, old_config)
|
|||||||
bss.bssid = phydev.macaddr_next();
|
bss.bssid = phydev.macaddr_next();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
iface_update_supplicant_macaddr(phy, config);
|
||||||
|
|
||||||
let bss = config.bss[0];
|
let bss = config.bss[0];
|
||||||
let err = wdev_create(phy, bss.ifname, { mode: "ap" });
|
let err = wdev_create(phy, bss.ifname, { mode: "ap" });
|
||||||
if (err)
|
if (err)
|
||||||
@ -498,14 +508,6 @@ function iface_reload_config(phydev, config, old_config)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function iface_update_supplicant_macaddr(phy, config)
|
|
||||||
{
|
|
||||||
let macaddr_list = [];
|
|
||||||
for (let i = 0; i < length(config.bss); i++)
|
|
||||||
push(macaddr_list, config.bss[i].bssid);
|
|
||||||
ubus.call("wpa_supplicant", "phy_set_macaddr_list", { phy: phy, macaddr: macaddr_list });
|
|
||||||
}
|
|
||||||
|
|
||||||
function iface_set_config(phy, config)
|
function iface_set_config(phy, config)
|
||||||
{
|
{
|
||||||
let old_config = hostapd.data.config[phy];
|
let old_config = hostapd.data.config[phy];
|
||||||
@ -536,7 +538,6 @@ function iface_set_config(phy, config)
|
|||||||
|
|
||||||
hostapd.printf(`Restart interface for phy ${phy}`);
|
hostapd.printf(`Restart interface for phy ${phy}`);
|
||||||
let ret = iface_restart(phydev, config, old_config);
|
let ret = iface_restart(phydev, config, old_config);
|
||||||
iface_update_supplicant_macaddr(phy, config);
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user