wifi: mac80211: take wiphy lock for MAC addr change
authorJohannes Berg <johannes.berg@intel.com>
Mon, 28 Aug 2023 12:00:00 +0000 (14:00 +0200)
committerJohannes Berg <johannes.berg@intel.com>
Mon, 11 Sep 2023 09:27:22 +0000 (11:27 +0200)
We want to ensure everything holds the wiphy lock,
so also extend that to the MAC change callback.

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

index a465a18..343343a 100644 (file)
@@ -251,9 +251,9 @@ unlock:
        return ret;
 }
 
-static int ieee80211_change_mac(struct net_device *dev, void *addr)
+static int _ieee80211_change_mac(struct ieee80211_sub_if_data *sdata,
+                                void *addr)
 {
-       struct ieee80211_sub_if_data *sdata = IEEE80211_DEV_TO_SUB_IF(dev);
        struct ieee80211_local *local = sdata->local;
        struct sockaddr *sa = addr;
        bool check_dup = true;
@@ -278,7 +278,7 @@ static int ieee80211_change_mac(struct net_device *dev, void *addr)
 
        if (live)
                drv_remove_interface(local, sdata);
-       ret = eth_mac_addr(dev, sa);
+       ret = eth_mac_addr(sdata->dev, sa);
 
        if (ret == 0) {
                memcpy(sdata->vif.addr, sa->sa_data, ETH_ALEN);
@@ -294,6 +294,19 @@ static int ieee80211_change_mac(struct net_device *dev, void *addr)
        return ret;
 }
 
+static int ieee80211_change_mac(struct net_device *dev, void *addr)
+{
+       struct ieee80211_sub_if_data *sdata = IEEE80211_DEV_TO_SUB_IF(dev);
+       struct ieee80211_local *local = sdata->local;
+       int ret;
+
+       wiphy_lock(local->hw.wiphy);
+       ret = _ieee80211_change_mac(sdata, addr);
+       wiphy_unlock(local->hw.wiphy);
+
+       return ret;
+}
+
 static inline int identical_mac_addr_allowed(int type1, int type2)
 {
        return type1 == NL80211_IFTYPE_MONITOR ||