When a channel context is added, it is still not assigned to the link
and the link is not yet active. As a result, the channel context
min_def is used when the AP is started, even when the full bandwidth
should be used.
Fix it by updating the PHY channel context when the link is already
active so the full bandwidth is used when needed.
Signed-off-by: Avraham Stern <avraham.stern@intel.com>
Signed-off-by: Miri Korenblit <miriam.rachel.korenblit@intel.com>
Link: https://patch.msgid.link/20250430155443.30b043b10fb1.I62c2aa58687e4796b759fa68132122119a337b49@changeid
 #include "tx.h"
 #include "power.h"
 #include "key.h"
+#include "phy.h"
 #include "iwl-utils.h"
 
 #include "fw/api/sta.h"
 {
        struct iwl_mld *mld = IWL_MAC80211_GET_MLD(hw);
        struct iwl_mld_vif *mld_vif = iwl_mld_vif_from_mac80211(vif);
+       struct ieee80211_chanctx_conf *ctx;
        int ret;
 
        if (vif->type == NL80211_IFTYPE_AP)
                return iwl_mld_mac_fw_action(mld, mld->p2p_device_vif,
                                             FW_CTXT_ACTION_MODIFY);
 
+       /* When the channel context was added, the link is not yet active, so
+        * min_def is always used. Update the PHY again here in case def should
+        * actually be used.
+        */
+       ctx = wiphy_dereference(mld->wiphy, link->chanctx_conf);
+       iwl_mld_update_phy_chandef(mld, ctx);
+
        return 0;
 rm_bcast:
        iwl_mld_remove_bcast_sta(mld, vif, link);
 
                        return;
        }
 update:
-       phy->chandef = *chandef;
 
-       iwl_mld_phy_fw_action(mld, ctx, FW_CTXT_ACTION_MODIFY);
+       iwl_mld_update_phy_chandef(mld, ctx);
 }
 
 static u8
 
 
        return iwl_mld_send_cmd_pdu(mld, PHY_CONFIGURATION_CMD, &cmd);
 }
+
+void iwl_mld_update_phy_chandef(struct iwl_mld *mld,
+                               struct ieee80211_chanctx_conf *ctx)
+{
+       struct iwl_mld_phy *phy = iwl_mld_phy_from_mac80211(ctx);
+       struct cfg80211_chan_def *chandef =
+               iwl_mld_get_chandef_from_chanctx(mld, ctx);
+
+       phy->chandef = *chandef;
+       iwl_mld_phy_fw_action(mld, ctx, FW_CTXT_ACTION_MODIFY);
+}
 
 
 int iwl_mld_send_phy_cfg_cmd(struct iwl_mld *mld);
 
+void iwl_mld_update_phy_chandef(struct iwl_mld *mld,
+                               struct ieee80211_chanctx_conf *ctx);
+
 #endif /* __iwl_mld_phy_h__ */