wifi: rtw89: fw: move polling function of firmware path ready to an individual function
authorPing-Ke Shih <pkshih@realtek.com>
Fri, 1 Sep 2023 07:39:49 +0000 (15:39 +0800)
committerKalle Valo <kvalo@kernel.org>
Thu, 7 Sep 2023 05:57:14 +0000 (08:57 +0300)
To download firmware, we need to check path is ready. There are two kinds
of path -- one is to download firmware header, and the other is to download
firmware body.

Since the polling method is different from WiFi 7 chips, make it to be
an individual function, and then we can reuse the download flow.

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

index 763872d3b7c7015bd9d26476dad3343e8319f8c7..85edc7afabd44537cf94953b2bc23e2471f5f968 100644 (file)
@@ -54,7 +54,6 @@ static u8 _fw_get_rdy(struct rtw89_dev *rtwdev)
        return FIELD_GET(B_AX_WCPU_FWDL_STS_MASK, val);
 }
 
-#define FWDL_WAIT_CNT 400000
 int rtw89_fw_check_rdy(struct rtw89_dev *rtwdev)
 {
        u8 val;
@@ -768,7 +767,6 @@ fail:
 
 static int rtw89_fw_download_hdr(struct rtw89_dev *rtwdev, const u8 *fw, u32 len)
 {
-       u8 val;
        int ret;
 
        ret = __rtw89_fw_download_hdr(rtwdev, fw, len);
@@ -777,9 +775,7 @@ static int rtw89_fw_download_hdr(struct rtw89_dev *rtwdev, const u8 *fw, u32 len
                return ret;
        }
 
-       ret = read_poll_timeout_atomic(rtw89_read8, val, val & B_AX_FWDL_PATH_RDY,
-                                      1, FWDL_WAIT_CNT, false,
-                                      rtwdev, R_AX_WCPU_FW_CTRL);
+       ret = rtw89_fwdl_check_path_ready_ax(rtwdev, false);
        if (ret) {
                rtw89_err(rtwdev, "[ERR]FWDL path ready\n");
                return ret;
@@ -892,7 +888,6 @@ int rtw89_fw_download(struct rtw89_dev *rtwdev, enum rtw89_fw_type type)
        struct rtw89_fw_info *fw_info = &rtwdev->fw;
        struct rtw89_fw_suit *fw_suit = rtw89_fw_suit_get(rtwdev, type);
        struct rtw89_fw_bin_info info;
-       u8 val;
        int ret;
 
        rtw89_mac_disable_cpu(rtwdev);
@@ -906,9 +901,7 @@ int rtw89_fw_download(struct rtw89_dev *rtwdev, enum rtw89_fw_type type)
                goto fwdl_err;
        }
 
-       ret = read_poll_timeout_atomic(rtw89_read8, val, val & B_AX_H2C_PATH_RDY,
-                                      1, FWDL_WAIT_CNT, false,
-                                      rtwdev, R_AX_WCPU_FW_CTRL);
+       ret = rtw89_fwdl_check_path_ready_ax(rtwdev, true);
        if (ret) {
                rtw89_err(rtwdev, "[ERR]H2C path ready\n");
                goto fwdl_err;
index 156d09dfca45edcba3cda3262ed54573a4e8a00e..430e5cff0510c8fc6fad70a9147ad96f44fec148 100644 (file)
@@ -3618,6 +3618,8 @@ struct rtw89_fw_h2c_rf_get_mccch {
 #define RTW89_FW_BACKTRACE_MAX_SIZE 512 /* 8 * 64 (entries) */
 #define RTW89_FW_BACKTRACE_KEY 0xBACEBACE
 
+#define FWDL_WAIT_CNT 400000
+
 int rtw89_fw_check_rdy(struct rtw89_dev *rtwdev);
 int rtw89_fw_recognize(struct rtw89_dev *rtwdev);
 int rtw89_fw_recognize_elements(struct rtw89_dev *rtwdev);
index fab9f5004a75e3eff2b01813b602c9725a539a01..013114fd9d1981b9d7d45ca15c90dfe01bf3a340 100644 (file)
@@ -5684,6 +5684,17 @@ int rtw89_mac_ptk_drop_by_band_and_wait(struct rtw89_dev *rtwdev,
        return ret;
 }
 
+int rtw89_fwdl_check_path_ready_ax(struct rtw89_dev *rtwdev,
+                                  bool h2c_or_fwdl)
+{
+       u8 check = h2c_or_fwdl ? B_AX_H2C_PATH_RDY : B_AX_FWDL_PATH_RDY;
+       u8 val;
+
+       return read_poll_timeout_atomic(rtw89_read8, val, val & check,
+                                       1, FWDL_WAIT_CNT, false,
+                                       rtwdev, R_AX_WCPU_FW_CTRL);
+}
+
 const struct rtw89_mac_gen_def rtw89_mac_gen_ax = {
        .band1_offset = RTW89_MAC_AX_BAND_REG_OFFSET,
        .filter_model_addr = R_AX_FILTER_MODEL_ADDR,
index 7cf34137c0bcfc2513757997c162bdf97cd52e1e..a9a571df3a77a688079d7bfe6e7f47394e300852 100644 (file)
@@ -1207,5 +1207,7 @@ int rtw89_mac_resize_ple_rx_quota(struct rtw89_dev *rtwdev, bool wow);
 int rtw89_mac_ptk_drop_by_band_and_wait(struct rtw89_dev *rtwdev,
                                        enum rtw89_mac_idx band);
 void rtw89_mac_hw_mgnt_sec(struct rtw89_dev *rtwdev, bool wow);
+int rtw89_fwdl_check_path_ready_ax(struct rtw89_dev *rtwdev,
+                                  bool h2c_or_fwdl);
 
 #endif