hostapd: shut down client mode on the same phy while restarting AP

An active client mode interface could prevent the AP from claiming its channel
and mess up the bringup sequence order

Signed-off-by: Felix Fietkau <nbd@nbd.name>
This commit is contained in:
Felix Fietkau 2023-08-11 15:45:14 +02:00
parent 80edfaf675
commit c1600df91f
2 changed files with 31 additions and 4 deletions

View File

@ -66,10 +66,12 @@ function iface_restart(phy, config, old_config)
if (err) if (err)
hostapd.printf(`Failed to create ${bss.ifname} on phy ${phy}: ${err}`); hostapd.printf(`Failed to create ${bss.ifname} on phy ${phy}: ${err}`);
let config_inline = iface_gen_config(phy, config); let config_inline = iface_gen_config(phy, config);
if (hostapd.add_iface(`bss_config=${bss.ifname}:${config_inline}`) < 0) {
let ubus = hostapd.data.ubus;
ubus.call("wpa_supplicant", "phy_set_state", { phy: phy, stop: true });
if (hostapd.add_iface(`bss_config=${bss.ifname}:${config_inline}`) < 0)
hostapd.printf(`hostapd.add_iface failed for phy ${phy} ifname=${bss.ifname}`); hostapd.printf(`hostapd.add_iface failed for phy ${phy} ifname=${bss.ifname}`);
return; ubus.call("wpa_supplicant", "phy_set_state", { phy: phy, stop: false });
}
} }
function array_to_obj(arr, key, start) function array_to_obj(arr, key, start)

View File

@ -11,6 +11,9 @@ function iface_stop(iface)
{ {
let ifname = iface.config.iface; let ifname = iface.config.iface;
if (!iface.running)
return;
delete wpas.data.iface_phy[ifname]; delete wpas.data.iface_phy[ifname];
wpas.remove_iface(ifname); wpas.remove_iface(ifname);
wdev_remove(ifname); wdev_remove(ifname);
@ -40,7 +43,7 @@ function iface_cb(new_if, old_if)
return; return;
} }
if (old_if && old_if.running) if (old_if)
iface_stop(old_if); iface_stop(old_if);
} }
@ -76,6 +79,28 @@ function start_pending(phy_name)
} }
let main_obj = { let main_obj = {
phy_set_state: {
args: {
phy: "",
stop: true,
},
call: function(req) {
if (!req.args.phy || req.args.stop == null)
return libubus.STATUS_INVALID_ARGUMENT;
let phy = wpas.data.config[req.args.phy];
if (!phy)
return libubus.STATUS_NOT_FOUND;
if (req.args.stop) {
for (let ifname in phy.data)
iface_stop(phy.data[ifname]);
} else {
start_pending(req.args.phy);
}
return 0;
}
},
config_set: { config_set: {
args: { args: {
phy: "", phy: "",