AP: Determine Short SSID value for the BSS
This can be used in the future to implement support for RNR and scanning extensions using a shorter field for the SSID. Signed-off-by: Andrei Otcheretianski <andrei.otcheretianski@intel.com>
This commit is contained in:
parent
41b06b065e
commit
522450b7b1
6 changed files with 12 additions and 0 deletions
|
@ -145,6 +145,7 @@ OBJS += src/utils/wpa_debug.c
|
||||||
OBJS += src/utils/wpabuf.c
|
OBJS += src/utils/wpabuf.c
|
||||||
OBJS += src/utils/os_$(CONFIG_OS).c
|
OBJS += src/utils/os_$(CONFIG_OS).c
|
||||||
OBJS += src/utils/ip_addr.c
|
OBJS += src/utils/ip_addr.c
|
||||||
|
OBJS += src/utils/crc32.c
|
||||||
|
|
||||||
OBJS += src/common/ieee802_11_common.c
|
OBJS += src/common/ieee802_11_common.c
|
||||||
OBJS += src/common/wpa_common.c
|
OBJS += src/common/wpa_common.c
|
||||||
|
|
|
@ -158,6 +158,7 @@ OBJS_c += ../src/utils/wpa_debug.o
|
||||||
OBJS += ../src/utils/wpabuf.o
|
OBJS += ../src/utils/wpabuf.o
|
||||||
OBJS += ../src/utils/os_$(CONFIG_OS).o
|
OBJS += ../src/utils/os_$(CONFIG_OS).o
|
||||||
OBJS += ../src/utils/ip_addr.o
|
OBJS += ../src/utils/ip_addr.o
|
||||||
|
OBJS += ../src/utils/crc32.o
|
||||||
|
|
||||||
OBJS += ../src/common/ieee802_11_common.o
|
OBJS += ../src/common/ieee802_11_common.o
|
||||||
OBJS += ../src/common/wpa_common.o
|
OBJS += ../src/common/wpa_common.o
|
||||||
|
|
|
@ -88,6 +88,7 @@ typedef enum hostap_security_policy {
|
||||||
struct hostapd_ssid {
|
struct hostapd_ssid {
|
||||||
u8 ssid[SSID_MAX_LEN];
|
u8 ssid[SSID_MAX_LEN];
|
||||||
size_t ssid_len;
|
size_t ssid_len;
|
||||||
|
u32 short_ssid;
|
||||||
unsigned int ssid_set:1;
|
unsigned int ssid_set:1;
|
||||||
unsigned int utf8_ssid:1;
|
unsigned int utf8_ssid:1;
|
||||||
unsigned int wpa_passphrase_set:1;
|
unsigned int wpa_passphrase_set:1;
|
||||||
|
|
|
@ -13,6 +13,7 @@
|
||||||
|
|
||||||
#include "utils/common.h"
|
#include "utils/common.h"
|
||||||
#include "utils/eloop.h"
|
#include "utils/eloop.h"
|
||||||
|
#include "utils/crc32.h"
|
||||||
#include "common/ieee802_11_defs.h"
|
#include "common/ieee802_11_defs.h"
|
||||||
#include "common/wpa_ctrl.h"
|
#include "common/wpa_ctrl.h"
|
||||||
#include "common/hw_features_common.h"
|
#include "common/hw_features_common.h"
|
||||||
|
@ -1190,6 +1191,12 @@ static int hostapd_setup_bss(struct hostapd_data *hapd, int first)
|
||||||
os_memcpy(conf->ssid.ssid, ssid, conf->ssid.ssid_len);
|
os_memcpy(conf->ssid.ssid, ssid, conf->ssid.ssid_len);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Short SSID calculation is identical to FCS and it is defined in
|
||||||
|
* IEEE P802.11-REVmd/D3.0, 9.4.2.170.3 (Calculating the Short-SSID).
|
||||||
|
*/
|
||||||
|
conf->ssid.short_ssid = crc32(conf->ssid.ssid, conf->ssid.ssid_len);
|
||||||
|
|
||||||
if (!hostapd_drv_none(hapd)) {
|
if (!hostapd_drv_none(hapd)) {
|
||||||
wpa_printf(MSG_ERROR, "Using interface %s with hwaddr " MACSTR
|
wpa_printf(MSG_ERROR, "Using interface %s with hwaddr " MACSTR
|
||||||
" and ssid \"%s\"",
|
" and ssid \"%s\"",
|
||||||
|
|
|
@ -94,6 +94,7 @@ OBJS += src/utils/wpa_debug.c
|
||||||
OBJS += src/utils/wpabuf.c
|
OBJS += src/utils/wpabuf.c
|
||||||
OBJS += src/utils/bitfield.c
|
OBJS += src/utils/bitfield.c
|
||||||
OBJS += src/utils/ip_addr.c
|
OBJS += src/utils/ip_addr.c
|
||||||
|
OBJS += src/utils/crc32.c
|
||||||
OBJS += wmm_ac.c
|
OBJS += wmm_ac.c
|
||||||
OBJS += op_classes.c
|
OBJS += op_classes.c
|
||||||
OBJS += rrm.c
|
OBJS += rrm.c
|
||||||
|
|
|
@ -104,6 +104,7 @@ OBJS += ../src/utils/wpa_debug.o
|
||||||
OBJS += ../src/utils/wpabuf.o
|
OBJS += ../src/utils/wpabuf.o
|
||||||
OBJS += ../src/utils/bitfield.o
|
OBJS += ../src/utils/bitfield.o
|
||||||
OBJS += ../src/utils/ip_addr.o
|
OBJS += ../src/utils/ip_addr.o
|
||||||
|
OBJS += ../src/utils/crc32.o
|
||||||
OBJS += op_classes.o
|
OBJS += op_classes.o
|
||||||
OBJS += rrm.o
|
OBJS += rrm.o
|
||||||
OBJS_p = wpa_passphrase.o
|
OBJS_p = wpa_passphrase.o
|
||||||
|
|
Loading…
Reference in a new issue