wifi: mwifiex: duplicate static structs used in driver instances
authorSascha Hauer <s.hauer@pengutronix.de>
Fri, 9 Aug 2024 08:11:33 +0000 (10:11 +0200)
committerKalle Valo <kvalo@kernel.org>
Fri, 16 Aug 2024 09:47:39 +0000 (12:47 +0300)
mwifiex_band_2ghz and mwifiex_band_5ghz are statically allocated, but
used and modified in driver instances. Duplicate them before using
them in driver instances so that different driver instances do not
influence each other.

This was observed on a board which has one PCIe and one SDIO mwifiex
adapter. It blew up in mwifiex_setup_ht_caps(). This was called with
the statically allocated struct which is modified in this function.

Cc: stable@vger.kernel.org
Fixes: d6bffe8bb520 ("mwifiex: support for creation of AP interface")
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Reviewed-by: Francesco Dolcini <francesco.dolcini@toradex.com>
Acked-by: Brian Norris <briannorris@chromium.org>
Signed-off-by: Kalle Valo <kvalo@kernel.org>
Link: https://patch.msgid.link/20240809-mwifiex-duplicate-static-structs-v1-1-6837b903b1a4@pengutronix.de
drivers/net/wireless/marvell/mwifiex/cfg80211.c

index 155eb0fab12a48b568ab189c45819d8df7bd3045..bf35c92f91d7e949bdd772a31bcb94e6d7cdb3e4 100644 (file)
@@ -4363,11 +4363,27 @@ int mwifiex_register_cfg80211(struct mwifiex_adapter *adapter)
        if (ISSUPP_ADHOC_ENABLED(adapter->fw_cap_info))
                wiphy->interface_modes |= BIT(NL80211_IFTYPE_ADHOC);
 
-       wiphy->bands[NL80211_BAND_2GHZ] = &mwifiex_band_2ghz;
-       if (adapter->config_bands & BAND_A)
-               wiphy->bands[NL80211_BAND_5GHZ] = &mwifiex_band_5ghz;
-       else
+       wiphy->bands[NL80211_BAND_2GHZ] = devm_kmemdup(adapter->dev,
+                                                      &mwifiex_band_2ghz,
+                                                      sizeof(mwifiex_band_2ghz),
+                                                      GFP_KERNEL);
+       if (!wiphy->bands[NL80211_BAND_2GHZ]) {
+               ret = -ENOMEM;
+               goto err;
+       }
+
+       if (adapter->config_bands & BAND_A) {
+               wiphy->bands[NL80211_BAND_5GHZ] = devm_kmemdup(adapter->dev,
+                                                              &mwifiex_band_5ghz,
+                                                              sizeof(mwifiex_band_5ghz),
+                                                              GFP_KERNEL);
+               if (!wiphy->bands[NL80211_BAND_5GHZ]) {
+                       ret = -ENOMEM;
+                       goto err;
+               }
+       } else {
                wiphy->bands[NL80211_BAND_5GHZ] = NULL;
+       }
 
        if (adapter->drcs_enabled && ISSUPP_DRCS_ENABLED(adapter->fw_cap_info))
                wiphy->iface_combinations = &mwifiex_iface_comb_ap_sta_drcs;
@@ -4461,8 +4477,7 @@ int mwifiex_register_cfg80211(struct mwifiex_adapter *adapter)
        if (ret < 0) {
                mwifiex_dbg(adapter, ERROR,
                            "%s: wiphy_register failed: %d\n", __func__, ret);
-               wiphy_free(wiphy);
-               return ret;
+               goto err;
        }
 
        if (!adapter->regd) {
@@ -4504,4 +4519,9 @@ int mwifiex_register_cfg80211(struct mwifiex_adapter *adapter)
 
        adapter->wiphy = wiphy;
        return ret;
+
+err:
+       wiphy_free(wiphy);
+
+       return ret;
 }