Share freq-to-channel conversion function
Add ieee80211_freq_to_channel_ext() conversion function into ieee802_11_common.c. This function converts freq to channel and additionally computes operating class, based on provided HT and VHT parameters. Signed-off-by: Andrei Otcheretianski <andrei.otcheretianski@intel.com>
This commit is contained in:
		
							parent
							
								
									6fad40df9e
								
							
						
					
					
						commit
						793ea13e2b
					
				
					 3 changed files with 136 additions and 67 deletions
				
			
		|  | @ -568,26 +568,139 @@ int hostapd_config_wmm_ac(struct hostapd_wmm_ac_params wmm_ac_params[], | ||||||
| 
 | 
 | ||||||
| enum hostapd_hw_mode ieee80211_freq_to_chan(int freq, u8 *channel) | enum hostapd_hw_mode ieee80211_freq_to_chan(int freq, u8 *channel) | ||||||
| { | { | ||||||
| 	enum hostapd_hw_mode mode = NUM_HOSTAPD_MODES; | 	u8 op_class; | ||||||
|  | 
 | ||||||
|  | 	return ieee80211_freq_to_channel_ext(freq, 0, 0, &op_class, channel); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * ieee80211_freq_to_channel_ext - Convert frequency into channel info | ||||||
|  |  * for HT40 and VHT. DFS channels are not covered. | ||||||
|  |  * @freq: Frequency (MHz) to convert | ||||||
|  |  * @sec_channel: 0 = non-HT40, 1 = sec. channel above, -1 = sec. channel below | ||||||
|  |  * @vht: 0 - non-VHT, 1 - 80 MHz | ||||||
|  |  * @op_class: Buffer for returning operating class | ||||||
|  |  * @channel: Buffer for returning channel number | ||||||
|  |  * Returns: hw_mode on success, NUM_HOSTAPD_MODES on failure | ||||||
|  |  */ | ||||||
|  | enum hostapd_hw_mode ieee80211_freq_to_channel_ext(unsigned int freq, | ||||||
|  | 						   int sec_channel, int vht, | ||||||
|  | 						   u8 *op_class, u8 *channel) | ||||||
|  | { | ||||||
|  | 	/* TODO: more operating classes */ | ||||||
|  | 
 | ||||||
|  | 	if (sec_channel > 1 || sec_channel < -1) | ||||||
|  | 		return NUM_HOSTAPD_MODES; | ||||||
| 
 | 
 | ||||||
| 	if (freq >= 2412 && freq <= 2472) { | 	if (freq >= 2412 && freq <= 2472) { | ||||||
| 		mode = HOSTAPD_MODE_IEEE80211G; | 		if ((freq - 2407) % 5) | ||||||
|  | 			return NUM_HOSTAPD_MODES; | ||||||
|  | 
 | ||||||
|  | 		if (vht) | ||||||
|  | 			return NUM_HOSTAPD_MODES; | ||||||
|  | 
 | ||||||
|  | 		/* 2.407 GHz, channels 1..13 */ | ||||||
|  | 		if (sec_channel == 1) | ||||||
|  | 			*op_class = 83; | ||||||
|  | 		else if (sec_channel == -1) | ||||||
|  | 			*op_class = 84; | ||||||
|  | 		else | ||||||
|  | 			*op_class = 81; | ||||||
|  | 
 | ||||||
| 		*channel = (freq - 2407) / 5; | 		*channel = (freq - 2407) / 5; | ||||||
| 	} else if (freq == 2484) { | 
 | ||||||
| 		mode = HOSTAPD_MODE_IEEE80211B; | 		return HOSTAPD_MODE_IEEE80211G; | ||||||
| 		*channel = 14; |  | ||||||
| 	} else if (freq >= 4900 && freq < 5000) { |  | ||||||
| 		mode = HOSTAPD_MODE_IEEE80211A; |  | ||||||
| 		*channel = (freq - 4000) / 5; |  | ||||||
| 	} else if (freq >= 5000 && freq < 5900) { |  | ||||||
| 		mode = HOSTAPD_MODE_IEEE80211A; |  | ||||||
| 		*channel = (freq - 5000) / 5; |  | ||||||
| 	} else if (freq >= 56160 + 2160 * 1 && freq <= 56160 + 2160 * 4) { |  | ||||||
| 		mode = HOSTAPD_MODE_IEEE80211AD; |  | ||||||
| 		*channel = (freq - 56160) / 2160; |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return mode; | 	if (freq == 2484) { | ||||||
|  | 		if (sec_channel || vht) | ||||||
|  | 			return NUM_HOSTAPD_MODES; | ||||||
|  | 
 | ||||||
|  | 		*op_class = 82; /* channel 14 */ | ||||||
|  | 		*channel = 14; | ||||||
|  | 
 | ||||||
|  | 		return HOSTAPD_MODE_IEEE80211B; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	if (freq >= 4900 && freq < 5000) { | ||||||
|  | 		if ((freq - 4000) % 5) | ||||||
|  | 			return NUM_HOSTAPD_MODES; | ||||||
|  | 		*channel = (freq - 4000) / 5; | ||||||
|  | 		*op_class = 0; /* TODO */ | ||||||
|  | 		return HOSTAPD_MODE_IEEE80211A; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	/* 5 GHz, channels 36..48 */ | ||||||
|  | 	if (freq >= 5180 && freq <= 5240) { | ||||||
|  | 		if ((freq - 5000) % 5) | ||||||
|  | 			return NUM_HOSTAPD_MODES; | ||||||
|  | 
 | ||||||
|  | 		if (sec_channel == 1) | ||||||
|  | 			*op_class = 116; | ||||||
|  | 		else if (sec_channel == -1) | ||||||
|  | 			*op_class = 117; | ||||||
|  | 		else if (vht) | ||||||
|  | 			*op_class = 128; | ||||||
|  | 		else | ||||||
|  | 			*op_class = 115; | ||||||
|  | 
 | ||||||
|  | 		*channel = (freq - 5000) / 5; | ||||||
|  | 
 | ||||||
|  | 		return HOSTAPD_MODE_IEEE80211A; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	/* 5 GHz, channels 149..161 */ | ||||||
|  | 	if (freq >= 5745 && freq <= 5805) { | ||||||
|  | 		if ((freq - 5000) % 5) | ||||||
|  | 			return NUM_HOSTAPD_MODES; | ||||||
|  | 
 | ||||||
|  | 		if (sec_channel == 1) | ||||||
|  | 			*op_class = 126; | ||||||
|  | 		else if (sec_channel == -1) | ||||||
|  | 			*op_class = 127; | ||||||
|  | 		else if (vht) | ||||||
|  | 			*op_class = 128; | ||||||
|  | 		else | ||||||
|  | 			*op_class = 124; | ||||||
|  | 
 | ||||||
|  | 		*channel = (freq - 5000) / 5; | ||||||
|  | 
 | ||||||
|  | 		return HOSTAPD_MODE_IEEE80211A; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	/* 5 GHz, channels 149..169 */ | ||||||
|  | 	if (freq >= 5745 && freq <= 5845) { | ||||||
|  | 		if ((freq - 5000) % 5) | ||||||
|  | 			return NUM_HOSTAPD_MODES; | ||||||
|  | 
 | ||||||
|  | 		*op_class = 125; | ||||||
|  | 
 | ||||||
|  | 		*channel = (freq - 5000) / 5; | ||||||
|  | 
 | ||||||
|  | 		return HOSTAPD_MODE_IEEE80211A; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	if (freq >= 5000 && freq < 5900) { | ||||||
|  | 		if ((freq - 5000) % 5) | ||||||
|  | 			return NUM_HOSTAPD_MODES; | ||||||
|  | 		*channel = (freq - 5000) / 5; | ||||||
|  | 		*op_class = 0; /* TODO */ | ||||||
|  | 		return HOSTAPD_MODE_IEEE80211A; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	/* 56.16 GHz, channel 1..4 */ | ||||||
|  | 	if (freq >= 56160 + 2160 * 1 && freq <= 56160 + 2160 * 4) { | ||||||
|  | 		if (sec_channel || vht) | ||||||
|  | 			return NUM_HOSTAPD_MODES; | ||||||
|  | 
 | ||||||
|  | 		*channel = (freq - 56160) / 2160; | ||||||
|  | 		*op_class = 180; | ||||||
|  | 
 | ||||||
|  | 		return HOSTAPD_MODE_IEEE80211AD; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return NUM_HOSTAPD_MODES; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -114,6 +114,9 @@ int hostapd_config_wmm_ac(struct hostapd_wmm_ac_params wmm_ac_params[], | ||||||
| 			  const char *name, const char *val); | 			  const char *name, const char *val); | ||||||
| enum hostapd_hw_mode ieee80211_freq_to_chan(int freq, u8 *channel); | enum hostapd_hw_mode ieee80211_freq_to_chan(int freq, u8 *channel); | ||||||
| int ieee80211_chan_to_freq(const char *country, u8 op_class, u8 chan); | int ieee80211_chan_to_freq(const char *country, u8 op_class, u8 chan); | ||||||
|  | enum hostapd_hw_mode ieee80211_freq_to_channel_ext(unsigned int freq, | ||||||
|  | 						   int sec_channel, int vht, | ||||||
|  | 						   u8 *op_class, u8 *channel); | ||||||
| int ieee80211_is_dfs(int freq); | int ieee80211_is_dfs(int freq); | ||||||
| 
 | 
 | ||||||
| int supp_rates_11b_only(struct ieee802_11_elems *elems); | int supp_rates_11b_only(struct ieee802_11_elems *elems); | ||||||
|  |  | ||||||
|  | @ -9,6 +9,7 @@ | ||||||
| #include "includes.h" | #include "includes.h" | ||||||
| 
 | 
 | ||||||
| #include "common.h" | #include "common.h" | ||||||
|  | #include "common/defs.h" | ||||||
| #include "common/ieee802_11_common.h" | #include "common/ieee802_11_common.h" | ||||||
| #include "p2p_i.h" | #include "p2p_i.h" | ||||||
| 
 | 
 | ||||||
|  | @ -67,59 +68,11 @@ int p2p_channel_to_freq(int op_class, int channel) | ||||||
|  */ |  */ | ||||||
| int p2p_freq_to_channel(unsigned int freq, u8 *op_class, u8 *channel) | int p2p_freq_to_channel(unsigned int freq, u8 *op_class, u8 *channel) | ||||||
| { | { | ||||||
| 	/* TODO: more operating classes */ | 	if (ieee80211_freq_to_channel_ext(freq, 0, 0, op_class, channel) == | ||||||
| 	if (freq >= 2412 && freq <= 2472) { | 	    NUM_HOSTAPD_MODES) | ||||||
| 		if ((freq - 2407) % 5) |  | ||||||
| 		return -1; | 		return -1; | ||||||
| 
 | 
 | ||||||
| 		*op_class = 81; /* 2.407 GHz, channels 1..13 */ |  | ||||||
| 		*channel = (freq - 2407) / 5; |  | ||||||
| 	return 0; | 	return 0; | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if (freq == 2484) { |  | ||||||
| 		*op_class = 82; /* channel 14 */ |  | ||||||
| 		*channel = 14; |  | ||||||
| 		return 0; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if (freq >= 5180 && freq <= 5240) { |  | ||||||
| 		if ((freq - 5000) % 5) |  | ||||||
| 			return -1; |  | ||||||
| 
 |  | ||||||
| 		*op_class = 115; /* 5 GHz, channels 36..48 */ |  | ||||||
| 		*channel = (freq - 5000) / 5; |  | ||||||
| 		return 0; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if (freq >= 5745 && freq <= 5805) { |  | ||||||
| 		if ((freq - 5000) % 5) |  | ||||||
| 			return -1; |  | ||||||
| 
 |  | ||||||
| 		*op_class = 124; /* 5 GHz, channels 149..161 */ |  | ||||||
| 		*channel = (freq - 5000) / 5; |  | ||||||
| 		return 0; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if (freq >= 5745 && freq <= 5845) { |  | ||||||
| 		if ((freq - 5000) % 5) |  | ||||||
| 			return -1; |  | ||||||
| 
 |  | ||||||
| 		*op_class = 125; /* 5 GHz, channels 149..169 */ |  | ||||||
| 		*channel = (freq - 5000) / 5; |  | ||||||
| 		return 0; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if (freq >= 58320 && freq <= 64800) { |  | ||||||
| 		if ((freq - 58320) % 2160) |  | ||||||
| 			return -1; |  | ||||||
| 
 |  | ||||||
| 		*op_class = 180; /* 60 GHz, channels 1..4 */ |  | ||||||
| 		*channel = (freq - 56160) / 2160; |  | ||||||
| 		return 0; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return -1; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Andrei Otcheretianski
						Andrei Otcheretianski