]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
wifi: rtw89: 8852a: move DIG tables to rtw8852a.c
authorZong-Zhe Yang <kevin_yang@realtek.com>
Fri, 13 Feb 2026 06:15:45 +0000 (14:15 +0800)
committerPing-Ke Shih <pkshih@realtek.com>
Tue, 3 Mar 2026 02:33:15 +0000 (10:33 +0800)
Now, most of PHY parameter tables in driver can be loaded via FW elements.
Plan to generate the corresponding FW elements for 8852A PHY tables. Then,
after FW elements work for a enough time, rtw8852a_table.c can be cleaned
up. However, DIG (dynamic initial gain) tables are legacy for 8852A only,
so FW element doesn't support. Their sizes are not very big, so move them
to rtw8852a.c and keep rtw8852a_table.c for PHY tables which are supported
by FW elements.

No logic is changed.

Signed-off-by: Zong-Zhe Yang <kevin_yang@realtek.com>
Signed-off-by: Ping-Ke Shih <pkshih@realtek.com>
Link: https://patch.msgid.link/20260213061552.29997-6-pkshih@realtek.com
drivers/net/wireless/realtek/rtw89/rtw8852a.c
drivers/net/wireless/realtek/rtw89/rtw8852a_table.c
drivers/net/wireless/realtek/rtw89/rtw8852a_table.h

index 0d5ec97557831c837adcffc4c96b6d51a24c82b4..6089cf9e1d5408e3db18bbc569640684145ff07b 100644 (file)
@@ -2179,6 +2179,57 @@ static void rtw8852a_query_ppdu(struct rtw89_dev *rtwdev,
                rtw8852a_fill_freq_with_ppdu(rtwdev, phy_ppdu, status);
 }
 
+#define DECLARE_DIG_TABLE(name) \
+static const struct rtw89_phy_dig_gain_cfg name##_table = { \
+       .table = name, \
+       .size = ARRAY_SIZE(name) \
+}
+
+static const struct rtw89_reg_def rtw89_8852a_lna_gain_g[] = {
+       {R_PATH0_LNA_ERR1, B_PATH0_LNA_ERR_G0_G_MSK},
+       {R_PATH0_LNA_ERR2, B_PATH0_LNA_ERR_G1_G_MSK},
+       {R_PATH0_LNA_ERR2, B_PATH0_LNA_ERR_G2_G_MSK},
+       {R_PATH0_LNA_ERR3, B_PATH0_LNA_ERR_G3_G_MSK},
+       {R_PATH0_LNA_ERR3, B_PATH0_LNA_ERR_G4_G_MSK},
+       {R_PATH0_LNA_ERR4, B_PATH0_LNA_ERR_G5_G_MSK},
+       {R_PATH0_LNA_ERR5, B_PATH0_LNA_ERR_G6_G_MSK},
+};
+
+DECLARE_DIG_TABLE(rtw89_8852a_lna_gain_g);
+
+static const struct rtw89_reg_def rtw89_8852a_tia_gain_g[] = {
+       {R_PATH0_TIA_ERR_G0, B_PATH0_TIA_ERR_G0_G_MSK},
+       {R_PATH0_TIA_ERR_G1, B_PATH0_TIA_ERR_G1_G_MSK},
+};
+
+DECLARE_DIG_TABLE(rtw89_8852a_tia_gain_g);
+
+static const struct rtw89_reg_def rtw89_8852a_lna_gain_a[] = {
+       {R_PATH0_LNA_ERR1, B_PATH0_LNA_ERR_G0_A_MSK},
+       {R_PATH0_LNA_ERR1, B_PATH0_LNA_ERR_G1_A_MSK},
+       {R_PATH0_LNA_ERR2, B_PATH0_LNA_ERR_G2_A_MSK},
+       {R_PATH0_LNA_ERR3, B_PATH0_LNA_ERR_G3_A_MSK},
+       {R_PATH0_LNA_ERR3, B_PATH0_LNA_ERR_G4_A_MSK},
+       {R_PATH0_LNA_ERR4, B_PATH0_LNA_ERR_G5_A_MSK},
+       {R_PATH0_LNA_ERR4, B_PATH0_LNA_ERR_G6_A_MSK},
+};
+
+DECLARE_DIG_TABLE(rtw89_8852a_lna_gain_a);
+
+static const struct rtw89_reg_def rtw89_8852a_tia_gain_a[] = {
+       {R_PATH0_TIA_ERR_G0, B_PATH0_TIA_ERR_G0_A_MSK},
+       {R_PATH0_TIA_ERR_G1, B_PATH0_TIA_ERR_G1_A_MSK},
+};
+
+DECLARE_DIG_TABLE(rtw89_8852a_tia_gain_a);
+
+static const struct rtw89_phy_dig_gain_table rtw89_8852a_phy_dig_table = {
+       .cfg_lna_g = &rtw89_8852a_lna_gain_g_table,
+       .cfg_tia_g = &rtw89_8852a_tia_gain_g_table,
+       .cfg_lna_a = &rtw89_8852a_lna_gain_a_table,
+       .cfg_tia_a = &rtw89_8852a_tia_gain_a_table
+};
+
 #ifdef CONFIG_PM
 static const struct wiphy_wowlan_support rtw_wowlan_stub_8852a = {
        .flags = WIPHY_WOWLAN_MAGIC_PKT | WIPHY_WOWLAN_DISCONNECT,
index 495890c180ef6fa64dfae4acc350dde22b17ca78..ffdeb38019910eafb465d27769b3ba73b1b20ba2 100644 (file)
@@ -50952,50 +50952,6 @@ const s8 rtw89_8852a_txpwr_lmt_ru_5g[RTW89_RU_NUM][RTW89_NTX_NUM]
        [2][1][RTW89_UK][46] = 32,
 };
 
