Browse Source

qcacld-3.0: Add new Ini to control pcie gen and lane params

As per the requirement, add a new Ini CFG_PCIE_CONFIG to
enable or disable externally. This Ini is used to control
pcie generation speed and lane width parameters to max value.
If enabled as of now this Ini makes generation as 3 and lanes
as 2 for pcie.

Change-Id: I96c1a133fa0b22d3b35a229b2fd9ba2904bb3d8f
CRs-Fixed: 3481707
Aravind Kishore Sukla 1 year ago
parent
commit
21305513a9

+ 2 - 0
components/fw_offload/core/inc/wlan_fw_offload_main.h

@@ -221,6 +221,7 @@ struct wlan_fwol_tsf_accuracy_configs {
  * @ie_allowlist_cfg: IE Allowlist related config items
  * @neighbor_report_cfg: 11K neighbor report config
  * @ani_enabled: ANI enable/disable
+ * @pcie_config: to control pcie gen and lane params
  * @enable_rts_sifsbursting: Enable RTS SIFS Bursting
  * @enable_sifs_burst: Enable SIFS burst
  * @max_mpdus_inampdu: Max number of MPDUS
@@ -264,6 +265,7 @@ struct wlan_fwol_cfg {
 	struct wlan_fwol_ie_allowlist ie_allowlist_cfg;
 	struct wlan_fwol_neighbor_report_cfg neighbor_report_cfg;
 	bool ani_enabled;
+	bool pcie_config;
 	bool enable_rts_sifsbursting;
 	uint8_t enable_sifs_burst;
 	uint8_t max_mpdus_inampdu;

+ 1 - 0
components/fw_offload/core/src/wlan_fw_offload_main.c

@@ -654,6 +654,7 @@ QDF_STATUS fwol_cfg_on_psoc_enable(struct wlan_objmgr_psoc *psoc)
 	fwol_init_ie_whiltelist_in_cfg(psoc, &fwol_cfg->ie_allowlist_cfg);
 	fwol_init_neighbor_report_cfg(psoc, &fwol_cfg->neighbor_report_cfg);
 	fwol_cfg->ani_enabled = cfg_get(psoc, CFG_ENABLE_ANI);
+	fwol_cfg->pcie_config = cfg_get(psoc, CFG_PCIE_CONFIG);
 	fwol_cfg->enable_rts_sifsbursting =
 				cfg_get(psoc, CFG_SET_RTS_FOR_SIFS_BURSTING);
 	fwol_cfg->enable_sifs_burst = cfg_get(psoc, CFG_SET_SIFS_BURST);

+ 28 - 0
components/fw_offload/dispatcher/inc/cfg_fwol_generic.h

@@ -929,6 +929,33 @@
 		1, \
 		"enable pci gen")
 
+/*
+ * <ini>
+ * pcie_config - Ini to control pcie gen and lane params
+ * @Min: 0
+ * @Max: 1
+ * @Default: 0
+ *
+ * This ini is used to control to pcie gen and lane params
+ * 0 - FW controlled
+ * 1 - Force PCIe Gen and lane to max supported value
+ *
+ * Related: g_enable_pci_gen
+ *
+ * Supported Feature: PCI
+ *
+ * Usage: External
+ *
+ * </ini>
+ */
+#define CFG_PCIE_CONFIG CFG_INI_UINT( \
+				"pcie_config", \
+				0, \
+				1, \
+				0, \
+				CFG_VALUE_OR_DEFAULT, \
+				"to control pcie gen and lane")
+
 #define CFG_FWOL_GENERIC_ALL \
 	CFG_FWOL_DHCP \
 	CFG(CFG_ENABLE_ANI) \
@@ -961,6 +988,7 @@
 	CFG(CFG_SAP_SHO_CONFIG) \
 	CFG(CFG_DISABLE_HW_ASSIST) \
 	CFG(CFG_ENABLE_PCI_GEN) \
+	CFG(CFG_PCIE_CONFIG) \
 	ENABLE_OFDM_SCRAMBLER_SEED
 
 #endif

