On 9/9/2022 3:28 PM, Johannes Berg wrote:
Hi,
No, they aren't, and shouldn't be.
IEEE P802.11be™/D2.0
35.3.3 Multi-link device addressing
An MLD has an MLD MAC address that singly identifies the MLD.
Each STA affiliated with an MLD shall have a different MAC address.
NOTE 1—The MLD MAC address of an MLD might be the same as the MAC
address of one affiliated STA or different
from the MAC address of any affiliated STA.
Right. I was over-simplifying, that was basically the "tl;dr" version of
my statement, without the longer one ;-)
This means the MLD address can be same with one link.
True.
I suggest to set primary link local addr same with MLD address for station.
I wouldn't suggest that, but YMMV.
reason is:
When station up, one link interface of driver will be created with the
addr of struct ieee80211_vif,
it is used for scan and non-MLO connection.
If station start to do MLO connection now, then random local link addr
will be generated by below call stack.
for the 1st link. This lead driver must change the link interface local
address to this random addr.
Well, that depends how you treat "address of an interface", no? I don't
think there's really any need to "install" a MAC address to the NIC
until you even start any kind of operation.
True, if you cannot scan using the MLD address while you also have a
different link address, you might be in trouble - but I find this
unrealistic because you would want to be able to scan on any part of the
hardware that is doing any of the links?
Scan probe request needs the local address, so we must fill one address
to it.
And we use the same local address to scan for 2.4 GHz/5 GHz/6 GHz band.
In any case, changing this makes the receive logic a bit different. You
would have to ensure that your driver does indeed indicate the link a
frame was received on, I think? Also, ieee80211_rx_for_interface() might
have to change, something like the below maybe?
I looked the ieee80211_rx_for_interface(), it is to find struct
link_sta_info with the source
address of an rx frame. For station, the hdr->addr2 means the address of
the AP, so
the the change of mac80211/wireless will not effect the
ieee80211_rx_for_interface().
Because it is the MLD/link address of the AP(maybe it is same addr for
MLD/one link) when we as station.
If we just change the first link's address to the same as the MLD
address without any changes then the code without the changes below
would overwrite the link ID because it can find the link STA address,
even if the device already did address translation. Of course this is
only relevant if it does address translation w/o indicating the link,
which it shouldn't ... hence the patch.
In any case, I expect this will end up being some kind of driver policy,
so I can imagine that we could make a relatively simple patch with a new
method to let drivers set the link address that gets used. It cannot be
changing the link address when it's added to the driver since this patch
that this thread is based on means the driver doesn't get to know about
the links until it's far too late (and even before this patch, the links
were only created after assoc, when the link addresses were already sent
to the AP)
Thanks for the incoming new method to let drivers set the link address.
It is better to let driver to fill all the links' address in load phase.
And then it never change again. And one of the address array is always
used for primary link.
johannes
diff --git a/include/net/mac80211.h b/include/net/mac80211.h
index ac2bad57933f..648b2de8dd3e 100644
--- a/include/net/mac80211.h
+++ b/include/net/mac80211.h
@@ -1482,7 +1482,8 @@ enum mac80211_rx_encoding {
* @ampdu_delimiter_crc: A-MPDU delimiter CRC
* @zero_length_psdu_type: radiotap type of the 0-length PSDU
* @link_valid: if the link which is identified by @link_id is valid. This flag
- * is set only when connection is MLO.
+ * is set only when connection is MLO. Note that setting this also implies
+ * address translation was done.
* @link_id: id of the link used to receive the packet. This is used along with
* @link_valid.
*/
diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c
index a57811372027..963de5d880d7 100644
--- a/net/mac80211/rx.c
+++ b/net/mac80211/rx.c
@@ -4946,22 +4946,24 @@ static void __ieee80211_rx_handle_8023(struct ieee80211_hw *hw,
static bool ieee80211_rx_for_interface(struct ieee80211_rx_data *rx,
struct sk_buff *skb, bool consume)
{
- struct link_sta_info *link_sta;
+ struct ieee80211_rx_status *status = IEEE80211_SKB_RXCB(skb);
struct ieee80211_hdr *hdr = (void *)skb->data;
+ struct link_sta_info *link_sta = NULL;
/*
- * Look up link station first, in case there's a
- * chance that they might have a link address that
- * is identical to the MLD address, that way we'll
- * have the link information if needed.
+ * Unless the driver did addr translation and provided the link
+ * ID, look up link station first. Note that if we get a frame
+ * without link ID in the status and the device happens to use
+ * identical addresses for one of the links and the MLD, then
+ * we cannot identify whether it was translated already or not.
*/
- link_sta = link_sta_info_get_bss(rx->sdata, hdr->addr2);
+ if (!status->link_valid)
+ link_sta = link_sta_info_get_bss(rx->sdata, hdr->addr2);
+
if (link_sta) {
rx->sta = link_sta->sta;
rx->link_id = link_sta->link_id;
} else {
- struct ieee80211_rx_status *status = IEEE80211_SKB_RXCB(skb);
-
rx->sta = sta_info_get_bss(rx->sdata, hdr->addr2);
if (rx->sta) {
if (status->link_valid &&
Thanks.
Below patch has said driver should report link id if addr translated.
https://git.kernel.org/pub/scm/linux/kernel/git/wireless/wireless-next.git/commit/?h=mld&id=ea9d807b56428d65cf43030cbd7ae5a580077147
wifi: mac80211: add link information in ieee80211_rx_status
In MLO, when the address translation from link to MLD is done
in fw/hw, it is necessary to be able to have some information
on the link on which the frame has been received. Extend the
rx API to include link_id and a valid flag in ieee80211_rx_status.
Also make chanes to mac80211 rx APIs to make use of the reported
link_id after sanity checks.