[PATCH] nl80211: Send RTM_SETLINK to the correct interface for extra BSSs
Rafał Miłecki
zajec5 at gmail.com
Mon Sep 22 23:26:12 PDT 2025
W dniu 23.07.2025 o 13:48, Rafał Miłecki pisze:
> From: Rafał Miłecki <rafal at milecki.pl>
>
> Modify wpa_driver_nl80211_set_operstate() to use BSS's ifindex instead
> of the main one. This results in calling RTM_SETLINK for interface that
> is actually used for a given BSS. It helps kernel to maintain proper
> "operstate" values.
>
> I noticed this "operstate" issue when working with wireless driver that
> doesn't happen to call netif helpers (like netif_carrier_on()). In such
> cases kernel doesn't update "operstate" properly on its own and hostapd
> can be helpful there.
A kindly reminder about this small PATCH. Could someone review / accept
it, please?
> Before:
> $ grep . /sys/class/net/wlan*/operstate
> /sys/class/net/wlan0-1/operstate:unknown
> /sys/class/net/wlan0/operstate:up
> /sys/class/net/wlan1-1/operstate:unknown
> /sys/class/net/wlan1/operstate:up
>
> After:
> $ grep . /sys/class/net/wlan*/operstate
> /sys/class/net/wlan0-1/operstate:up
> /sys/class/net/wlan0/operstate:up
> /sys/class/net/wlan1-1/operstate:up
> /sys/class/net/wlan1/operstate:up
>
> Signed-off-by: Rafał Miłecki <rafal at milecki.pl>
> ---
> src/drivers/driver_nl80211.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/src/drivers/driver_nl80211.c b/src/drivers/driver_nl80211.c
> index 0cc5b4b0e..ebd93d856 100644
> --- a/src/drivers/driver_nl80211.c
> +++ b/src/drivers/driver_nl80211.c
> @@ -7808,7 +7808,7 @@ static int wpa_driver_nl80211_set_operstate(void *priv, int state)
> bss->ifname, drv->operstate, state,
> state ? "UP" : "DORMANT");
> drv->operstate = state;
> - return netlink_send_oper_ifla(drv->global->netlink, drv->ifindex, -1,
> + return netlink_send_oper_ifla(drv->global->netlink, bss->ifindex, -1,
> state ? IF_OPER_UP : IF_OPER_DORMANT);
> }
>
More information about the Hostap
mailing list