wifi: mac80211: accept STA changes without link changes
authorJohannes Berg <johannes.berg@intel.com>
Sat, 23 Jul 2022 20:08:49 +0000 (22:08 +0200)
committerJohannes Berg <johannes.berg@intel.com>
Thu, 25 Aug 2022 08:40:46 +0000 (10:40 +0200)
If there's no link ID, then check that there are no changes to
the link, and if so accept them, unless a new link is created.
While at it, reject creating a new link without an address.

This fixes authorizing an MLD (peer) that has no link 0.

Signed-off-by: Johannes Berg <johannes.berg@intel.com>
net/mac80211/cfg.c

index a4f6971b7a190a9c1469994626c7048a43523505..167acf843d7587b711eee8c447435b95ae0fb723 100644 (file)
@@ -1610,6 +1610,18 @@ static int sta_link_apply_parameters(struct ieee80211_local *local,
                rcu_dereference_protected(sta->link[link_id],
                                          lockdep_is_held(&local->sta_mtx));
 
+       /*
+        * If there are no changes, then accept a link that doesn't exist,
+        * unless it's a new link.
+        */
+       if (params->link_id < 0 && !new_link &&
+           !params->link_mac && !params->txpwr_set &&
+           !params->supported_rates_len &&
+           !params->ht_capa && !params->vht_capa &&
+           !params->he_capa && !params->eht_capa &&
+           !params->opmode_notif_used)
+               return 0;
+
        if (!link || !link_sta)
                return -EINVAL;
 
@@ -1625,6 +1637,8 @@ static int sta_link_apply_parameters(struct ieee80211_local *local,
                                             params->link_mac)) {
                        return -EINVAL;
                }
+       } else if (new_link) {
+               return -EINVAL;
        }
 
        if (params->txpwr_set) {