<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">--- a/core.c
+++ b/core.c
@@ -718,7 +718,7 @@ static void mwl_chnl_switch_event(struct
 		vif = container_of((void *)mwl_vif, struct ieee80211_vif,
 				   drv_priv);
 
-		if (vif-&gt;csa_active)
+		if (vif-&gt;bss_conf.csa_active)
 			ieee80211_csa_finish(vif);
 	}
 	spin_unlock_bh(&amp;priv-&gt;vif_lock);
--- a/debugfs.c
+++ b/debugfs.c
@@ -498,9 +498,9 @@ static ssize_t mwl_debugfs_vif_read(stru
 		switch (vif-&gt;type) {
 		case NL80211_IFTYPE_AP:
 			len += scnprintf(p + len, size - len, "type: ap\n");
-			memcpy(ssid, vif-&gt;bss_conf.ssid,
-			       vif-&gt;bss_conf.ssid_len);
-			ssid[vif-&gt;bss_conf.ssid_len] = 0;
+			memcpy(ssid, vif-&gt;cfg.ssid,
+			       vif-&gt;cfg.ssid_len);
+			ssid[vif-&gt;cfg.ssid_len] = 0;
 			len += scnprintf(p + len, size - len,
 					 "ssid: %s\n", ssid);
 			len += scnprintf(p + len, size - len,
@@ -522,8 +522,8 @@ static ssize_t mwl_debugfs_vif_read(stru
 					 "type: unknown\n");
 			break;
 		}
-		if (vif-&gt;chanctx_conf) {
-			chan_def = &amp;vif-&gt;chanctx_conf-&gt;def;
+		if (vif-&gt;bss_conf.chanctx_conf) {
+			chan_def = &amp;vif-&gt;bss_conf.chanctx_conf-&gt;def;
 			len += scnprintf(p + len, size - len,
 					 "channel: %d: width: %d\n",
 					 chan_def-&gt;chan-&gt;hw_value,
@@ -596,18 +596,18 @@ static ssize_t mwl_debugfs_sta_read(stru
 			sta_info-&gt;wds ? "true" : "false",
 			sta_info-&gt;ba_hist.enable ? "enable" : "disable",
 			sta_info-&gt;is_amsdu_allowed ? sta_info-&gt;amsdu_ctrl.cap : 0 ,
-			sta-&gt;ht_cap.ht_supported ? sta-&gt;ht_cap.cap : 0,
-			sta-&gt;ht_cap.ht_supported ? sta-&gt;ht_cap.ampdu_factor : 0,
-			sta-&gt;ht_cap.ht_supported ? sta-&gt;ht_cap.ampdu_density : 0,
-			sta-&gt;ht_cap.ht_supported ? sta-&gt;ht_cap.mcs.rx_mask[0] : 0,
-			sta-&gt;ht_cap.ht_supported ? sta-&gt;ht_cap.mcs.rx_mask[1] : 0,
-			sta-&gt;ht_cap.ht_supported ? sta-&gt;ht_cap.mcs.rx_mask[2] : 0,
-			sta-&gt;ht_cap.ht_supported ? sta-&gt;ht_cap.mcs.rx_mask[3] : 0,
-			sta-&gt;vht_cap.vht_supported ? sta-&gt;vht_cap.cap : 0,
-			sta-&gt;vht_cap.vht_supported ? sta-&gt;vht_cap.vht_mcs.rx_mcs_map : 0,
-			sta-&gt;vht_cap.vht_supported ? sta-&gt;vht_cap.vht_mcs.tx_mcs_map : 0,
-			sta-&gt;bandwidth,
-			sta-&gt;rx_nss,
+			sta-&gt;deflink.ht_cap.ht_supported ? sta-&gt;deflink.ht_cap.cap : 0,
+			sta-&gt;deflink.ht_cap.ht_supported ? sta-&gt;deflink.ht_cap.ampdu_factor : 0,
+			sta-&gt;deflink.ht_cap.ht_supported ? sta-&gt;deflink.ht_cap.ampdu_density : 0,
+			sta-&gt;deflink.ht_cap.ht_supported ? sta-&gt;deflink.ht_cap.mcs.rx_mask[0] : 0,
+			sta-&gt;deflink.ht_cap.ht_supported ? sta-&gt;deflink.ht_cap.mcs.rx_mask[1] : 0,
+			sta-&gt;deflink.ht_cap.ht_supported ? sta-&gt;deflink.ht_cap.mcs.rx_mask[2] : 0,
+			sta-&gt;deflink.ht_cap.ht_supported ? sta-&gt;deflink.ht_cap.mcs.rx_mask[3] : 0,
+			sta-&gt;deflink.vht_cap.vht_supported ? sta-&gt;deflink.vht_cap.cap : 0,
+			sta-&gt;deflink.vht_cap.vht_supported ? sta-&gt;deflink.vht_cap.vht_mcs.rx_mcs_map : 0,
+			sta-&gt;deflink.vht_cap.vht_supported ? sta-&gt;deflink.vht_cap.vht_mcs.tx_mcs_map : 0,
+			sta-&gt;deflink.bandwidth,
+			sta-&gt;deflink.rx_nss,
 			sta-&gt;tdls,
 			sta-&gt;tdls_initiator,
 			sta-&gt;wme,
--- a/hif/fwcmd.c
+++ b/hif/fwcmd.c
@@ -633,11 +633,15 @@ einval:
 }
 
 static int mwl_fwcmd_set_ap_beacon(struct mwl_priv *priv,
-				   struct mwl_vif *mwl_vif,
-				   struct ieee80211_bss_conf *bss_conf)
+				   struct ieee80211_vif *vif)
 {
 	struct hostcmd_cmd_ap_beacon *pcmd;
 	struct ds_params *phy_ds_param_set;
+	struct mwl_vif *mwl_vif;
+	struct ieee80211_bss_conf *bss_conf;
+
+	mwl_vif = mwl_dev_get_vif(vif);
+	bss_conf = &amp;vif-&gt;bss_conf;
 
 	/* wmm structure of start command is defined less one byte,
 	 * due to following field country is not used, add byte one
@@ -664,7 +668,7 @@ static int mwl_fwcmd_set_ap_beacon(struc
 	pcmd-&gt;cmd_hdr.macid = mwl_vif-&gt;macid;
 
 	ether_addr_copy(pcmd-&gt;start_cmd.sta_mac_addr, mwl_vif-&gt;bssid);
-	memcpy(pcmd-&gt;start_cmd.ssid, bss_conf-&gt;ssid, bss_conf-&gt;ssid_len);
+	memcpy(pcmd-&gt;start_cmd.ssid, vif-&gt;cfg.ssid, vif-&gt;cfg.ssid_len);
 	if (priv-&gt;chip_type == MWL8997)
 		ether_addr_copy(pcmd-&gt;start_cmd.bssid, mwl_vif-&gt;bssid);
 	pcmd-&gt;start_cmd.bss_type = 1;
@@ -2090,7 +2094,7 @@ int mwl_fwcmd_set_beacon(struct ieee8021
 	if (mwl_fwcmd_set_wsc_ie(hw, b_inf-&gt;ie_wsc_len, b_inf-&gt;ie_wsc_ptr))
 		goto err;
 
-	if (mwl_fwcmd_set_ap_beacon(priv, mwl_vif, &amp;vif-&gt;bss_conf))
+	if (mwl_fwcmd_set_ap_beacon(priv, vif))
 		goto err;
 
 	if (b_inf-&gt;cap_info &amp; WLAN_CAPABILITY_SPECTRUM_MGMT)
@@ -2152,38 +2156,38 @@ int mwl_fwcmd_set_new_stn_add(struct iee
 	ether_addr_copy(pcmd-&gt;mac_addr, sta-&gt;addr);
 
 	if (hw-&gt;conf.chandef.chan-&gt;band == NL80211_BAND_2GHZ)
-		rates = sta-&gt;supp_rates[NL80211_BAND_2GHZ];
+		rates = sta-&gt;deflink.supp_rates[NL80211_BAND_2GHZ];
 	else
-		rates = sta-&gt;supp_rates[NL80211_BAND_5GHZ] &lt;&lt; 5;
+		rates = sta-&gt;deflink.supp_rates[NL80211_BAND_5GHZ] &lt;&lt; 5;
 	pcmd-&gt;peer_info.legacy_rate_bitmap = cpu_to_le32(rates);
 
-	if (sta-&gt;ht_cap.ht_supported) {
+	if (sta-&gt;deflink.ht_cap.ht_supported) {
 		int i;
 
 		for (i = 0; i &lt; 4; i++) {
-			if (i &lt; sta-&gt;rx_nss) {
+			if (i &lt; sta-&gt;deflink.rx_nss) {
 				pcmd-&gt;peer_info.ht_rates[i] =
-					sta-&gt;ht_cap.mcs.rx_mask[i];
+					sta-&gt;deflink.ht_cap.mcs.rx_mask[i];
 			} else {
 				pcmd-&gt;peer_info.ht_rates[i] = 0;
 			}
 		}
-		pcmd-&gt;peer_info.ht_cap_info = cpu_to_le16(sta-&gt;ht_cap.cap);
+		pcmd-&gt;peer_info.ht_cap_info = cpu_to_le16(sta-&gt;deflink.ht_cap.cap);
 		pcmd-&gt;peer_info.mac_ht_param_info =
-			(sta-&gt;ht_cap.ampdu_factor &amp; 3) |
-			((sta-&gt;ht_cap.ampdu_density &amp; 7) &lt;&lt; 2);
+			(sta-&gt;deflink.ht_cap.ampdu_factor &amp; 3) |
+			((sta-&gt;deflink.ht_cap.ampdu_density &amp; 7) &lt;&lt; 2);
 	}
 
-	if (sta-&gt;vht_cap.vht_supported) {
+	if (sta-&gt;deflink.vht_cap.vht_supported) {
 		u32 rx_mcs_map_mask = 0;
 
-		rx_mcs_map_mask = ((0x0000FFFF) &gt;&gt; (sta-&gt;rx_nss * 2))
-			&lt;&lt; (sta-&gt;rx_nss * 2);
+		rx_mcs_map_mask = ((0x0000FFFF) &gt;&gt; (sta-&gt;deflink.rx_nss * 2))
+			&lt;&lt; (sta-&gt;deflink.rx_nss * 2);
 		pcmd-&gt;peer_info.vht_max_rx_mcs =
 			cpu_to_le32((*((u32 *)
-			&amp;sta-&gt;vht_cap.vht_mcs.rx_mcs_map)) | rx_mcs_map_mask);
-		pcmd-&gt;peer_info.vht_cap = cpu_to_le32(sta-&gt;vht_cap.cap);
-		pcmd-&gt;peer_info.vht_rx_channel_width = sta-&gt;bandwidth;
+			&amp;sta-&gt;deflink.vht_cap.vht_mcs.rx_mcs_map)) | rx_mcs_map_mask);
+		pcmd-&gt;peer_info.vht_cap = cpu_to_le32(sta-&gt;deflink.vht_cap.cap);
+		pcmd-&gt;peer_info.vht_rx_channel_width = sta-&gt;deflink.bandwidth;
 	}
 
 	pcmd-&gt;is_qos_sta = sta-&gt;wme;
@@ -2239,38 +2243,38 @@ int mwl_fwcmd_set_new_stn_add_sc4(struct
 	ether_addr_copy(pcmd-&gt;mac_addr, sta-&gt;addr);
 
 	if (hw-&gt;conf.chandef.chan-&gt;band == NL80211_BAND_2GHZ)
-		rates = sta-&gt;supp_rates[NL80211_BAND_2GHZ];
+		rates = sta-&gt;deflink.supp_rates[NL80211_BAND_2GHZ];
 	else
-		rates = sta-&gt;supp_rates[NL80211_BAND_5GHZ] &lt;&lt; 5;
+		rates = sta-&gt;deflink.supp_rates[NL80211_BAND_5GHZ] &lt;&lt; 5;
 	pcmd-&gt;peer_info.legacy_rate_bitmap = cpu_to_le32(rates);
 
-	if (sta-&gt;ht_cap.ht_supported) {
+	if (sta-&gt;deflink.ht_cap.ht_supported) {
 		int i;
 
 		for (i = 0; i &lt; 4; i++) {
-			if (i &lt; sta-&gt;rx_nss) {
+			if (i &lt; sta-&gt;deflink.rx_nss) {
 				pcmd-&gt;peer_info.ht_rates[i] =
-					sta-&gt;ht_cap.mcs.rx_mask[i];
+					sta-&gt;deflink.ht_cap.mcs.rx_mask[i];
 			} else {
 				pcmd-&gt;peer_info.ht_rates[i] = 0;
 			}
 		}
-		pcmd-&gt;peer_info.ht_cap_info = cpu_to_le16(sta-&gt;ht_cap.cap);
+		pcmd-&gt;peer_info.ht_cap_info = cpu_to_le16(sta-&gt;deflink.ht_cap.cap);
 		pcmd-&gt;peer_info.mac_ht_param_info =
-			(sta-&gt;ht_cap.ampdu_factor &amp; 3) |
-			((sta-&gt;ht_cap.ampdu_density &amp; 7) &lt;&lt; 2);
+			(sta-&gt;deflink.ht_cap.ampdu_factor &amp; 3) |
+			((sta-&gt;deflink.ht_cap.ampdu_density &amp; 7) &lt;&lt; 2);
 	}
 
-	if (sta-&gt;vht_cap.vht_supported) {
+	if (sta-&gt;deflink.vht_cap.vht_supported) {
 		u32 rx_mcs_map_mask = 0;
 
-		rx_mcs_map_mask = ((0x0000FFFF) &gt;&gt; (sta-&gt;rx_nss * 2))
-			&lt;&lt; (sta-&gt;rx_nss * 2);
+		rx_mcs_map_mask = ((0x0000FFFF) &gt;&gt; (sta-&gt;deflink.rx_nss * 2))
+			&lt;&lt; (sta-&gt;deflink.rx_nss * 2);
 		pcmd-&gt;peer_info.vht_max_rx_mcs =
 			cpu_to_le32((*((u32 *)
-			&amp;sta-&gt;vht_cap.vht_mcs.rx_mcs_map)) | rx_mcs_map_mask);
-		pcmd-&gt;peer_info.vht_cap = cpu_to_le32(sta-&gt;vht_cap.cap);
-		pcmd-&gt;peer_info.vht_rx_channel_width = sta-&gt;bandwidth;
+			&amp;sta-&gt;deflink.vht_cap.vht_mcs.rx_mcs_map)) | rx_mcs_map_mask);
+		pcmd-&gt;peer_info.vht_cap = cpu_to_le32(sta-&gt;deflink.vht_cap.cap);
+		pcmd-&gt;peer_info.vht_rx_channel_width = sta-&gt;deflink.bandwidth;
 	}
 
 	pcmd-&gt;is_qos_sta = sta-&gt;wme;
@@ -2787,9 +2791,9 @@ int mwl_fwcmd_create_ba(struct ieee80211
 	pcmd-&gt;ba_info.create_params.flags = cpu_to_le32(ba_flags);
 	pcmd-&gt;ba_info.create_params.queue_id = stream-&gt;idx;
 	pcmd-&gt;ba_info.create_params.param_info =
-		(stream-&gt;sta-&gt;ht_cap.ampdu_factor &amp;
+		(stream-&gt;sta-&gt;deflink.ht_cap.ampdu_factor &amp;
 		 IEEE80211_HT_AMPDU_PARM_FACTOR) |
-		((stream-&gt;sta-&gt;ht_cap.ampdu_density &lt;&lt; 2) &amp;
+		((stream-&gt;sta-&gt;deflink.ht_cap.ampdu_density &lt;&lt; 2) &amp;
 		 IEEE80211_HT_AMPDU_PARM_DENSITY);
 	if (direction == BA_FLAG_DIRECTION_UP) {
 		pcmd-&gt;ba_info.create_params.reset_seq_no = 0;
@@ -2799,9 +2803,9 @@ int mwl_fwcmd_create_ba(struct ieee80211
 		pcmd-&gt;ba_info.create_params.current_seq = cpu_to_le16(0);
 	}
 	if (priv-&gt;chip_type == MWL8964 &amp;&amp;
-	    stream-&gt;sta-&gt;vht_cap.vht_supported) {
+	    stream-&gt;sta-&gt;deflink.vht_cap.vht_supported) {
 		pcmd-&gt;ba_info.create_params.vht_rx_factor =
-			cpu_to_le32((stream-&gt;sta-&gt;vht_cap.cap  &amp;
+			cpu_to_le32((stream-&gt;sta-&gt;deflink.vht_cap.cap  &amp;
 			IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_MASK) &gt;&gt;
 			IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_SHIFT);
 	}
--- a/hif/pcie/8864/tx.c
+++ b/hif/pcie/8864/tx.c
@@ -743,7 +743,7 @@ void pcie_8864_tx_xmit(struct ieee80211_
 	index = SYSADPT_TX_WMM_QUEUES - index - 1;
 	txpriority = index;
 
-	if (sta &amp;&amp; sta-&gt;ht_cap.ht_supported &amp;&amp;
+	if (sta &amp;&amp; sta-&gt;deflink.ht_cap.ht_supported &amp;&amp;
 	  !(xmitcontrol &amp; EAGLE_TXD_XMITCTRL_USE_MC_RATE) &amp;&amp;
 	    ieee80211_is_data_qos(wh-&gt;frame_control)) {
 		tid = qos &amp; 0xf;
--- a/hif/pcie/8964/tx_ndp.c
+++ b/hif/pcie/8964/tx_ndp.c
@@ -607,7 +607,7 @@ void pcie_tx_xmit_ndp(struct ieee80211_h
 		pcie_tx_encapsulate_frame(priv, skb, k_conf);
 	} else {
 		tid = qos &amp; 0x7;
-		if (sta &amp;&amp; sta-&gt;ht_cap.ht_supported &amp;&amp; !eapol_frame &amp;&amp;
+		if (sta &amp;&amp; sta-&gt;deflink.ht_cap.ht_supported &amp;&amp; !eapol_frame &amp;&amp;
 		    qos != 0xFFFF) {
 			pcie_tx_count_packet(sta, tid);
 			spin_lock_bh(&amp;priv-&gt;stream_lock);
--- a/hif/pcie/8997/tx.c
+++ b/hif/pcie/8997/tx.c
@@ -81,7 +81,7 @@ static int pcie_txbd_ring_create(struct
 	wiphy_info(priv-&gt;hw-&gt;wiphy,
 		   "TX ring: - base: %p, pbase: 0x%x, len: %d\n",
 		   pcie_priv-&gt;txbd_ring_vbase,
-		   pcie_priv-&gt;txbd_ring_pbase,
+		   (u32)pcie_priv-&gt;txbd_ring_pbase,
 		   pcie_priv-&gt;txbd_ring_size);
 
 	for (num = 0; num &lt; PCIE_MAX_TXRX_BD; num++) {
@@ -694,7 +694,7 @@ void pcie_8997_tx_xmit(struct ieee80211_
 	index = SYSADPT_TX_WMM_QUEUES - index - 1;
 	txpriority = index;
 
-	if (sta &amp;&amp; sta-&gt;ht_cap.ht_supported &amp;&amp;
+	if (sta &amp;&amp; sta-&gt;deflink.ht_cap.ht_supported &amp;&amp;
 	  !(xmitcontrol &amp; EAGLE_TXD_XMITCTRL_USE_MC_RATE) &amp;&amp;
 	    ieee80211_is_data_qos(wh-&gt;frame_control)) {
 		tid = qos &amp; 0xf;
--- a/mac80211.c
+++ b/mac80211.c
@@ -368,15 +368,15 @@ static void mwl_mac80211_bss_info_change
 		}
 	}
 
-	if ((changed &amp; BSS_CHANGED_ASSOC) &amp;&amp; vif-&gt;bss_conf.assoc)
+	if ((changed &amp; BSS_CHANGED_ASSOC) &amp;&amp; vif-&gt;cfg.assoc)
 		mwl_fwcmd_set_aid(hw, vif, (u8 *)vif-&gt;bss_conf.bssid,
-				  vif-&gt;bss_conf.aid);
+				  vif-&gt;cfg.aid);
 }
 
 static void mwl_mac80211_bss_info_changed_ap(struct ieee80211_hw *hw,
 					     struct ieee80211_vif *vif,
 					     struct ieee80211_bss_conf *info,
-					     u32 changed)
+					     u64 changed)
 {
 	struct mwl_priv *priv = hw-&gt;priv;
 	struct mwl_vif *mwl_vif;
@@ -426,8 +426,8 @@ static void mwl_mac80211_bss_info_change
 	if (changed &amp; (BSS_CHANGED_BEACON_INT | BSS_CHANGED_BEACON)) {
 		struct sk_buff *skb;
 
-		if ((info-&gt;ssid[0] != '\0') &amp;&amp;
-		    (info-&gt;ssid_len != 0) &amp;&amp;
+		if ((vif-&gt;cfg.ssid[0] != '\0') &amp;&amp;
+		    (vif-&gt;cfg.ssid_len != 0) &amp;&amp;
 		    (!info-&gt;hidden_ssid)) {
 			if (mwl_vif-&gt;broadcast_ssid != true) {
 				mwl_fwcmd_broadcast_ssid_enable(hw, vif, true);
@@ -441,7 +441,7 @@ static void mwl_mac80211_bss_info_change
 		}
 
 		if (!mwl_vif-&gt;set_beacon) {
-			skb = ieee80211_beacon_get(hw, vif);
+			skb = ieee80211_beacon_get(hw, vif, 0);
 
 			if (skb) {
 				mwl_fwcmd_set_beacon(hw, vif, skb-&gt;data, skb-&gt;len);
@@ -458,7 +458,7 @@ static void mwl_mac80211_bss_info_change
 static void mwl_mac80211_bss_info_changed(struct ieee80211_hw *hw,
 					  struct ieee80211_vif *vif,
 					  struct ieee80211_bss_conf *info,
-					  u32 changed)
+					  u64 changed)
 {
 	switch (vif-&gt;type) {
 	case NL80211_IFTYPE_AP:
@@ -583,10 +583,10 @@ static int mwl_mac80211_sta_add(struct i
 	if (vif-&gt;type == NL80211_IFTYPE_MESH_POINT)
 		sta_info-&gt;is_mesh_node = true;
 
-	if (sta-&gt;ht_cap.ht_supported) {
+	if (sta-&gt;deflink.ht_cap.ht_supported) {
 		sta_info-&gt;is_ampdu_allowed = true;
 		sta_info-&gt;is_amsdu_allowed = false;
-		if (sta-&gt;ht_cap.cap &amp; IEEE80211_HT_CAP_MAX_AMSDU) {
+		if (sta-&gt;deflink.ht_cap.cap &amp; IEEE80211_HT_CAP_MAX_AMSDU) {
 			sta_info-&gt;amsdu_ctrl.cap = MWL_AMSDU_SIZE_8K;
 			sta_info-&gt;amsdu_ctrl.amsdu_allow_size = SYSADPT_AMSDU_8K_MAX_SIZE;
 		}
@@ -670,7 +670,7 @@ static int mwl_mac80211_sta_remove(struc
 
 static int mwl_mac80211_conf_tx(struct ieee80211_hw *hw,
 				struct ieee80211_vif *vif,
-				u16 queue,
+				unsigned int link_id, u16 queue,
 				const struct ieee80211_tx_queue_params *params)
 {
 	struct mwl_priv *priv = hw-&gt;priv;
@@ -934,4 +934,5 @@ const struct ieee80211_ops mwl_mac80211_
 	.pre_channel_switch = mwl_mac80211_chnl_switch,
 	.sw_scan_start      = mwl_mac80211_sw_scan_start,
 	.sw_scan_complete   = mwl_mac80211_sw_scan_complete,
+	.wake_tx_queue	    = ieee80211_handle_wake_tx_queue,
 };
--- a/utils.c
+++ b/utils.c
@@ -173,9 +173,9 @@ u32 utils_get_init_tx_rate(struct mwl_pr
 	u32 tx_rate;
 	u16 format, nss, bw, rate_mcs;
 
-	if (sta-&gt;vht_cap.vht_supported)
+	if (sta-&gt;deflink.vht_cap.vht_supported)
 		format = TX_RATE_FORMAT_11AC;
-	else if (sta-&gt;ht_cap.ht_supported)
+	else if (sta-&gt;deflink.ht_cap.ht_supported)
 		format = TX_RATE_FORMAT_11N;
 	else
 		format = TX_RATE_FORMAT_LEGACY;
@@ -192,11 +192,11 @@ u32 utils_get_init_tx_rate(struct mwl_pr
 		nss = 3;
 		break;
 	default:
-		nss = sta-&gt;rx_nss;
+		nss = sta-&gt;deflink.rx_nss;
 		break;
 	}
-	if (nss &gt; sta-&gt;rx_nss)
-		nss = sta-&gt;rx_nss;
+	if (nss &gt; sta-&gt;deflink.rx_nss)
+		nss = sta-&gt;deflink.rx_nss;
 
 	switch (conf-&gt;chandef.width) {
 	case NL80211_CHAN_WIDTH_20_NOHT:
@@ -213,11 +213,11 @@ u32 utils_get_init_tx_rate(struct mwl_pr
 		bw = TX_RATE_BANDWIDTH_160;
 		break;
 	default:
-		bw = sta-&gt;bandwidth;
+		bw = sta-&gt;deflink.bandwidth;
 		break;
 	}
-	if (bw &gt; sta-&gt;bandwidth)
-		bw = sta-&gt;bandwidth;
+	if (bw &gt; sta-&gt;deflink.bandwidth)
+		bw = sta-&gt;deflink.bandwidth;
 
 	switch (format) {
 	case TX_RATE_FORMAT_LEGACY:
</pre></body></html>