Convert mac80211 bw to ath11k bw before updating peer stats
bw counters, which fixes incorrect peer stats counters update.
Signed-off-by: Venkateswara Naralasetty <vnaralas@codeaurora.org>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
        tx_stats = arsta->tx_stats;
        gi = FIELD_GET(RATE_INFO_FLAGS_SHORT_GI, arsta->txrate.flags);
        mcs = txrate->mcs;
-       bw = txrate->bw;
+       bw = ath11k_mac_mac80211_bw_to_ath11k_bw(txrate->bw);
        nss = txrate->nss - 1;
 
 #define STATS_OP_FMT(name) tx_stats->stats[ATH11K_STATS_TYPE_##name]
 
        return ret;
 }
 
+enum ath11k_supported_bw ath11k_mac_mac80211_bw_to_ath11k_bw(enum rate_info_bw bw)
+{
+       switch (bw) {
+       case RATE_INFO_BW_20:
+               return ATH11K_BW_20;
+       case RATE_INFO_BW_40:
+               return ATH11K_BW_40;
+       case RATE_INFO_BW_80:
+               return ATH11K_BW_80;
+       case RATE_INFO_BW_160:
+               return ATH11K_BW_160;
+       default:
+               return ATH11K_BW_20;
+       }
+}
+
 int ath11k_mac_hw_ratecode_to_legacy_rate(u8 hw_rc, u8 preamble, u8 *rateidx,
                                          u16 *rate)
 {
 
 void ath11k_mac_peer_cleanup_all(struct ath11k *ar);
 int ath11k_mac_tx_mgmt_pending_free(int buf_id, void *skb, void *ctx);
 u8 ath11k_mac_bw_to_mac80211_bw(u8 bw);
+enum ath11k_supported_bw ath11k_mac_mac80211_bw_to_ath11k_bw(enum rate_info_bw bw);
 #endif