]> git.proxmox.com Git - mirror_ubuntu-focal-kernel.git/commitdiff
rtw88: config 8822c multicast address in MAC init flow
authorTzu-En Huang <tehuang@realtek.com>
Tue, 8 Oct 2019 08:20:54 +0000 (16:20 +0800)
committerSeth Forshee <seth.forshee@canonical.com>
Fri, 20 Mar 2020 21:31:25 +0000 (16:31 -0500)
BugLink: https://bugs.launchpad.net/bugs/1780590
Multicast address should be congiured in the initialization flow.
The value is created by a hashed calculation that is also implemented
by the hardware for multicast address filtering.

Signed-off-by: Tzu-En Huang <tehuang@realtek.com>
Signed-off-by: Yan-Hsuan Chuang <yhchuang@realtek.com>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
(cherry picked from commit 27c65bfc434fb18db001c3ade07dbdb189eda7ec)
Signed-off-by: Kai-Heng Feng <kai.heng.feng@canonical.com>
Signed-off-by: Seth Forshee <seth.forshee@canonical.com>
drivers/net/wireless/realtek/rtw88/reg.h
drivers/net/wireless/realtek/rtw88/rtw8822c.c

index bd04c3fad1ee41909a7847142039562f0b825f5a..330574a9f55a3d6d0032a0de8e1ab0ad28746baa 100644 (file)
 #define REG_RX_PKT_LIMIT       0x060C
 #define REG_RX_DRVINFO_SZ      0x060F
 #define BIT_APP_PHYSTS         BIT(28)
+#define REG_MAR                        0x0620
 #define REG_USTIME_EDCA                0x0638
 #define REG_ACKTO_CCK          0x0639
 #define REG_RESP_SIFS_CCK      0x063C
index dd1031f78f9d13f788e6634478b56df645b36ee1..1748909f30720e2ac6920595ddd1e8b3a390a976 100644 (file)
@@ -1112,6 +1112,7 @@ static void rtw8822c_phy_set_param(struct rtw_dev *rtwdev)
 #define WLAN_RTS_RATE_FB_RATE4_H       0x400003E0
 #define WLAN_RTS_RATE_FB_RATE5         0x0600F015
 #define WLAN_RTS_RATE_FB_RATE5_H       0x000000E0
+#define WLAN_MULTI_ADDR                        0xFFFFFFFF
 
 #define WLAN_TX_FUNC_CFG1              0x30
 #define WLAN_TX_FUNC_CFG2              0x30
@@ -1221,6 +1222,8 @@ static int rtw8822c_mac_init(struct rtw_dev *rtwdev)
        rtw_write8(rtwdev, REG_BCN_MAX_ERR, WLAN_BCN_MAX_ERR);
 
        /* WMAC configuration */
+       rtw_write32(rtwdev, REG_MAR, WLAN_MULTI_ADDR);
+       rtw_write32(rtwdev, REG_MAR + 4, WLAN_MULTI_ADDR);
        rtw_write8(rtwdev, REG_BBPSF_CTRL + 2, WLAN_RESP_TXRATE);
        rtw_write8(rtwdev, REG_ACKTO, WLAN_ACK_TO);
        rtw_write8(rtwdev, REG_ACKTO_CCK, WLAN_ACK_TO_CCK);