> > Thanks! At high level, we are fine with this approach. > :) > As discussed, > we need to have a mechanism to be able to set link specific > configurations such as link STA mac addr before assoc in STA mode. Right. > The proposal to have some sort of mapping between local and OTA link > will work. So in AP mode, it is OTA link_id but in STA mode, it is local > link_id which does not change the life time of the STA link > interface? Will that be still called link_id or something which means > pseudo link_id (something like link_idx?) to avoid confusions with > OTA link_id? I started calling it link_num later, but that might also be confusing and misinterpreted as num_links or so? ... > With a single netdev for MLD interface, we may need to add NL options > (in NL80211_CMD_SET_INTERFACE?) to set the link mac addr in both AP and > STA mode? Also, interface to report the mac addresses of all interfaces > to the user space in NL80211_CMD_NEW_INTERFACE event. Right, we need to report multi-link stuff in a lot of places, inside the LINKS attribute I guess. I thought setting the address would be good enough when we create a link, but maybe we need to be able to change it too, dunno. Not my highest priority :) > I assume link_id will be added in NL80211_CMD_FRAME command/event as > well for the application to identify the link on which the frame > is-received/to-be-transmitted? Good point, I guess we need that. > > /* currently used for IBSS and SME - might be rearranged later */ > > + // FIXME: move SSID to link? > > It seems all the links affiliated to an MLD should have the same SSID, > may be SSID is not link specific? Yeah you mentioned this to me elsewhere - you're right. I got confused about MBSSID APs. I also made it so for MLD the NL80211_ATTR_SSID attribute is now required in AP mode. > > @@ -4669,8 +4709,12 @@ static int nl80211_set_mac_acl(struct sk_buff > *skb, struct genl_info *info) > > dev->ieee80211_ptr->iftype != NL80211_IFTYPE_P2P_GO) > > return -EOPNOTSUPP; > > > > - if (!dev->ieee80211_ptr->beacon_interval) > > - return -EINVAL; > > +// FIXME: do we consider this to be on the MLD? I guess so? > > +// then what about legacy stations? or should we have > > +// ACL on each link? seems odd ... > > I think it makes sense to have this for MLD rather than individual link > interfaces, it is unlikely to have different policies for link and MLD > interfaces in terms of blocking/allowing a particular station mac. Agree. Also implementations are unlikely to want different tables for different links, unless they're different NICs like in some of your use cases, but copying the same table over to each is always possible. > > @@ -5785,12 +5837,18 @@ static int nl80211_start_ap(struct sk_buff > *skb, struct genl_info *info) > > else if (info->attrs[NL80211_ATTR_EXTERNAL_AUTH_SUPPORT]) > > params->flags |= NL80211_AP_SETTINGS_EXTERNAL_AUTH_SUPPORT; > > > > + /* FIXME: check that SSID(len) didn't change! > > + * or - ugh - can it? what about multi-BSSID > > + * where the transmitting BSSID/SSID might be > > + * different on different links? > > + */ > > May be this is not an issue? With mBSSID, start_ap will be called for > each BSS part of the mBSSID group. Configurations like SSID will be for > that particular BSS irrespective of whether that is transmitting or > non-transmitting BSS. Yep, I got confused, thanks. > > + if (internal_flags & NL80211_FLAG_MLO_VALID_LINK_ID) { > > + struct nlattr *link_id = info->attrs[NL80211_ATTR_MLO_LINK_ID]; [...] > > + /* non-MLO -> no link ID attribute accepted */ > > + if (!wdev->valid_links && link_id) { > > Isn't that we hit this condition when adding the very first link to the > MLD using NL80211_CMD_ADD_LINK? > Oh, I don't think CMD_ADD_LINK would set NL80211_FLAG_MLO_VALID_LINK_ID, that's just helper functionality for those commands that expect everything to already be set up. johannes