-#define DECLARE_DIG_TABLE(name) \
-static const struct rtw89_phy_dig_gain_cfg name##_table = { \
-       .table = name, \
-       .size = ARRAY_SIZE(name) \
-}
-
-static const struct rtw89_reg_def rtw89_8852a_lna_gain_g[] = {
-       {R_PATH0_LNA_ERR1, B_PATH0_LNA_ERR_G0_G_MSK},
-       {R_PATH0_LNA_ERR2, B_PATH0_LNA_ERR_G1_G_MSK},
-       {R_PATH0_LNA_ERR2, B_PATH0_LNA_ERR_G2_G_MSK},
-       {R_PATH0_LNA_ERR3, B_PATH0_LNA_ERR_G3_G_MSK},
-       {R_PATH0_LNA_ERR3, B_PATH0_LNA_ERR_G4_G_MSK},
-       {R_PATH0_LNA_ERR4, B_PATH0_LNA_ERR_G5_G_MSK},
-       {R_PATH0_LNA_ERR5, B_PATH0_LNA_ERR_G6_G_MSK},
-};
-
-DECLARE_DIG_TABLE(rtw89_8852a_lna_gain_g);
-
-static const struct rtw89_reg_def rtw89_8852a_tia_gain_g[] = {
-       {R_PATH0_TIA_ERR_G0, B_PATH0_TIA_ERR_G0_G_MSK},
-       {R_PATH0_TIA_ERR_G1, B_PATH0_TIA_ERR_G1_G_MSK},
-};
-
-DECLARE_DIG_TABLE(rtw89_8852a_tia_gain_g);
-
-static const struct rtw89_reg_def rtw89_8852a_lna_gain_a[] = {
-       {R_PATH0_LNA_ERR1, B_PATH0_LNA_ERR_G0_A_MSK},
-       {R_PATH0_LNA_ERR1, B_PATH0_LNA_ERR_G1_A_MSK},
-       {R_PATH0_LNA_ERR2, B_PATH0_LNA_ERR_G2_A_MSK},
-       {R_PATH0_LNA_ERR3, B_PATH0_LNA_ERR_G3_A_MSK},
-       {R_PATH0_LNA_ERR3, B_PATH0_LNA_ERR_G4_A_MSK},
-       {R_PATH0_LNA_ERR4, B_PATH0_LNA_ERR_G5_A_MSK},
-       {R_PATH0_LNA_ERR4, B_PATH0_LNA_ERR_G6_A_MSK},
-};
-
-DECLARE_DIG_TABLE(rtw89_8852a_lna_gain_a);
-
-static const struct rtw89_reg_def rtw89_8852a_tia_gain_a[] = {
-       {R_PATH0_TIA_ERR_G0, B_PATH0_TIA_ERR_G0_A_MSK},
-       {R_PATH0_TIA_ERR_G1, B_PATH0_TIA_ERR_G1_A_MSK},
-};
-
-DECLARE_DIG_TABLE(rtw89_8852a_tia_gain_a);
-
 const struct rtw89_phy_table rtw89_8852a_phy_bb_table = {
        .regs           = rtw89_8852a_phy_bb_regs,
        .n_regs         = ARRAY_SIZE(rtw89_8852a_phy_bb_regs),
@@ -51042,13 +50998,6 @@ const struct rtw89_txpwr_track_cfg rtw89_8852a_trk_cfg = {
        .delta_swingidx_2g_cck_a_p = _txpwr_track_delta_swingidx_2g_cck_a_p,
 };
 
-const struct rtw89_phy_dig_gain_table rtw89_8852a_phy_dig_table = {
-       .cfg_lna_g = &rtw89_8852a_lna_gain_g_table,
-       .cfg_tia_g = &rtw89_8852a_tia_gain_g_table,
-       .cfg_lna_a = &rtw89_8852a_lna_gain_a_table,
-       .cfg_tia_a = &rtw89_8852a_tia_gain_a_table
-};
-
 const struct rtw89_rfe_parms rtw89_8852a_dflt_parms = {
        .byr_tbl = &rtw89_8852a_byr_table,
        .rule_2ghz = {
index 7463ae6ee3f9b2bbb944bd13bbe7fa3aa25cd891..58fe8575c1c9a1e0734620f9c869708b6eb7a2ea 100644 (file)
@@ -11,7 +11,6 @@ extern const struct rtw89_phy_table rtw89_8852a_phy_bb_table;
 extern const struct rtw89_phy_table rtw89_8852a_phy_radioa_table;
 extern const struct rtw89_phy_table rtw89_8852a_phy_radiob_table;
 extern const struct rtw89_phy_table rtw89_8852a_phy_nctl_table;
-extern const struct rtw89_phy_dig_gain_table rtw89_8852a_phy_dig_table;
 extern const struct rtw89_txpwr_track_cfg rtw89_8852a_trk_cfg;
 extern const struct rtw89_rfe_parms rtw89_8852a_dflt_parms;