Ver Fonte

qcacld-3.0: Fix logic for filling DBS/SBS freq range

Fix logic for filling DBS/SBS freq range at the time
of init from mac phy capabilities.

Change-Id: I6e6bc2ea5fa2dd349337d663c813ff473ce787a4
CRs-Fixed: 3049819
Utkarsh Bhatnagar há 3 anos atrás
pai
commit
29ebd12842

+ 121 - 190
components/cmn_services/policy_mgr/src/wlan_policy_mgr_get_set_utils.c

@@ -668,221 +668,153 @@ static void policy_mgr_set_hw_mode_params(struct wlan_objmgr_psoc *psoc,
 }
 
 static void
-policy_mgr_dbs_update_mac0(struct policy_mgr_freq_range *mac_freq,
-			   struct wlan_psoc_host_mac_phy_caps *mac_cap)
+policy_mgr_update_24Ghz_freq_info(struct policy_mgr_freq_range *mac_range,
+				  struct wlan_psoc_host_mac_phy_caps *mac_cap)
 {
-	/*
-	 * Fill 2.4 ghz freq only for MAC Phy 0
-	 */
-	mac_freq->low_2ghz_freq = QDF_MAX(mac_cap->reg_cap_ext.low_2ghz_chan,
-					  wlan_reg_min_24ghz_chan_freq());
-	mac_freq->high_2ghz_freq = mac_cap->reg_cap_ext.high_2ghz_chan ?
-				   QDF_MIN(mac_cap->reg_cap_ext.high_2ghz_chan,
-					   wlan_reg_max_24ghz_chan_freq()) :
-				   wlan_reg_max_24ghz_chan_freq();
-
-	/*
-	 * Filling high 5 ghz low and high here as they will be later used while
-	 * processing mac 1 frequency range. If mac 0, 5ghz frequency range is
-	 * present then it is intersected with mac 1 ranges and maximum of both
-	 * is considered as viable range.
-	 */
-	mac_freq->low_5ghz_freq = mac_cap->reg_cap_ext.low_5ghz_chan;
-	mac_freq->high_5ghz_freq = mac_cap->reg_cap_ext.high_5ghz_chan;
+	mac_range->low_2ghz_freq = QDF_MAX(mac_cap->reg_cap_ext.low_2ghz_chan,
+					   wlan_reg_min_24ghz_chan_freq());
+	mac_range->high_2ghz_freq = mac_cap->reg_cap_ext.high_2ghz_chan ?
+				    QDF_MIN(mac_cap->reg_cap_ext.high_2ghz_chan,
+					    wlan_reg_max_24ghz_chan_freq()) :
+				    wlan_reg_max_24ghz_chan_freq();
 }
 
 static void
-policy_mgr_dbs_update_mac1(struct policy_mgr_psoc_priv_obj *pm_ctx,
-			   struct policy_mgr_freq_range *mac_freq,
-			   struct wlan_psoc_host_mac_phy_caps *mac_cap)
+policy_mgr_update_5Ghz_freq_info(struct policy_mgr_freq_range *mac_range,
+				  struct wlan_psoc_host_mac_phy_caps *mac_cap)
 {
 	qdf_freq_t max_5g_freq;
-	struct policy_mgr_freq_range *mac0_freq;
 
 	max_5g_freq = wlan_reg_max_6ghz_chan_freq() ?
-		      wlan_reg_max_6ghz_chan_freq() :
-		      wlan_reg_max_5ghz_chan_freq();
-
-	/*
-	 * For MAC 1, fill the maximum and minimum possible value for 5ghz even
-	 * if the frequency are zeroes, as for DBS, 5 ghz channel should be
-	 * enabled.
-	 */
-	mac_freq->low_5ghz_freq = QDF_MAX(mac_cap->reg_cap_ext.low_5ghz_chan,
-				     wlan_reg_min_5ghz_chan_freq());
-	mac_freq->high_5ghz_freq = mac_cap->reg_cap_ext.high_5ghz_chan ?
-				   QDF_MIN(mac_cap->reg_cap_ext.high_5ghz_chan,
-					   max_5g_freq) :
-				   max_5g_freq;
+			wlan_reg_max_6ghz_chan_freq() :
+			wlan_reg_max_5ghz_chan_freq();
 
-	mac0_freq = &pm_ctx->hw_mode.freq_range_caps[MODE_DBS][0];
-
-	if (mac0_freq->low_5ghz_freq) {
-		if (mac0_freq->low_5ghz_freq < mac_freq->low_5ghz_freq)
-			mac_freq->low_5ghz_freq = mac0_freq->low_5ghz_freq;
-		mac0_freq->low_5ghz_freq = 0;
-	}
+	mac_range->low_5ghz_freq = QDF_MAX(mac_cap->reg_cap_ext.low_5ghz_chan,
+					   wlan_reg_min_5ghz_chan_freq());
+	mac_range->high_5ghz_freq = mac_cap->reg_cap_ext.high_5ghz_chan ?
+				    QDF_MIN(mac_cap->reg_cap_ext.high_5ghz_chan,
+					    max_5g_freq) :
+				    max_5g_freq;
 
-	if (mac0_freq->high_5ghz_freq) {
-		if (mac0_freq->high_5ghz_freq > mac_freq->high_5ghz_freq)
-			mac_freq->high_5ghz_freq = mac0_freq->high_5ghz_freq;
-		mac0_freq->high_5ghz_freq = 0;
-	}
 }
 
