]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
rtw89: add hci_func_en_addr to support variant generation
authorPing-Ke Shih <pkshih@realtek.com>
Mon, 7 Mar 2022 06:04:51 +0000 (14:04 +0800)
committerKalle Valo <kvalo@kernel.org>
Thu, 10 Mar 2022 16:42:58 +0000 (18:42 +0200)
The HCI_FUNC_EN address of 8852C is different from existing chipset, so
add a chip_info::hci_func_en_addr to fill the address individually.

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

index b92dc2a03724204a32a12a0c2949f7f1e10122af..1aec32e8afba2b5fdc9b8f4dd5b2078504066209 100644 (file)
@@ -2307,6 +2307,8 @@ struct rtw89_chip_info {
        u8 rf_para_dlink_num;
        const struct rtw89_btc_rf_trx_para *rf_para_dlink;
        u8 ps_mode_supported;
+
+       u32 hci_func_en_addr;
 };
 
 union rtw89_bus_info {
index d202ee761e90266def72734a8dcc45e832c0742c..9ba47a72812f94ab3b17844f69575d066fb3022e 100644 (file)
@@ -2619,7 +2619,9 @@ static int rtw89_mac_fw_dl_pre_init(struct rtw89_dev *rtwdev)
 
 static void rtw89_mac_hci_func_en(struct rtw89_dev *rtwdev)
 {
-       rtw89_write32_set(rtwdev, R_AX_HCI_FUNC_EN,
+       const struct rtw89_chip_info *chip = rtwdev->chip;
+
+       rtw89_write32_set(rtwdev, chip->hci_func_en_addr,
                          B_AX_HCI_TXDMA_EN | B_AX_HCI_RXDMA_EN);
 }
 
index bb95e524d67beec4af5a40a712c859ca52e4439b..86b18dbbc76918ef1bdb21e37782c7f062682f2c 100644 (file)
 #define B_AX_ASFF_FULL_NO_STK BIT(1)
 #define B_AX_EN_STUCK_DBG BIT(0)
 
+#define R_AX_HCI_FUNC_EN_V1 0x7880
+
 #define R_AX_PHYREG_SET 0x8040
 #define PHYREG_SET_ALL_CYCLE 0x8
 
index 1448214d6241b0baee8ece8f20815597540af082..86a5808a76c8045e593bb6e0fcc92ac32512557b 100644 (file)
@@ -2057,6 +2057,7 @@ const struct rtw89_chip_info rtw8852a_chip_info = {
        .ps_mode_supported      = BIT(RTW89_PS_MODE_RFOFF) |
                                  BIT(RTW89_PS_MODE_CLK_GATED) |
                                  BIT(RTW89_PS_MODE_PWR_GATED),
+       .hci_func_en_addr       = R_AX_HCI_FUNC_EN,
 };
 EXPORT_SYMBOL(rtw8852a_chip_info);
 
index cb4bcb85c418519d25451be8e1245dece1ca0293..3fa2dd4ff514c1dea3074cdc9a55dd5eac25b709 100644 (file)
@@ -194,6 +194,7 @@ const struct rtw89_chip_info rtw8852c_chip_info = {
        .fw_name                = "rtw89/rtw8852c_fw.bin",
        .pwr_on_seq             = NULL,
        .pwr_off_seq            = NULL,
+       .hci_func_en_addr       = R_AX_HCI_FUNC_EN_V1,
 };
 EXPORT_SYMBOL(rtw8852c_chip_info);