]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
wifi: rtw89: 8922a: extend and add quota number
authorPing-Ke Shih <pkshih@realtek.com>
Fri, 24 Nov 2023 07:16:56 +0000 (15:16 +0800)
committerKalle Valo <kvalo@kernel.org>
Fri, 1 Dec 2023 12:39:28 +0000 (14:39 +0200)
Define 8922A buffer quota that are used by HCI control flow, payload
engine, descriptor engine and etc for operation modes, such as SCC (single
channel concurrence) and download firmware. Since WiFi 7 chips has more
buffer classifications, add fields and struct according to design.

Signed-off-by: Ping-Ke Shih <pkshih@realtek.com>
Signed-off-by: Kalle Valo <kvalo@kernel.org>
Link: https://lore.kernel.org/r/20231124071703.132549-2-pkshih@realtek.com
drivers/net/wireless/realtek/rtw89/core.h
drivers/net/wireless/realtek/rtw89/mac.c
drivers/net/wireless/realtek/rtw89/mac.h
drivers/net/wireless/realtek/rtw89/rtw8922a.c

index c9f054c0f6fb2be44f491693226f220928558bb4..7010cf818fb4c3d9de468a561a0f61ef35ff29f3 100644 (file)
@@ -3292,6 +3292,8 @@ struct rtw89_dle_size {
        u16 pge_size;
        u16 lnk_pge_num;
        u16 unlnk_pge_num;
+       /* for WiFi 7 chips below */
+       u32 srt_ofst;
 };
 
 struct rtw89_wde_quota {
@@ -3314,6 +3316,26 @@ struct rtw89_ple_quota {
        u16 wd_rel;
        u16 cpu_io;
        u16 tx_rpt;
+       /* for WiFi 7 chips below */
+       u16 h2d;
+};
+
+struct rtw89_rsvd_quota {
+       u16 mpdu_info_tbl;
+       u16 b0_csi;
+       u16 b1_csi;
+       u16 b0_lmr;
+       u16 b1_lmr;
+       u16 b0_ftm;
+       u16 b1_ftm;
+       u16 b0_smr;
+       u16 b1_smr;
+       u16 others;
+};
+
+struct rtw89_dle_rsvd_size {
+       u32 srt_ofst;
+       u32 size;
 };
 
 struct rtw89_dle_mem {
@@ -3324,6 +3346,10 @@ struct rtw89_dle_mem {
        const struct rtw89_wde_quota *wde_max_qt;
        const struct rtw89_ple_quota *ple_min_qt;
        const struct rtw89_ple_quota *ple_max_qt;
+       /* for WiFi 7 chips below */
+       const struct rtw89_rsvd_quota *rsvd_qt;
+       const struct rtw89_dle_rsvd_size *rsvd0_size;
+       const struct rtw89_dle_rsvd_size *rsvd1_size;
 };
 
 struct rtw89_reg_def {
index 9ec3070516115cdf5034b417550defdbb90f6c1d..b93a00f56cb94d555108981a220961b209eb27c2 100644 (file)
@@ -1461,10 +1461,14 @@ static int rtw89_mac_sys_init(struct rtw89_dev *rtwdev)
 
 const struct rtw89_mac_size_set rtw89_mac_size = {
        .hfc_preccfg_pcie = {2, 40, 0, 0, 1, 0, 0, 0},
+       .hfc_prec_cfg_c0 = {2, 32, 0, 0, 0, 0, 0, 0},
+       .hfc_prec_cfg_c2 = {0, 256, 0, 0, 0, 0, 0, 0},
        /* PCIE 64 */
        .wde_size0 = {RTW89_WDE_PG_64, 4095, 1,},
+       .wde_size0_v1 = {RTW89_WDE_PG_64, 3328, 0, 0,},
        /* DLFW */
        .wde_size4 = {RTW89_WDE_PG_64, 0, 4096,},
+       .wde_size4_v1 = {RTW89_WDE_PG_64, 0, 3328, 0,},
        /* PCIE 64 */
        .wde_size6 = {RTW89_WDE_PG_64, 512, 0,},
        /* 8852B PCIE SCC */
@@ -1477,6 +1481,8 @@ const struct rtw89_mac_size_set rtw89_mac_size = {
        .wde_size19 = {RTW89_WDE_PG_64, 3328, 0,},
        /* PCIE */
        .ple_size0 = {RTW89_PLE_PG_128, 1520, 16,},
+       .ple_size0_v1 = {RTW89_PLE_PG_128, 2672, 256, 212992,},
+       .ple_size3_v1 = {RTW89_PLE_PG_128, 2928, 0, 212992,},
        /* DLFW */
        .ple_size4 = {RTW89_PLE_PG_128, 64, 1472,},
        /* PCIE 64 */
@@ -1489,6 +1495,7 @@ const struct rtw89_mac_size_set rtw89_mac_size = {
        .ple_size19 = {RTW89_PLE_PG_128, 1904, 16,},
        /* PCIE 64 */
        .wde_qt0 = {3792, 196, 0, 107,},
+       .wde_qt0_v1 = {3302, 6, 0, 20,},
        /* DLFW */
        .wde_qt4 = {0, 0, 0, 0,},
        /* PCIE 64 */
@@ -1499,10 +1506,13 @@ const struct rtw89_mac_size_set rtw89_mac_size = {
        .wde_qt17 = {0, 0, 0,  0,},
        /* 8852C PCIE SCC */
        .wde_qt18 = {3228, 60, 0, 40,},
+       .ple_qt0 = {320, 0, 32, 16, 13, 13, 292, 0, 32, 18, 1, 4, 0,},
+       .ple_qt1 = {320, 0, 32, 16, 1944, 1944, 2223, 0, 1963, 1949, 1, 1935, 0,},
        /* PCIE SCC */
        .ple_qt4 = {264, 0, 16, 20, 26, 13, 356, 0, 32, 40, 8,},
        /* PCIE SCC */
        .ple_qt5 = {264, 0, 32, 20, 64, 13, 1101, 0, 64, 128, 120,},
+       .ple_qt9 = {0, 0, 32, 256, 0, 0, 0, 0, 0, 0, 1, 0, 0,},
        /* DLFW */
        .ple_qt13 = {0, 0, 16, 48, 0, 0, 0, 0, 0, 0, 0,},
        /* PCIE 64 */
@@ -1523,6 +1533,10 @@ const struct rtw89_mac_size_set rtw89_mac_size = {
        .ple_qt_52b_wow = {147, 0, 16, 20, 157, 13, 133, 0, 172, 14, 24, 0,},
        /* 8851B PCIE WOW */
        .ple_qt_51b_wow = {147, 0, 16, 20, 157, 13, 133, 0, 172, 14, 24, 0,},
+       .ple_rsvd_qt0 = {2, 112, 56, 6, 6, 6, 6, 0, 0, 62,},
+       .ple_rsvd_qt1 = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0,},
+       .rsvd0_size0 = {212992, 0,},
+       .rsvd1_size0 = {587776, 2048,},
 };
 EXPORT_SYMBOL(rtw89_mac_size);
 
index f47a42387a6a6c3284c4c41bf1589803cdaa8f1b..511ee5dc424049b598505a86c8c263bdb315f96f 100644 (file)
@@ -818,27 +818,37 @@ enum mac_ax_err_info {
 
 struct rtw89_mac_size_set {
        const struct rtw89_hfc_prec_cfg hfc_preccfg_pcie;
+       const struct rtw89_hfc_prec_cfg hfc_prec_cfg_c0;
+       const struct rtw89_hfc_prec_cfg hfc_prec_cfg_c2;
        const struct rtw89_dle_size wde_size0;
+       const struct rtw89_dle_size wde_size0_v1;
        const struct rtw89_dle_size wde_size4;
+       const struct rtw89_dle_size wde_size4_v1;
        const struct rtw89_dle_size wde_size6;
        const struct rtw89_dle_size wde_size7;
        const struct rtw89_dle_size wde_size9;
        const struct rtw89_dle_size wde_size18;
        const struct rtw89_dle_size wde_size19;
        const struct rtw89_dle_size ple_size0;
+       const struct rtw89_dle_size ple_size0_v1;
+       const struct rtw89_dle_size ple_size3_v1;
        const struct rtw89_dle_size ple_size4;
        const struct rtw89_dle_size ple_size6;
        const struct rtw89_dle_size ple_size8;
        const struct rtw89_dle_size ple_size18;
        const struct rtw89_dle_size ple_size19;
        const struct rtw89_wde_quota wde_qt0;
+       const struct rtw89_wde_quota wde_qt0_v1;
        const struct rtw89_wde_quota wde_qt4;
        const struct rtw89_wde_quota wde_qt6;
        const struct rtw89_wde_quota wde_qt7;
        const struct rtw89_wde_quota wde_qt17;
        const struct rtw89_wde_quota wde_qt18;
+       const struct rtw89_ple_quota ple_qt0;
+       const struct rtw89_ple_quota ple_qt1;
        const struct rtw89_ple_quota ple_qt4;
        const struct rtw89_ple_quota ple_qt5;
+       const struct rtw89_ple_quota ple_qt9;
        const struct rtw89_ple_quota ple_qt13;
        const struct rtw89_ple_quota ple_qt18;
        const struct rtw89_ple_quota ple_qt44;
@@ -849,6 +859,10 @@ struct rtw89_mac_size_set {
        const struct rtw89_ple_quota ple_qt_52a_wow;
        const struct rtw89_ple_quota ple_qt_52b_wow;
        const struct rtw89_ple_quota ple_qt_51b_wow;
+       const struct rtw89_rsvd_quota ple_rsvd_qt0;
+       const struct rtw89_rsvd_quota ple_rsvd_qt1;
+       const struct rtw89_dle_rsvd_size rsvd0_size0;
+       const struct rtw89_dle_rsvd_size rsvd1_size0;
 };
 
 extern const struct rtw89_mac_size_set rtw89_mac_size;
index d190f095a5a8f48f31289b97b07da7ece6909d4e..b75d555d0cc3b032aecb4cc6f61212d2e8d3b4c7 100644 (file)
 #define RTW8922A_MODULE_FIRMWARE \
        RTW8922A_FW_BASENAME ".bin"
 
+static const struct rtw89_hfc_ch_cfg rtw8922a_hfc_chcfg_pcie[] = {
+       {2, 1641, grp_0}, /* ACH 0 */
+       {2, 1641, grp_0}, /* ACH 1 */
+       {2, 1641, grp_0}, /* ACH 2 */
+       {2, 1641, grp_0}, /* ACH 3 */
+       {2, 1641, grp_1}, /* ACH 4 */
+       {2, 1641, grp_1}, /* ACH 5 */
+       {2, 1641, grp_1}, /* ACH 6 */
+       {2, 1641, grp_1}, /* ACH 7 */
+       {2, 1641, grp_0}, /* B0MGQ */
+       {2, 1641, grp_0}, /* B0HIQ */
+       {2, 1641, grp_1}, /* B1MGQ */
+       {2, 1641, grp_1}, /* B1HIQ */
+       {0, 0, 0}, /* FWCMDQ */
+       {0, 0, 0}, /* BMC */
+       {0, 0, 0}, /* H2D */
+};
+
+static const struct rtw89_hfc_pub_cfg rtw8922a_hfc_pubcfg_pcie = {
+       1651, /* Group 0 */
+       1651, /* Group 1 */
+       3302, /* Public Max */
+       0, /* WP threshold */
+};
+
+static const struct rtw89_hfc_param_ini rtw8922a_hfc_param_ini_pcie[] = {
+       [RTW89_QTA_SCC] = {rtw8922a_hfc_chcfg_pcie, &rtw8922a_hfc_pubcfg_pcie,
+                          &rtw89_mac_size.hfc_prec_cfg_c0, RTW89_HCIFC_POH},
+       [RTW89_QTA_DLFW] = {NULL, NULL, &rtw89_mac_size.hfc_prec_cfg_c2,
+                           RTW89_HCIFC_POH},
+       [RTW89_QTA_INVALID] = {NULL},
+};
+
+static const struct rtw89_dle_mem rtw8922a_dle_mem_pcie[] = {
+       [RTW89_QTA_SCC] = {RTW89_QTA_SCC, &rtw89_mac_size.wde_size0_v1,
+                          &rtw89_mac_size.ple_size0_v1, &rtw89_mac_size.wde_qt0_v1,
+                          &rtw89_mac_size.wde_qt0_v1, &rtw89_mac_size.ple_qt0,
+                          &rtw89_mac_size.ple_qt1, &rtw89_mac_size.ple_rsvd_qt0,
+                          &rtw89_mac_size.rsvd0_size0, &rtw89_mac_size.rsvd1_size0},
+       [RTW89_QTA_DLFW] = {RTW89_QTA_DLFW, &rtw89_mac_size.wde_size4_v1,
+                           &rtw89_mac_size.ple_size3_v1, &rtw89_mac_size.wde_qt4,
+                           &rtw89_mac_size.wde_qt4, &rtw89_mac_size.ple_qt9,
+                           &rtw89_mac_size.ple_qt9, &rtw89_mac_size.ple_rsvd_qt1,
+                           &rtw89_mac_size.rsvd0_size0, &rtw89_mac_size.rsvd1_size0},
+       [RTW89_QTA_INVALID] = {RTW89_QTA_INVALID, NULL, NULL, NULL, NULL, NULL,
+                              NULL},
+};
+
 static const struct rtw89_efuse_block_cfg rtw8922a_efuse_blocks[] = {
        [RTW89_EFUSE_BLOCK_SYS]                 = {.offset = 0x00000, .size = 0x310},
        [RTW89_EFUSE_BLOCK_RF]                  = {.offset = 0x10000, .size = 0x240},
@@ -292,6 +340,8 @@ const struct rtw89_chip_info rtw8922a_chip_info = {
        .max_amsdu_limit        = 8000,
        .dis_2g_40m_ul_ofdma    = false,
        .rsvd_ple_ofst          = 0x8f800,
+       .hfc_param_ini          = rtw8922a_hfc_param_ini_pcie,
+       .dle_mem                = rtw8922a_dle_mem_pcie,
        .rf_base_addr           = {0xe000, 0xf000},
        .pwr_on_seq             = NULL,
        .pwr_off_seq            = NULL,