-
 static void
-policy_mgr_update_dbs_freq_info(struct policy_mgr_psoc_priv_obj *pm_ctx,
-				struct wlan_psoc_host_mac_phy_caps *mac_cap,
-				uint32_t phy_id)
+policy_mgr_update_freq_info(struct policy_mgr_psoc_priv_obj *pm_ctx,
+			    struct wlan_psoc_host_mac_phy_caps *mac_cap,
+			    enum policy_mgr_mode mode,
+			    uint32_t phy_id)
 {
-	struct policy_mgr_freq_range *mac;
+	struct policy_mgr_freq_range *mac_range;
 
-	mac = &pm_ctx->hw_mode.freq_range_caps[MODE_DBS][phy_id];
+	mac_range = &pm_ctx->hw_mode.freq_range_caps[mode][phy_id];
+	if (mac_cap->supported_bands & WMI_HOST_WLAN_2G_CAPABILITY)
+		policy_mgr_update_24Ghz_freq_info(mac_range, mac_cap);
 
-	/* mac can either be 0 or 1 */
-	if (phy_id)
-		policy_mgr_dbs_update_mac1(pm_ctx, mac, mac_cap);
-	else
-		policy_mgr_dbs_update_mac0(mac, mac_cap);
+	if (mac_cap->supported_bands & WMI_HOST_WLAN_5G_CAPABILITY)
+		policy_mgr_update_5Ghz_freq_info(mac_range, mac_cap);
 }
 
 static void
