wifi: rtw89: mac: add registers of MU-EDCA parameters for WiFi 7 chips
authorPing-Ke Shih <pkshih@realtek.com>
Thu, 12 Oct 2023 02:14:52 +0000 (10:14 +0800)
committerKalle Valo <kvalo@kernel.org>
Sat, 14 Oct 2023 06:43:31 +0000 (09:43 +0300)
According to chip generation, set MU-EDCA parameters from mac80211 when
connected.

Signed-off-by: Ping-Ke Shih <pkshih@realtek.com>
Signed-off-by: Kalle Valo <kvalo@kernel.org>
Link: https://lore.kernel.org/r/20231012021455.19816-4-pkshih@realtek.com
drivers/net/wireless/realtek/rtw89/mac80211.c
drivers/net/wireless/realtek/rtw89/reg.h

index 16bbb775119795b15e25ac79000de9f66f1b9a69..31d1f78916751ed9f0d08b782c37e5386b5c5c09 100644 (file)
@@ -328,11 +328,14 @@ static void ____rtw89_conf_tx_edca(struct rtw89_dev *rtwdev,
        rtw89_fw_h2c_set_edca(rtwdev, rtwvif, ac_to_fw_idx[ac], val);
 }
 
-static const u32 ac_to_mu_edca_param[IEEE80211_NUM_ACS] = {
-       [IEEE80211_AC_VO] = R_AX_MUEDCA_VO_PARAM_0,
-       [IEEE80211_AC_VI] = R_AX_MUEDCA_VI_PARAM_0,
-       [IEEE80211_AC_BE] = R_AX_MUEDCA_BE_PARAM_0,
-       [IEEE80211_AC_BK] = R_AX_MUEDCA_BK_PARAM_0,
+#define R_MUEDCA_ACS_PARAM(acs) {R_AX_MUEDCA_ ## acs ## _PARAM_0, \
+                                R_BE_MUEDCA_ ## acs ## _PARAM_0}
+
+static const u32 ac_to_mu_edca_param[IEEE80211_NUM_ACS][RTW89_CHIP_GEN_NUM] = {
+       [IEEE80211_AC_VO] = R_MUEDCA_ACS_PARAM(VO),
+       [IEEE80211_AC_VI] = R_MUEDCA_ACS_PARAM(VI),
+       [IEEE80211_AC_BE] = R_MUEDCA_ACS_PARAM(BE),
+       [IEEE80211_AC_BK] = R_MUEDCA_ACS_PARAM(BK),
 };
 
 static void ____rtw89_conf_tx_mu_edca(struct rtw89_dev *rtwdev,
@@ -340,6 +343,7 @@ static void ____rtw89_conf_tx_mu_edca(struct rtw89_dev *rtwdev,
 {
        struct ieee80211_tx_queue_params *params = &rtwvif->tx_params[ac];
        struct ieee80211_he_mu_edca_param_ac_rec *mu_edca;
+       int gen = rtwdev->chip->chip_gen;
        u8 aifs, aifsn;
        u16 timer_32us;
        u32 reg;
@@ -356,7 +360,7 @@ static void ____rtw89_conf_tx_mu_edca(struct rtw89_dev *rtwdev,
        val = FIELD_PREP(B_AX_MUEDCA_BE_PARAM_0_TIMER_MASK, timer_32us) |
              FIELD_PREP(B_AX_MUEDCA_BE_PARAM_0_CW_MASK, mu_edca->ecw_min_max) |
              FIELD_PREP(B_AX_MUEDCA_BE_PARAM_0_AIFS_MASK, aifs);
-       reg = rtw89_mac_reg_by_idx(rtwdev, ac_to_mu_edca_param[ac], rtwvif->mac_idx);
+       reg = rtw89_mac_reg_by_idx(rtwdev, ac_to_mu_edca_param[ac][gen], rtwvif->mac_idx);
        rtw89_write32(rtwdev, reg, val);
 
        rtw89_mac_set_hw_muedca_ctrl(rtwdev, rtwvif, true);
index 96d5959c299e5e3aac0d5d8e512b6ac0d0b0ec18..d62b3f93b14ecaaa7b998b1394b637447ceafdbd 100644 (file)
 #define B_BE_P0_SYNC_PORT_SRC_SEL_MASK GENMASK(26, 24)
 #define B_BE_P0_TSFTR_SYNC_OFFSET_MASK GENMASK(18, 0)
 
+#define R_BE_MUEDCA_BE_PARAM_0 0x10350
+#define R_BE_MUEDCA_BK_PARAM_0 0x10354
+#define R_BE_MUEDCA_VI_PARAM_0 0x10358
+#define R_BE_MUEDCA_VO_PARAM_0 0x1035C
+
 #define R_BE_MUEDCA_EN 0x10370
 #define R_BE_MUEDCA_EN_C1 0x14370
 #define B_BE_MUEDCA_WMM_SEL BIT(8)