+ 17 - 0
components/fw_offload/dispatcher/inc/wlan_fwol_ucfg_api.h

@@ -219,6 +219,16 @@ ucfg_fwol_get_all_allowlist_params(struct wlan_objmgr_psoc *psoc,
 QDF_STATUS ucfg_fwol_get_ani_enabled(struct wlan_objmgr_psoc *psoc,
 				     bool *ani_enabled);
 
+/**
+ * ucfg_fwol_get_pcie_config() - Assigns the pcie_config value
+ * @psoc: pointer to the psoc object
+ * @pcie_config: pointer to return pcie_config value
+ *
+ * Return: QDF Status
+ */
+QDF_STATUS ucfg_fwol_get_pcie_config(struct wlan_objmgr_psoc *psoc,
+				     bool *pcie_config);
+
 /**
  * ucfg_get_enable_rts_sifsbursting() - Assigns the enable_rts_sifsbursting
  *                                      value
@@ -882,6 +892,13 @@ ucfg_fwol_get_ani_enabled(struct wlan_objmgr_psoc *psoc,
 	return QDF_STATUS_E_FAILURE;
 }
 
+static inline QDF_STATUS
+ucfg_fwol_get_pcie_config(struct wlan_objmgr_psoc *psoc,
+			  bool *pcie_config)
+{
+	return QDF_STATUS_E_FAILURE;
+}
+
 static inline QDF_STATUS
 ucfg_get_enable_rts_sifsbursting(struct wlan_objmgr_psoc *psoc,
 				 bool *enable_rts_sifsbursting)

+ 15 - 0
components/fw_offload/dispatcher/src/wlan_fwol_ucfg_api.c

@@ -322,6 +322,21 @@ QDF_STATUS ucfg_fwol_get_ani_enabled(struct wlan_objmgr_psoc *psoc,
 	return QDF_STATUS_SUCCESS;
 }
 
+QDF_STATUS ucfg_fwol_get_pcie_config(struct wlan_objmgr_psoc *psoc,
+				     bool *pcie_config)
+{
+	struct wlan_fwol_psoc_obj *fwol_obj;
+
+	fwol_obj = fwol_get_psoc_obj(psoc);
+	if (!fwol_obj) {
+		fwol_err("Failed to get FWOL obj");
+		return QDF_STATUS_E_FAILURE;
+	}
+
+	*pcie_config = fwol_obj->cfg.pcie_config;
+	return QDF_STATUS_SUCCESS;
+}
+
 static QDF_STATUS ucfg_fwol_get_ilp_config(struct wlan_objmgr_psoc *psoc,
 					   uint32_t *enable_ilp)
 {

+ 62 - 2
core/hdd/src/wlan_hdd_main.c

@@ -344,6 +344,9 @@ static qdf_wake_lock_t wlan_wake_lock;
 #define HDD_INVALID_MIN_PCIE_GEN_SPEED (0)
 #define HDD_INVALID_MAX_PCIE_GEN_SPEED (4)
 
+#define MAX_PDEV_PRE_ENABLE_PARAMS 8
+#define FTM_MAX_PDEV_PARAMS 1
+
 #define WOW_MAX_FILTER_LISTS 1
 #define WOW_MAX_FILTERS_PER_LIST 4
 #define WOW_MIN_PATTERN_SIZE 6
@@ -4523,6 +4526,44 @@ static inline void hdd_qmi_register_callbacks(struct hdd_context *hdd_ctx)
 	os_if_qmi_register_callbacks(hdd_ctx->psoc, &cb_obj);
 }
 
+/**
+ * hdd_set_pcie_params() - Set pcie params
+ * @hdd_ctx: HDD context
+ * @index: index value
+ * @param: pointer to vdev/pdev set param info
+ *
+ * Checks for pcie_config value and sets
+ * corresponding params
+ *
+ * Return: 0 on success and errno on failure.
+ */
+static int hdd_set_pcie_params(struct hdd_context *hdd_ctx,
+			       uint8_t index, struct dev_set_param *param)
+{
+	int ret = 0;
+	bool check_value = false;
+
+	ret = ucfg_fwol_get_pcie_config(hdd_ctx->psoc, &check_value);
+	if (QDF_IS_STATUS_SUCCESS(ret)) {
+		if (QDF_GLOBAL_FTM_MODE == hdd_get_conparam()) {
+			ret = mlme_check_index_setparam(param,
+					wmi_pdev_param_pcie_config,
+					(int)check_value, index++,
+					FTM_MAX_PDEV_PARAMS);
+		} else {
+			ret = mlme_check_index_setparam(param,
+					wmi_pdev_param_pcie_config,
+					(int)check_value, index++,
+					MAX_PDEV_PRE_ENABLE_PARAMS);
+		}
+		if (QDF_IS_STATUS_ERROR(ret)) {
+			hdd_err("failed to set wmi_pdev_param_pcie_config");
+			return ret;
+		}
+	}
+	return ret;
+}
+
 int hdd_wlan_start_modules(struct hdd_context *hdd_ctx, bool reinit)
 {
 	int ret = 0;
@@ -4533,6 +4574,8 @@ int hdd_wlan_start_modules(struct hdd_context *hdd_ctx, bool reinit)
 	struct target_psoc_info *tgt_hdl;
 	unsigned long thermal_state = 0;
 	bool is_sched_disabled = false;
+	uint8_t index = 0;
+	struct dev_set_param setparam[MAX_PDEV_PRE_ENABLE_PARAMS] = {};
 
 	hdd_enter();
 	qdf_dev = cds_get_context(QDF_MODULE_ID_QDF_DEVICE);
@@ -4737,6 +4780,18 @@ int hdd_wlan_start_modules(struct hdd_context *hdd_ctx, bool reinit)
 			 * in FW use vdev_id = 0.
 			 */
 			hdd_set_fw_log_params(hdd_ctx, 0);
+			ret = hdd_set_pcie_params(hdd_ctx, index, setparam);
+			if (QDF_IS_STATUS_ERROR(ret))
+				break;
+			index++;
+			ret = sme_send_multi_pdev_vdev_set_params(
+					MLME_PDEV_SETPARAM,
+					WMI_PDEV_ID_SOC, setparam, index);
+			if (QDF_IS_STATUS_ERROR(ret)) {
+				hdd_err("failed to send pdev set params");
+				return ret;
+			}
+
 			ret = -EINVAL;
 			break;
 		}
@@ -14425,7 +14480,6 @@ static int hdd_initialize_mac_address(struct hdd_context *hdd_ctx)
 	return ret;
 }
 