-policy_mgr_fill_sbs_2ghz_freq(uint32_t phy_id,
-			      struct policy_mgr_freq_range *mac,
-			      struct wlan_psoc_host_mac_phy_caps *mac_phy_cap)
+policy_mgr_fill_sbs_freq_from_dbs(struct policy_mgr_psoc_priv_obj *pm_ctx,
+				  uint8_t phy_id)
 {
+	uint8_t shared_phy_id;
+	struct policy_mgr_freq_range *sbs_mac_range, *shared_mac_range;
+	struct policy_mgr_freq_range *non_shared_range;
+
+	sbs_mac_range = &pm_ctx->hw_mode.freq_range_caps[MODE_SBS][phy_id];
+
 	/*
-	 * Fill 2.4 ghz freq only for MAC Phy 0
+	 * if SBS mac range has both 2.4 and 5 Ghz range, i e shared phy_id
+	 * keep the range as it is in SBS
 	 */
-	if (!phy_id) {
-		mac->low_2ghz_freq =
-				QDF_MAX(mac_phy_cap->reg_cap_ext.low_2ghz_chan,
-					wlan_reg_min_24ghz_chan_freq());
-		mac->high_2ghz_freq =
-				mac_phy_cap->reg_cap_ext.high_2ghz_chan ?
-				QDF_MIN(mac_phy_cap->reg_cap_ext.high_2ghz_chan,
-					wlan_reg_max_24ghz_chan_freq()) :
-				wlan_reg_max_24ghz_chan_freq();
+	if (sbs_mac_range->low_2ghz_freq && sbs_mac_range->low_5ghz_freq)
+		return;
+	if (sbs_mac_range->low_2ghz_freq && !sbs_mac_range->low_5ghz_freq) {
+		policy_mgr_err("Invalid DBS/SBS mode with only 2.4Ghz");
+		policy_mgr_dump_freq_range_per_mac(sbs_mac_range, MODE_SBS);
+		return;
 	}
 
-}
-
-static void
-policy_mgr_fill_sbs_5ghz_freq(uint32_t phy_id,
-			      struct policy_mgr_freq_range *mac,
-			      struct wlan_psoc_host_mac_phy_caps *mac_cap,
-			      struct policy_mgr_psoc_priv_obj *pm_ctx)
-{
-	qdf_freq_t max_5g_freq;
-	struct policy_mgr_freq_range *mac0 = NULL;
-
-	max_5g_freq = wlan_reg_max_6ghz_chan_freq() ?
-		      wlan_reg_max_6ghz_chan_freq() :
-		      wlan_reg_max_5ghz_chan_freq();
-
+	non_shared_range = sbs_mac_range;
 	/*
-	 * If both low and high 5 ghz freq are zero, then disable that range by
-	 * filling zero for that particular mac. If one of the frequencies is
-	 * zero, then take the maximum possible range for that case.
-	 *
-	 * For 5 Ghz and 6 Ghz Frequency, If the mac0 lower 5ghz frequency is
-	 * greater than mac1 lower 5 ghz frequency then the mac0 has high share
-	 * of 5g range and it should be made sure that mac1 5g high is less than
-	 * mac 0 5g low.
-	 * If the mac0 lower 5ghz frequency is less than mac1 lower 5 ghz
-	 * frequency then the mac0 has low share of 5g range and it should be
-	 * made sure that mac1 5g low is greater than mac0 5g high.
+	 * if SBS mac range has only 5Ghz then its the non shared phy, so
+	 * modify the range as per the shared mac.
 	 */
-	if (mac_cap->reg_cap_ext.low_5ghz_chan ||
-	    mac_cap->reg_cap_ext.high_5ghz_chan) {
-		mac->low_5ghz_freq = QDF_MAX(mac_cap->reg_cap_ext.low_5ghz_chan,
-				     wlan_reg_min_5ghz_chan_freq());
-		mac->high_5ghz_freq = mac_cap->reg_cap_ext.high_5ghz_chan ?
-				    QDF_MIN(mac_cap->reg_cap_ext.high_5ghz_chan,
-					    max_5g_freq) :
-				    max_5g_freq;
+	shared_phy_id = phy_id ? 0 : 1;
+	shared_mac_range =
+		&pm_ctx->hw_mode.freq_range_caps[MODE_SBS][shared_phy_id];
 
-		if (phy_id) {
-			mac0 = &pm_ctx->hw_mode.freq_range_caps[MODE_SBS][0];
-
-			if (mac0->low_5ghz_freq > mac->low_5ghz_freq) {
-				if (mac->high_5ghz_freq >=
-				    mac0->low_5ghz_freq) {
-					mac->high_5ghz_freq =
-							mac0->low_5ghz_freq -
-							20;
-				}
-			} else {
-			/*
-			 * If Mac0 high_5ghz_freq is equal to max_5g_freq, this
-			 * means Mac0 supports all 5 Ghz channel, So, disable
-			 * the 5ghz channels for Mac1.
-			 */
-				if (mac0->high_5ghz_freq == max_5g_freq) {
-					mac->low_5ghz_freq = 0;
-					mac->high_5ghz_freq = 0;
-				} else if (mac0->high_5ghz_freq >=
-					   mac->low_5ghz_freq) {
-					mac->low_5ghz_freq =
-							mac0->high_5ghz_freq +
-							20;
-				}
-			}
-		}
+	if (shared_mac_range->low_5ghz_freq > non_shared_range->low_5ghz_freq) {
+		policy_mgr_debug("High 5Ghz shared");
+		/*
+		 * If the shared mac lower 5Ghz frequency is greater than
+		 * non-shared mac lower 5Ghz frequency then the shared mac has
+		 * HIGH 5Ghz shared with 2.4Ghz. So non-shared mac's 5Ghz high
+		 * freq should be less than the shared mac's low 5Ghz freq.
+		 */
+		if (non_shared_range->high_5ghz_freq >=
+		    shared_mac_range->low_5ghz_freq)
+			non_shared_range->high_5ghz_freq =
+				QDF_MAX(shared_mac_range->low_5ghz_freq - 10,
+					non_shared_range->low_5ghz_freq);
+	} else if (shared_mac_range->low_5ghz_freq <
+		   non_shared_range->low_5ghz_freq) {
+		policy_mgr_debug("LOW 5Ghz shared");
+		/*
+		 * If the shared mac lower 5Ghz frequency is less/equal than
+		 * non-shared mac lower 5Ghz frequency then the shared mac has
+		 * LOW 5Ghz shared with 2.4Ghz So non-shared mac's 5Ghz low
+		 * freq should be greater than the shared mac's high 5Ghz freq.
+		 */
+		if (shared_mac_range->high_5ghz_freq >=
+		    non_shared_range->low_5ghz_freq)
+			non_shared_range->low_5ghz_freq =
+				QDF_MIN(shared_mac_range->high_5ghz_freq + 10,
+					non_shared_range->high_5ghz_freq);
+	} else {
+		policy_mgr_debug("All 5Ghz shared, Do nothing");
 	}
 }
 
 static void
-policy_mgr_update_sbs_freq_info(struct policy_mgr_psoc_priv_obj *pm_ctx,
-				struct wlan_psoc_host_mac_phy_caps *mac_cap,
-				uint32_t phy_id)
+policy_mgr_update_dbs_sbs_freq_info(struct policy_mgr_psoc_priv_obj *pm_ctx)
 {
-	struct policy_mgr_freq_range *mac;
-
-	mac = &pm_ctx->hw_mode.freq_range_caps[MODE_SBS][phy_id];
-
-	policy_mgr_fill_sbs_5ghz_freq(phy_id, mac, mac_cap, pm_ctx);
-	policy_mgr_fill_sbs_2ghz_freq(phy_id, mac, mac_cap);
+	struct policy_mgr_freq_range *mac_range;
+	uint8_t phy_id;
+
+	/* Reset 5Ghz range for shared mac for DBS */
+	for (phy_id = 0; phy_id < MAX_MAC; phy_id++) {
+		mac_range =
+			&pm_ctx->hw_mode.freq_range_caps[MODE_DBS][phy_id];
+		if (mac_range->low_2ghz_freq &&
+		    mac_range->low_5ghz_freq) {
+			mac_range->low_5ghz_freq = 0;
+			mac_range->high_5ghz_freq = 0;
+		}
+	}
+	/* Fix SBS MAC range */
+	for (phy_id = 0; phy_id < MAX_MAC; phy_id++)
+		policy_mgr_fill_sbs_freq_from_dbs(pm_ctx, phy_id);
 }
 
-static void
-policy_mgr_update_smm_freq_info(struct policy_mgr_psoc_priv_obj *pm_ctx,
-				struct wlan_psoc_host_mac_phy_caps *mac_cap,
-				uint32_t phy_id)
+static bool
+policy_mgr_both_dbs_phy_range_updated(struct policy_mgr_psoc_priv_obj *pm_ctx)
 {
-	struct policy_mgr_freq_range *mac_range;
-	qdf_freq_t max_5g_freq;
-
-	mac_range = &pm_ctx->hw_mode.freq_range_caps[MODE_SMM][phy_id];
+	struct policy_mgr_freq_range *dbs_mac_range;
+	uint8_t phy_id;
 
-	policy_mgr_debug("Supported Bands %x", mac_cap->supported_bands);
-	if (mac_cap->supported_bands & WMI_HOST_WLAN_2G_CAPABILITY) {
-		mac_range->low_2ghz_freq =
-				QDF_MAX(mac_cap->reg_cap_ext.low_2ghz_chan,
-					wlan_reg_min_24ghz_chan_freq());
-		mac_range->high_2ghz_freq =
-				mac_cap->reg_cap_ext.high_2ghz_chan ?
-				QDF_MIN(mac_cap->reg_cap_ext.high_2ghz_chan,
-					wlan_reg_max_24ghz_chan_freq()) :
-				wlan_reg_max_24ghz_chan_freq();
+	for (phy_id = 0; phy_id < MAX_MAC; phy_id++) {
+		dbs_mac_range =
+			&pm_ctx->hw_mode.freq_range_caps[MODE_DBS][phy_id];
+		/* modify SBS/DBS range only when both phy for DBS are filled */
+		if (!dbs_mac_range->low_2ghz_freq &&
+		    !dbs_mac_range->low_5ghz_freq)
+			return false;
 	}
 
-	if (mac_cap->supported_bands & WMI_HOST_WLAN_5G_CAPABILITY) {
-		max_5g_freq = wlan_reg_max_6ghz_chan_freq() ?
-			      wlan_reg_max_6ghz_chan_freq() :
-			      wlan_reg_max_5ghz_chan_freq();
-		mac_range->low_5ghz_freq =
-				QDF_MAX(mac_cap->reg_cap_ext.low_5ghz_chan,
-					wlan_reg_min_5ghz_chan_freq());
-		mac_range->high_5ghz_freq =
-				mac_cap->reg_cap_ext.high_5ghz_chan ?
-				QDF_MIN(mac_cap->reg_cap_ext.high_5ghz_chan,
-					max_5g_freq) :
-				max_5g_freq;
-	}
+	return true;
 }
-
 static void
 policy_mgr_update_mac_freq_info(struct wlan_objmgr_psoc *psoc,
 				struct policy_mgr_psoc_priv_obj *pm_ctx,
@@ -896,8 +828,8 @@ policy_mgr_update_mac_freq_info(struct wlan_objmgr_psoc *psoc,
 		return;
 	}
 
-	policy_mgr_debug("Hw_Mode: %d Phy_id: %d low_2g %d high_2g %d low_5g %d high_5g %d",
-			 hw_config_type, phy_id,
+	policy_mgr_debug("Hw_Mode: %d Phy_id: %d band: %x low_2g %d high_2g %d low_5g %d high_5g %d",
+			 hw_config_type, phy_id, mac_cap->supported_bands,
 			 mac_cap->reg_cap_ext.low_2ghz_chan,
 			 mac_cap->reg_cap_ext.high_2ghz_chan,
 			 mac_cap->reg_cap_ext.low_5ghz_chan,
@@ -909,31 +841,30 @@ policy_mgr_update_mac_freq_info(struct wlan_objmgr_psoc *psoc,
 			policy_mgr_debug("MAC Phy 1 is not supported");
 			break;
 		}
-		policy_mgr_update_smm_freq_info(pm_ctx, mac_cap,
-						phy_id);
+		policy_mgr_update_freq_info(pm_ctx, mac_cap, MODE_SMM, phy_id);
 		break;
 
 	case WMI_HW_MODE_DBS:
 	case WMI_HW_MODE_DBS_2G_5G:
-		policy_mgr_update_dbs_freq_info(pm_ctx, mac_cap,
-						phy_id);
+		policy_mgr_update_freq_info(pm_ctx, mac_cap, MODE_DBS, phy_id);
 		break;
 	case WMI_HW_MODE_DBS_SBS:
 	case WMI_HW_MODE_DBS_OR_SBS:
-		policy_mgr_update_sbs_freq_info(pm_ctx, mac_cap,
-						phy_id);
-		policy_mgr_update_dbs_freq_info(pm_ctx, mac_cap,
-						phy_id);
+		policy_mgr_update_freq_info(pm_ctx, mac_cap, MODE_DBS, phy_id);
+		policy_mgr_update_freq_info(pm_ctx, mac_cap, MODE_SBS, phy_id);
+
+		/* Modify the SBS/DBS list once both phy info are filled */
+		if (policy_mgr_both_dbs_phy_range_updated(pm_ctx))
+			policy_mgr_update_dbs_sbs_freq_info(pm_ctx);
 		break;
 	case WMI_HW_MODE_2G_PHYB:
 		if (phy_id)
-			policy_mgr_update_smm_freq_info(pm_ctx, mac_cap,
-							phy_id);
+			policy_mgr_update_freq_info(pm_ctx, mac_cap, MODE_SMM,
+						    phy_id);
 		break;
 	case WMI_HW_MODE_SBS:
 	case WMI_HW_MODE_SBS_PASSIVE:
-		policy_mgr_update_sbs_freq_info(pm_ctx, mac_cap,
-						phy_id);
+		policy_mgr_update_freq_info(pm_ctx, mac_cap, MODE_SBS, phy_id);
 		break;
 	default:
 		policy_mgr_err("HW mode not defined %d",