diff --git a/src/ap/hw_features.c b/src/ap/hw_features.c index d629bbece..cc0c19d67 100644 --- a/src/ap/hw_features.c +++ b/src/ap/hw_features.c @@ -277,30 +277,7 @@ static int ieee80211n_check_40mhz_5g(struct hostapd_iface *iface, static int ieee80211n_check_20mhz_bss(struct wpa_scan_res *bss, int pri_freq, int start, int end) { - struct ieee802_11_elems elems; - struct ieee80211_ht_operation *oper; - - if (bss->freq < start || bss->freq > end || bss->freq == pri_freq) - return 0; - - ieee802_11_parse_elems((u8 *) (bss + 1), bss->ie_len, &elems, 0); - if (!elems.ht_capabilities) { - wpa_printf(MSG_DEBUG, "Found overlapping legacy BSS: " - MACSTR " freq=%d", MAC2STR(bss->bssid), bss->freq); - return 1; - } - - if (elems.ht_operation && - elems.ht_operation_len >= sizeof(*oper)) { - oper = (struct ieee80211_ht_operation *) elems.ht_operation; - if (oper->ht_param & HT_INFO_HT_PARAM_SECONDARY_CHNL_OFF_MASK) - return 0; - - wpa_printf(MSG_DEBUG, "Found overlapping 20 MHz HT BSS: " - MACSTR " freq=%d", MAC2STR(bss->bssid), bss->freq); - return 1; - } - return 0; + return check_20mhz_bss(bss, pri_freq, start, end); } diff --git a/src/common/hw_features_common.c b/src/common/hw_features_common.c index bb6e5db29..ce729ff2e 100644 --- a/src/common/hw_features_common.c +++ b/src/common/hw_features_common.c @@ -236,3 +236,32 @@ int check_40mhz_5g(struct hostapd_hw_modes *mode, return 1; } + + +int check_20mhz_bss(struct wpa_scan_res *bss, int pri_freq, int start, int end) +{ + struct ieee802_11_elems elems; + struct ieee80211_ht_operation *oper; + + if (bss->freq < start || bss->freq > end || bss->freq == pri_freq) + return 0; + + ieee802_11_parse_elems((u8 *) (bss + 1), bss->ie_len, &elems, 0); + if (!elems.ht_capabilities) { + wpa_printf(MSG_DEBUG, "Found overlapping legacy BSS: " + MACSTR " freq=%d", MAC2STR(bss->bssid), bss->freq); + return 1; + } + + if (elems.ht_operation && + elems.ht_operation_len >= sizeof(*oper)) { + oper = (struct ieee80211_ht_operation *) elems.ht_operation; + if (oper->ht_param & HT_INFO_HT_PARAM_SECONDARY_CHNL_OFF_MASK) + return 0; + + wpa_printf(MSG_DEBUG, "Found overlapping 20 MHz HT BSS: " + MACSTR " freq=%d", MAC2STR(bss->bssid), bss->freq); + return 1; + } + return 0; +} diff --git a/src/common/hw_features_common.h b/src/common/hw_features_common.h index ed01d0ae2..8a03d7497 100644 --- a/src/common/hw_features_common.h +++ b/src/common/hw_features_common.h @@ -26,5 +26,6 @@ void get_pri_sec_chan(struct wpa_scan_res *bss, int *pri_chan, int *sec_chan); int check_40mhz_5g(struct hostapd_hw_modes *mode, struct wpa_scan_results *scan_res, int pri_chan, int sec_chan); +int check_20mhz_bss(struct wpa_scan_res *bss, int pri_freq, int start, int end); #endif /* HW_FEATURES_COMMON_H */