ath11k: convert ath11k_hw_params to an array
authorAnilkumar Kolli <akolli@codeaurora.org>
Tue, 16 Jun 2020 14:00:45 +0000 (17:00 +0300)
committerKalle Valo <kvalo@codeaurora.org>
Tue, 23 Jun 2020 07:51:37 +0000 (10:51 +0300)
Convert to ath11k_hw_params to an array to make it possible add new hardware in
the future, for example IPQ6018 or QCA6390.

No functional changes. Compile tested only.

Signed-off-by: Anilkumar Kolli <akolli@codeaurora.org>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
Link: https://lore.kernel.org/r/1592316055-24958-3-git-send-email-kvalo@codeaurora.org
drivers/net/wireless/ath/ath11k/core.c
drivers/net/wireless/ath/ath11k/hw.h

index 905cd8b..92d7925 100644 (file)
@@ -17,12 +17,15 @@ unsigned int ath11k_debug_mask;
 module_param_named(debug_mask, ath11k_debug_mask, uint, 0644);
 MODULE_PARM_DESC(debug_mask, "Debugging mask");
 
-static const struct ath11k_hw_params ath11k_hw_params = {
-       .name = "ipq8074",
-       .fw = {
-               .dir = IPQ8074_FW_DIR,
-               .board_size = IPQ8074_MAX_BOARD_DATA_SZ,
-               .cal_size =  IPQ8074_MAX_CAL_DATA_SZ,
+static const struct ath11k_hw_params ath11k_hw_params[] = {
+       {
+               .hw_rev = ATH11K_HW_IPQ8074,
+               .name = "ipq8074 hw2.0",
+               .fw = {
+                       .dir = IPQ8074_FW_DIR,
+                       .board_size = IPQ8074_MAX_BOARD_DATA_SZ,
+                       .cal_size =  IPQ8074_MAX_CAL_DATA_SZ,
+               },
        },
 };
 
@@ -717,6 +720,30 @@ static void ath11k_core_restart(struct work_struct *work)
        complete(&ab->driver_recovery);
 }
 
+static int ath11k_init_hw_params(struct ath11k_base *ab)
+{
+       const struct ath11k_hw_params *hw_params = NULL;
+       int i;
+
+       for (i = 0; i < ARRAY_SIZE(ath11k_hw_params); i++) {
+               hw_params = &ath11k_hw_params[i];
+
+               if (hw_params->hw_rev == ab->hw_rev)
+                       break;
+       }
+
+       if (i == ARRAY_SIZE(ath11k_hw_params)) {
+               ath11k_err(ab, "Unsupported hardware version: 0x%x\n", ab->hw_rev);
+               return -EINVAL;
+       }
+
+       ab->hw_params = *hw_params;
+
+       ath11k_dbg(ab, ATH11K_DBG_BOOT, "Hardware name %s\n", ab->hw_params.name);
+
+       return 0;
+}
+
 int ath11k_core_init(struct ath11k_base *ab)
 {
        struct device *dev = ab->dev;
@@ -735,7 +762,12 @@ int ath11k_core_init(struct ath11k_base *ab)
                return -EINVAL;
        }
        ab->tgt_rproc = prproc;
-       ab->hw_params = ath11k_hw_params;
+
+       ret = ath11k_init_hw_params(ab);
+       if (ret) {
+               ath11k_err(ab, "failed to get hw params %d\n", ret);
+               return ret;
+       }
 
        ret = ath11k_core_soc_create(ab);
        if (ret) {
index f7f070a..f95ad31 100644 (file)
@@ -106,6 +106,7 @@ enum ath11k_bus {
 
 struct ath11k_hw_params {
        const char *name;
+       u16 hw_rev;
        struct {
                const char *dir;
                size_t board_size;