Prechádzať zdrojové kódy

qcacld-3.0: Replace channel with frequency for 6G

Replace wlan_reg_is_24ghz_ch with wlan_reg_is_24ghz_ch_freq.
Replace channel with frequency in cds_get_vendor_reg_flags.

Change-Id: I72ffc5550e45be1edf460f9619fead8889cf2967
CRs-Fixed: 2714723
Jianmin Zhu 4 rokov pred
rodič
commit
faf92193d4

+ 4 - 3
core/cds/inc/cds_reg_service.h

@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2014-2017, 2019 The Linux Foundation. All rights reserved.
+ * Copyright (c) 2014-2017, 2019-2020 The Linux Foundation. All rights reserved.
  *
  * Permission to use, copy, modify, and/or distribute this software for
  * any purpose with or without fee is hereby granted, provided that the
@@ -42,14 +42,15 @@
  * cds_get_vendor_reg_flags() - This API returns vendor specific regulatory
  * channel flags
  * @pdev: pdev pointer
- * @chan: channel number
+ * @freq: channel frequency
  * @bandwidth: channel BW
  * @is_ht_enabled: HT enabled/disabled flag
  * @is_vht_enabled: VHT enabled/disabled flag
  * @sub_20_channel_width: Sub 20 channel bandwidth
  * Return: channel flags
  */