-#define MAX_PDEV_PRE_ENABLE_PARAMS 7
 /* params being sent:
  * wmi_pdev_param_tx_chain_mask_1ss
  * wmi_pdev_param_mgmt_retry_limit
@@ -14434,8 +14488,8 @@ static int hdd_initialize_mac_address(struct hdd_context *hdd_ctx)
  * wmi_pdev_param_smart_chainmask_scheme
  * wmi_pdev_param_alternative_chainmask_scheme
  * wmi_pdev_param_ani_enable
+ * wmi_pdev_param_pcie_config
  */
-
 /**
  * hdd_pre_enable_configure() - Configurations prior to cds_enable
  * @hdd_ctx:	HDD context
@@ -14576,6 +14630,11 @@ static int hdd_pre_enable_configure(struct hdd_context *hdd_ctx)
 		}
 	}
 
+	ret = hdd_set_pcie_params(hdd_ctx, index, setparam);
+	if (QDF_IS_STATUS_ERROR(ret))
+		goto out;
+	else
+		index++;
 	ret = sme_send_multi_pdev_vdev_set_params(MLME_PDEV_SETPARAM,
 						  WMI_PDEV_ID_SOC, setparam,
 						  index);
@@ -14583,6 +14642,7 @@ static int hdd_pre_enable_configure(struct hdd_context *hdd_ctx)
 		hdd_err("failed to send pdev set params");
 		goto out;
 	}
+
 	/* Configure global firmware params */
 	ret = ucfg_fwol_configure_global_params(hdd_ctx->psoc, hdd_ctx->pdev);
 	if (ret)