]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
wifi: ath12k: Fetch regdb.bin file from board-2.bin
authorAaradhana Sahu <quic_aarasahu@quicinc.com>
Thu, 16 Jan 2025 03:28:35 +0000 (08:58 +0530)
committerJeff Johnson <jeff.johnson@oss.qualcomm.com>
Wed, 29 Jan 2025 16:56:33 +0000 (08:56 -0800)
Currently, ath12k_core_fetch_regdb() finds regdb.bin file through
board id's but in board-2.bin file regdb.bin file is present with
default board id because of which regdb.bin is not fetched.

Add support to fetch regdb.bin file from board-2.bin through
default board id.

Tested-on: QCN9274 hw2.0 PCI WLAN.WBE.1.3.1-00173-QCAHKSWPL_SILICONZ-1

Signed-off-by: Aaradhana Sahu <quic_aarasahu@quicinc.com>
Reviewed-by: Aditya Kumar Singh <quic_adisi@quicinc.com>
Link: https://patch.msgid.link/20250116032835.118397-1-quic_aarasahu@quicinc.com
Signed-off-by: Jeff Johnson <jeff.johnson@oss.qualcomm.com>
drivers/net/wireless/ath/ath12k/core.c

index 2dd0666959cd4fbdfc17a36b4029fe06fc575d3f..60c077b016b4009d5b7cf28c1858d743d00ea02d 100644 (file)
@@ -177,7 +177,7 @@ EXPORT_SYMBOL(ath12k_core_resume);
 
 static int __ath12k_core_create_board_name(struct ath12k_base *ab, char *name,
                                           size_t name_len, bool with_variant,
-                                          bool bus_type_mode)
+                                          bool bus_type_mode, bool with_default)
 {
        /* strlen(',variant=') + strlen(ab->qmi.target.bdf_ext) */
        char variant[9 + ATH12K_QMI_BDF_EXT_STR_LENGTH] = { 0 };
@@ -208,7 +208,9 @@ static int __ath12k_core_create_board_name(struct ath12k_base *ab, char *name,
                          "bus=%s,qmi-chip-id=%d,qmi-board-id=%d%s",
                          ath12k_bus_str(ab->hif.bus),
                          ab->qmi.target.chip_id,
-                         ab->qmi.target.board_id, variant);
+                         with_default ?
+                         ATH12K_BOARD_ID_DEFAULT : ab->qmi.target.board_id,
+                         variant);
                break;
        }
 
@@ -220,19 +222,19 @@ static int __ath12k_core_create_board_name(struct ath12k_base *ab, char *name,
 static int ath12k_core_create_board_name(struct ath12k_base *ab, char *name,
                                         size_t name_len)
 {
-       return __ath12k_core_create_board_name(ab, name, name_len, true, false);
+       return __ath12k_core_create_board_name(ab, name, name_len, true, false, false);
 }
 
 static int ath12k_core_create_fallback_board_name(struct ath12k_base *ab, char *name,
                                                  size_t name_len)
 {
-       return __ath12k_core_create_board_name(ab, name, name_len, false, false);
+       return __ath12k_core_create_board_name(ab, name, name_len, false, false, true);
 }
 
 static int ath12k_core_create_bus_type_board_name(struct ath12k_base *ab, char *name,
                                                  size_t name_len)
 {
-       return __ath12k_core_create_board_name(ab, name, name_len, false, true);
+       return __ath12k_core_create_board_name(ab, name, name_len, false, true, true);
 }
 
 const struct firmware *ath12k_core_firmware_request(struct ath12k_base *ab,