-uint32_t cds_get_vendor_reg_flags(struct wlan_objmgr_pdev *pdev, uint32_t chan,
+uint32_t cds_get_vendor_reg_flags(struct wlan_objmgr_pdev *pdev,
+				  qdf_freq_t freq,
 				  uint16_t bandwidth,
 				  bool is_ht_enabled, bool is_vht_enabled,
 				  uint8_t sub_20_channel_width);

+ 33 - 26
core/cds/src/cds_reg_service.c

@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2014-2019 The Linux Foundation. All rights reserved.
+ * Copyright (c) 2014-2020 The Linux Foundation. All rights reserved.
  *
  * Permission to use, copy, modify, and/or distribute this software for
  * any purpose with or without fee is hereby granted, provided that the
@@ -30,18 +30,19 @@
 #include "cds_ieee80211_common_i.h"
 #include "cds_config.h"
 #include "cds_utils.h"
+#include "wlan_reg_services_api.h"
 
 uint32_t cds_get_vendor_reg_flags(struct wlan_objmgr_pdev *pdev,
-		uint32_t chan, uint16_t bandwidth,
+		qdf_freq_t freq, uint16_t bandwidth,
 		bool is_ht_enabled, bool is_vht_enabled,
 		uint8_t sub_20_channel_width)
 {
 	uint32_t flags = 0;
 	enum channel_state state;
 	struct ch_params ch_params;
-	int sec_channel;
+	qdf_freq_t sec_freq;
 
-	state = wlan_reg_get_channel_state(pdev, chan);
+	state = wlan_reg_get_channel_state_for_freq(pdev, freq);
 	if (state == CHANNEL_STATE_INVALID)
 		return flags;
 	if (state == CHANNEL_STATE_DFS) {
@@ -50,7 +51,7 @@ uint32_t cds_get_vendor_reg_flags(struct wlan_objmgr_pdev *pdev,
 	if (state == CHANNEL_STATE_DISABLE)
 		flags |= IEEE80211_CHAN_BLOCKED;
 
-	if (WLAN_REG_IS_24GHZ_CH(chan)) {
+	if (wlan_reg_is_24ghz_ch_freq(freq)) {
 		if ((bandwidth == CH_WIDTH_80P80MHZ) ||
 		    (bandwidth == CH_WIDTH_160MHZ) ||
 		    (bandwidth == CH_WIDTH_80MHZ)) {
@@ -62,24 +63,27 @@ uint32_t cds_get_vendor_reg_flags(struct wlan_objmgr_pdev *pdev,
 
 	switch (bandwidth) {
 	case CH_WIDTH_80P80MHZ:
-		if (wlan_reg_get_5g_bonded_channel_state(pdev, chan,
-					bandwidth) != CHANNEL_STATE_INVALID) {
+		if (wlan_reg_get_5g_bonded_channel_state_for_freq(pdev, freq,
+								  bandwidth) !=
+		    CHANNEL_STATE_INVALID) {
 			if (is_vht_enabled)
 				flags |= IEEE80211_CHAN_VHT80_80;
 		}
 		bandwidth = CH_WIDTH_160MHZ;
 	/* FALLTHROUGH */
 	case CH_WIDTH_160MHZ:
-		if (wlan_reg_get_5g_bonded_channel_state(pdev, chan,
-					bandwidth) != CHANNEL_STATE_INVALID) {
+		if (wlan_reg_get_5g_bonded_channel_state_for_freq(pdev, freq,
+								  bandwidth) !=
+		    CHANNEL_STATE_INVALID) {
 			if (is_vht_enabled)
 				flags |= IEEE80211_CHAN_VHT160;
 		}
 		bandwidth = CH_WIDTH_80MHZ;
 	/* FALLTHROUGH */
 	case CH_WIDTH_80MHZ:
-		if (wlan_reg_get_5g_bonded_channel_state(pdev, chan,
-					bandwidth) != CHANNEL_STATE_INVALID) {
+		if (wlan_reg_get_5g_bonded_channel_state_for_freq(pdev, freq,
+								  bandwidth) !=
+		    CHANNEL_STATE_INVALID) {
 			if (is_vht_enabled)
 				flags |= IEEE80211_CHAN_VHT80;
 		}
@@ -88,18 +92,19 @@ uint32_t cds_get_vendor_reg_flags(struct wlan_objmgr_pdev *pdev,
 	case CH_WIDTH_40MHZ:
 		qdf_mem_zero(&ch_params, sizeof(ch_params));
 		ch_params.ch_width = bandwidth;
-		wlan_reg_set_channel_params(pdev, chan, 0, &ch_params);
+		wlan_reg_set_channel_params_for_freq(pdev, freq, 0, &ch_params);
 
 		if (ch_params.sec_ch_offset == LOW_PRIMARY_CH)
-			sec_channel = chan + 4;
+			sec_freq = freq + 20;
 		else if (ch_params.sec_ch_offset == HIGH_PRIMARY_CH)
-			sec_channel = chan - 4;
+			sec_freq = freq - 20;
 		else
-			sec_channel = 0;
+			sec_freq = 0;
 
-		if (wlan_reg_get_bonded_channel_state(pdev, chan, bandwidth,
-					sec_channel) !=
-				CHANNEL_STATE_INVALID) {
+		if (wlan_reg_get_bonded_channel_state_for_freq(pdev, freq,
+							       bandwidth,
+							       sec_freq) !=
+		    CHANNEL_STATE_INVALID) {
 			if (ch_params.sec_ch_offset == LOW_PRIMARY_CH) {
 				flags |= IEEE80211_CHAN_HT40PLUS;
 				if (is_vht_enabled)
@@ -121,18 +126,20 @@ uint32_t cds_get_vendor_reg_flags(struct wlan_objmgr_pdev *pdev,
 		bandwidth = CH_WIDTH_10MHZ;
 	/* FALLTHROUGH */
 	case CH_WIDTH_10MHZ:
-		if ((wlan_reg_get_bonded_channel_state(pdev, chan, bandwidth,
-						0) != CHANNEL_STATE_INVALID) &&
-				(sub_20_channel_width ==
-				 WLAN_SUB_20_CH_WIDTH_10))
+		if (wlan_reg_get_bonded_channel_state_for_freq(pdev, freq,
+							       bandwidth,
+							       0) !=
+		     CHANNEL_STATE_INVALID &&
+		     sub_20_channel_width == WLAN_SUB_20_CH_WIDTH_10)
 			flags |= IEEE80211_CHAN_HALF;
 		bandwidth = CH_WIDTH_5MHZ;
 	/* FALLTHROUGH */
 	case CH_WIDTH_5MHZ:
-		if ((wlan_reg_get_bonded_channel_state(pdev, chan, bandwidth,
-						0) != CHANNEL_STATE_INVALID) &&
-				(sub_20_channel_width ==
-				 WLAN_SUB_20_CH_WIDTH_5))
+		if (wlan_reg_get_bonded_channel_state_for_freq(pdev, freq,
+							       bandwidth,
+							       0) !=
+		    CHANNEL_STATE_INVALID &&
+		    sub_20_channel_width == WLAN_SUB_20_CH_WIDTH_5)
 			flags |= IEEE80211_CHAN_QUARTER;
 		break;
 	default:

+ 1 - 1
core/hdd/src/wlan_hdd_cfg80211.c

@@ -2170,7 +2170,7 @@ hdd_update_reg_chan_info(struct hdd_adapter *adapter,
 
 		icv->flags = 0;
 		icv->flags = cds_get_vendor_reg_flags(hdd_ctx->pdev,
-				icv->ieee_chan_number,
+				icv->freq,
 				sap_config->acs_cfg.ch_width,
 				sap_config->acs_cfg.is_ht_enabled,
 				sap_config->acs_cfg.is_vht_enabled,