On Wed, 2023-09-06 at 06:34 -0400, Wen Gong wrote: > There are 2 fields valid_links and active_links in struct ieee80211_vif > of mac80211. For station mode, valid_links is always include the bitmap > of active_links. valid_links stores the bitmap of links which is created > in mac80211, and mac80211 only indicate the info of links which is existed > in active_links to driver. Finally, the active_links is the bitmap of > links which station can interactive with MLO AP it is connected to. > > Currently the active links is always only contain the primary link, > primary link means the link used by the latest exchange of successful > (Re)Association Request/Response frames. Then it will always have only > one link in driver after connected. > > Hence add this ops in struct ieee80211_ops to allow driver to determine > the active links bit map dynamically while connecting to MLO AP. This commit log does nothing to address the question "why do we need this", particularly since we already have ieee80211_set_active_links(/_async), so the driver can pretty much immediately enable all the links it wants. I see no value in this patch whatsoever. > @@ -166,6 +167,13 @@ static void ieee80211_set_vif_links_bitmaps(struct ieee80211_sub_if_data *sdata, > WARN_ON(dormant_links); > break; > case NL80211_IFTYPE_STATION: > + active_links = drv_calculate_active_links(sdata->local, sdata, > + valid_links & ~dormant_links); > + if (active_links) { > + sdata->vif.active_links = active_links; > + break; > + } > I also _really_ don't think this should operate at this low-level infrastructure. johannes