2016-09-27 03:47:47 +00:00
// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
# ifndef __ESP_WIFI_TYPES_H__
# define __ESP_WIFI_TYPES_H__
# include <stdint.h>
# include <stdbool.h>
# include "rom/queue.h"
# include "esp_err.h"
2016-11-08 09:45:17 +00:00
# include "esp_interface.h"
2016-09-27 03:47:47 +00:00
# ifdef __cplusplus
extern " C " {
# endif
typedef enum {
WIFI_MODE_NULL = 0 , /**< null mode */
WIFI_MODE_STA , /**< WiFi station mode */
WIFI_MODE_AP , /**< WiFi soft-AP mode */
WIFI_MODE_APSTA , /**< WiFi station + soft-AP mode */
WIFI_MODE_MAX
} wifi_mode_t ;
2016-11-08 09:45:17 +00:00
typedef esp_interface_t wifi_interface_t ;
# define WIFI_IF_STA ESP_IF_WIFI_STA
# define WIFI_IF_AP ESP_IF_WIFI_AP
2016-09-27 03:47:47 +00:00
typedef enum {
2017-09-19 12:59:48 +00:00
WIFI_COUNTRY_POLICY_AUTO , /**< Country policy is auto, use the country info of AP to which the station is connected */
WIFI_COUNTRY_POLICY_MANUAL , /**< Country policy is manual, always use the configured country info */
} wifi_country_policy_t ;
2017-09-27 01:09:21 +00:00
/** @brief Structure describing WiFi country-based regional restrictions. */
2017-09-19 12:59:48 +00:00
typedef struct {
char cc [ 3 ] ; /**< country code string */
uint8_t schan ; /**< start channel */
uint8_t nchan ; /**< total channel number */
2018-05-11 06:49:16 +00:00
int8_t max_tx_power ; /**< maximum tx power */
2017-09-19 12:59:48 +00:00
wifi_country_policy_t policy ; /**< country policy */
2016-09-27 03:47:47 +00:00
} wifi_country_t ;
typedef enum {
2017-03-17 09:28:01 +00:00
WIFI_AUTH_OPEN = 0 , /**< authenticate mode : open */
WIFI_AUTH_WEP , /**< authenticate mode : WEP */
WIFI_AUTH_WPA_PSK , /**< authenticate mode : WPA_PSK */
WIFI_AUTH_WPA2_PSK , /**< authenticate mode : WPA2_PSK */
WIFI_AUTH_WPA_WPA2_PSK , /**< authenticate mode : WPA_WPA2_PSK */
WIFI_AUTH_WPA2_ENTERPRISE , /**< authenticate mode : WPA2_ENTERPRISE */
2016-09-27 03:47:47 +00:00
WIFI_AUTH_MAX
} wifi_auth_mode_t ;
2017-09-26 07:02:52 +00:00
typedef enum {
2016-09-27 03:47:47 +00:00
WIFI_REASON_UNSPECIFIED = 1 ,
WIFI_REASON_AUTH_EXPIRE = 2 ,
WIFI_REASON_AUTH_LEAVE = 3 ,
WIFI_REASON_ASSOC_EXPIRE = 4 ,
WIFI_REASON_ASSOC_TOOMANY = 5 ,
WIFI_REASON_NOT_AUTHED = 6 ,
WIFI_REASON_NOT_ASSOCED = 7 ,
WIFI_REASON_ASSOC_LEAVE = 8 ,
WIFI_REASON_ASSOC_NOT_AUTHED = 9 ,
WIFI_REASON_DISASSOC_PWRCAP_BAD = 10 ,
WIFI_REASON_DISASSOC_SUPCHAN_BAD = 11 ,
WIFI_REASON_IE_INVALID = 13 ,
WIFI_REASON_MIC_FAILURE = 14 ,
WIFI_REASON_4WAY_HANDSHAKE_TIMEOUT = 15 ,
WIFI_REASON_GROUP_KEY_UPDATE_TIMEOUT = 16 ,
WIFI_REASON_IE_IN_4WAY_DIFFERS = 17 ,
WIFI_REASON_GROUP_CIPHER_INVALID = 18 ,
WIFI_REASON_PAIRWISE_CIPHER_INVALID = 19 ,
WIFI_REASON_AKMP_INVALID = 20 ,
WIFI_REASON_UNSUPP_RSN_IE_VERSION = 21 ,
WIFI_REASON_INVALID_RSN_IE_CAP = 22 ,
WIFI_REASON_802_1X_AUTH_FAILED = 23 ,
WIFI_REASON_CIPHER_SUITE_REJECTED = 24 ,
WIFI_REASON_BEACON_TIMEOUT = 200 ,
WIFI_REASON_NO_AP_FOUND = 201 ,
WIFI_REASON_AUTH_FAIL = 202 ,
WIFI_REASON_ASSOC_FAIL = 203 ,
WIFI_REASON_HANDSHAKE_TIMEOUT = 204 ,
2017-09-26 07:02:52 +00:00
} wifi_err_reason_t ;
2016-09-27 03:47:47 +00:00
typedef enum {
WIFI_SECOND_CHAN_NONE = 0 , /**< the channel width is HT20 */
2018-05-29 12:26:34 +00:00
WIFI_SECOND_CHAN_ABOVE , /**< the channel width is HT40 and the secondary channel is above the primary channel */
WIFI_SECOND_CHAN_BELOW , /**< the channel width is HT40 and the secondary channel is below the primary channel */
2016-09-27 03:47:47 +00:00
} wifi_second_chan_t ;
2017-03-16 08:20:19 +00:00
typedef enum {
WIFI_SCAN_TYPE_ACTIVE = 0 , /**< active scan */
WIFI_SCAN_TYPE_PASSIVE , /**< passive scan */
} wifi_scan_type_t ;
2017-09-27 01:09:21 +00:00
/** @brief Range of active scan times per channel */
2017-03-16 08:20:19 +00:00
typedef struct {
uint32_t min ; /**< minimum active scan time per channel, units: millisecond */
uint32_t max ; /**< maximum active scan time per channel, units: millisecond, values above 1500ms may
cause station to disconnect from AP and are not recommended . */
} wifi_active_scan_time_t ;
2017-09-27 01:09:21 +00:00
/** @brief Aggregate of active & passive scan time per channel */
2017-03-16 08:20:19 +00:00
typedef union {
2017-09-27 01:09:21 +00:00
wifi_active_scan_time_t active ; /**< active scan time per channel, units: millisecond. */
2017-03-16 08:20:19 +00:00
uint32_t passive ; /**< passive scan time per channel, units: millisecond, values above 1500ms may
cause station to disconnect from AP and are not recommended . */
} wifi_scan_time_t ;
2017-09-27 01:09:21 +00:00
/** @brief Parameters for an SSID scan. */
2016-09-27 03:47:47 +00:00
typedef struct {
2017-03-16 08:20:19 +00:00
uint8_t * ssid ; /**< SSID of AP */
uint8_t * bssid ; /**< MAC address of AP */
uint8_t channel ; /**< channel, scan the specific channel */
bool show_hidden ; /**< enable to scan AP whose SSID is hidden */
wifi_scan_type_t scan_type ; /**< scan type, active or passive */
wifi_scan_time_t scan_time ; /**< scan time per channel */
2016-09-27 03:47:47 +00:00
} wifi_scan_config_t ;
2017-09-19 12:17:25 +00:00
typedef enum {
WIFI_CIPHER_TYPE_NONE = 0 , /**< the cipher type is none */
WIFI_CIPHER_TYPE_WEP40 , /**< the cipher type is WEP40 */
WIFI_CIPHER_TYPE_WEP104 , /**< the cipher type is WEP104 */
WIFI_CIPHER_TYPE_TKIP , /**< the cipher type is TKIP */
WIFI_CIPHER_TYPE_CCMP , /**< the cipher type is CCMP */
WIFI_CIPHER_TYPE_TKIP_CCMP , /**< the cipher type is TKIP and CCMP */
WIFI_CIPHER_TYPE_UNKNOWN , /**< the cipher type is unknown */
} wifi_cipher_type_t ;
2018-05-15 03:59:32 +00:00
/**
* @ brief WiFi antenna
*
*/
typedef enum {
WIFI_ANT_ANT0 , /**< WiFi antenna 0 */
WIFI_ANT_ANT1 , /**< WiFi antenna 1 */
WIFI_ANT_MAX , /**< Invalid WiFi antenna */
} wifi_ant_t ;
/** @brief Description of a WiFi AP */
2016-09-27 03:47:47 +00:00
typedef struct {
uint8_t bssid [ 6 ] ; /**< MAC address of AP */
2017-04-12 13:02:28 +00:00
uint8_t ssid [ 33 ] ; /**< SSID of AP */
2016-09-27 03:47:47 +00:00
uint8_t primary ; /**< channel of AP */
2018-05-29 12:26:34 +00:00
wifi_second_chan_t second ; /**< secondary channel of AP */
2016-09-27 03:47:47 +00:00
int8_t rssi ; /**< signal strength of AP */
wifi_auth_mode_t authmode ; /**< authmode of AP */
2017-09-19 12:17:25 +00:00
wifi_cipher_type_t pairwise_cipher ; /**< pairwise cipher of AP */
wifi_cipher_type_t group_cipher ; /**< group cipher of AP */
2018-05-15 03:59:32 +00:00
wifi_ant_t ant ; /**< antenna used to receive beacon from AP */
2017-09-19 12:17:25 +00:00
uint32_t phy_11b : 1 ; /**< bit: 0 flag to identify if 11b mode is enabled or not */
uint32_t phy_11g : 1 ; /**< bit: 1 flag to identify if 11g mode is enabled or not */
uint32_t phy_11n : 1 ; /**< bit: 2 flag to identify if 11n mode is enabled or not */
uint32_t phy_lr : 1 ; /**< bit: 3 flag to identify if low rate is enabled or not */
uint32_t wps : 1 ; /**< bit: 4 flag to identify if WPS is supported or not */
uint32_t reserved : 27 ; /**< bit: 5..31 reserved */
2018-05-11 06:49:16 +00:00
wifi_country_t country ; /**< country information of AP */
2016-10-26 12:02:39 +00:00
} wifi_ap_record_t ;
2016-09-27 03:47:47 +00:00
2017-09-14 13:27:26 +00:00
typedef enum {
WIFI_FAST_SCAN = 0 , /**< Do fast scan, scan will end after find SSID match AP */
WIFI_ALL_CHANNEL_SCAN , /**< All channel scan, scan will end after scan all the channel */
} wifi_scan_method_t ;
typedef enum {
WIFI_CONNECT_AP_BY_SIGNAL = 0 , /**< Sort match AP in scan list by RSSI */
WIFI_CONNECT_AP_BY_SECURITY , /**< Sort match AP in scan list by security mode */
} wifi_sort_method_t ;
2017-09-27 01:09:21 +00:00
/** @brief Structure describing parameters for a WiFi fast scan */
2017-09-28 08:17:06 +00:00
typedef struct {
2017-09-27 01:09:21 +00:00
int8_t rssi ; /**< The minimum rssi to accept in the fast scan mode */
wifi_auth_mode_t authmode ; /**< The weakest authmode to accept in the fast scan mode */
2017-09-28 08:17:06 +00:00
} wifi_fast_scan_threshold_t ;
2018-07-20 12:30:29 +00:00
typedef wifi_fast_scan_threshold_t wifi_scan_threshold_t ; /**< wifi_fast_scan_threshold_t only used in fast scan mode once, now it enabled in all channel scan, the wifi_fast_scan_threshold_t will be remove in version 4.0 */
2016-09-27 03:47:47 +00:00
typedef enum {
2017-11-10 02:54:50 +00:00
WIFI_PS_NONE , /**< No power save */
2018-04-09 03:38:00 +00:00
WIFI_PS_MIN_MODEM , /**< Minimum modem power saving. In this mode, station wakes up to receive beacon every DTIM period */
WIFI_PS_MAX_MODEM , /**< Maximum modem power saving. In this mode, interval to receive beacons is determined by the listen_interval parameter in wifi_sta_config_t */
2016-09-27 03:47:47 +00:00
} wifi_ps_type_t ;
2018-04-09 03:38:00 +00:00
# define WIFI_PS_MODEM WIFI_PS_MIN_MODEM /**< @deprecated Use WIFI_PS_MIN_MODEM or WIFI_PS_MAX_MODEM instead */
2016-09-27 03:47:47 +00:00
# define WIFI_PROTOCOL_11B 1
# define WIFI_PROTOCOL_11G 2
# define WIFI_PROTOCOL_11N 4
2016-12-30 13:22:06 +00:00
# define WIFI_PROTOCOL_LR 8
2016-09-27 03:47:47 +00:00
typedef enum {
2017-01-02 12:03:10 +00:00
WIFI_BW_HT20 = 1 , /* Bandwidth is HT20 */
2016-09-27 03:47:47 +00:00
WIFI_BW_HT40 , /* Bandwidth is HT40 */
} wifi_bandwidth_t ;
2017-09-27 01:09:21 +00:00
/** @brief Soft-AP configuration settings for the ESP32 */
2016-09-27 03:47:47 +00:00
typedef struct {
2016-12-22 01:34:11 +00:00
uint8_t ssid [ 32 ] ; /**< SSID of ESP32 soft-AP */
uint8_t password [ 64 ] ; /**< Password of ESP32 soft-AP */
2016-09-27 03:47:47 +00:00
uint8_t ssid_len ; /**< Length of SSID. If softap_config.ssid_len==0, check the SSID until there is a termination character; otherwise, set the SSID length according to softap_config.ssid_len. */
uint8_t channel ; /**< Channel of ESP32 soft-AP */
wifi_auth_mode_t authmode ; /**< Auth mode of ESP32 soft-AP. Do not support AUTH_WEP in soft-AP mode */
uint8_t ssid_hidden ; /**< Broadcast SSID or not, default 0, broadcast the SSID */
uint8_t max_connection ; /**< Max number of stations allowed to connect in, default 4, max 4 */
uint16_t beacon_interval ; /**< Beacon interval, 100 ~ 60000 ms, default 100 ms */
} wifi_ap_config_t ;
2017-09-27 01:09:21 +00:00
/** @brief STA configuration settings for the ESP32 */
2016-09-27 03:47:47 +00:00
typedef struct {
2016-12-22 01:34:11 +00:00
uint8_t ssid [ 32 ] ; /**< SSID of target AP*/
uint8_t password [ 64 ] ; /**< password of target AP*/
2017-09-14 13:27:26 +00:00
wifi_scan_method_t scan_method ; /**< do all channel scan or fast scan */
2016-09-27 03:47:47 +00:00
bool bssid_set ; /**< whether set MAC address of target AP or not. Generally, station_config.bssid_set needs to be 0; and it needs to be 1 only when users need to check the MAC address of the AP.*/
uint8_t bssid [ 6 ] ; /**< MAC address of target AP*/
2017-04-26 03:45:30 +00:00
uint8_t channel ; /**< channel of target AP. Set to 1~13 to scan starting from the specified channel before connecting to AP. If the channel of AP is unknown, set it to 0.*/
2018-04-09 03:38:00 +00:00
uint16_t listen_interval ; /**< Listen interval for ESP32 station to receive beacon when WIFI_PS_MAX_MODEM is set. Units: AP beacon intervals. Defaults to 3 if set to 0. */
2017-09-14 13:27:26 +00:00
wifi_sort_method_t sort_method ; /**< sort the connect AP in the list by rssi or security mode */
2018-07-20 12:30:29 +00:00
wifi_scan_threshold_t threshold ; /**< When scan_method is set, only APs which have an auth mode that is more secure than the selected auth mode and a signal stronger than the minimum RSSI will be used. */
2016-09-27 03:47:47 +00:00
} wifi_sta_config_t ;
2017-09-27 01:09:21 +00:00
/** @brief Configuration data for ESP32 AP or STA.
*
* The usage of this union ( for ap or sta configuration ) is determined by the accompanying
* interface argument passed to esp_wifi_set_config ( ) or esp_wifi_get_config ( )
*
*/
2016-09-27 03:47:47 +00:00
typedef union {
wifi_ap_config_t ap ; /**< configuration of AP */
wifi_sta_config_t sta ; /**< configuration of STA */
} wifi_config_t ;
2017-09-27 01:09:21 +00:00
/** @brief Description of STA associated with AP */
2016-10-26 10:16:40 +00:00
typedef struct {
2017-09-27 01:09:21 +00:00
uint8_t mac [ 6 ] ; /**< mac address */
2018-05-11 06:49:16 +00:00
int8_t rssi ; /**< current average rssi of sta connected */
2018-04-24 08:22:33 +00:00
uint32_t phy_11b : 1 ; /**< bit: 0 flag to identify if 11b mode is enabled or not */
uint32_t phy_11g : 1 ; /**< bit: 1 flag to identify if 11g mode is enabled or not */
uint32_t phy_11n : 1 ; /**< bit: 2 flag to identify if 11n mode is enabled or not */
uint32_t phy_lr : 1 ; /**< bit: 3 flag to identify if low rate is enabled or not */
uint32_t reserved : 28 ; /**< bit: 4..31 reserved */
2016-12-12 02:00:24 +00:00
} wifi_sta_info_t ;
2016-10-26 10:16:40 +00:00
2016-10-31 03:17:33 +00:00
# define ESP_WIFI_MAX_CONN_NUM (10) /**< max number of stations which can connect to ESP32 soft-AP */
2016-12-12 02:00:24 +00:00
2017-09-27 01:09:21 +00:00
/** @brief List of stations associated with the ESP32 Soft-AP */
2016-10-26 10:16:40 +00:00
typedef struct {
2016-10-26 12:02:39 +00:00
wifi_sta_info_t sta [ ESP_WIFI_MAX_CONN_NUM ] ; /**< station list */
2017-09-27 01:09:21 +00:00
int num ; /**< number of stations in the list (other entries are invalid) */
2016-12-12 02:00:24 +00:00
} wifi_sta_list_t ;
2016-09-27 03:47:47 +00:00
typedef enum {
WIFI_STORAGE_FLASH , /**< all configuration will strore in both memory and flash */
WIFI_STORAGE_RAM , /**< all configuration will only store in the memory */
} wifi_storage_t ;
/**
2017-06-29 07:20:45 +00:00
* @ brief Vendor Information Element type
2016-09-27 03:47:47 +00:00
*
2017-06-29 07:20:45 +00:00
* Determines the frame type that the IE will be associated with .
2016-09-27 03:47:47 +00:00
*/
typedef enum {
WIFI_VND_IE_TYPE_BEACON ,
WIFI_VND_IE_TYPE_PROBE_REQ ,
WIFI_VND_IE_TYPE_PROBE_RESP ,
WIFI_VND_IE_TYPE_ASSOC_REQ ,
WIFI_VND_IE_TYPE_ASSOC_RESP ,
} wifi_vendor_ie_type_t ;
/**
2017-06-29 07:20:45 +00:00
* @ brief Vendor Information Element index
2016-09-27 03:47:47 +00:00
*
2017-06-29 07:20:45 +00:00
* Each IE type can have up to two associated vendor ID elements .
2016-09-27 03:47:47 +00:00
*/
typedef enum {
WIFI_VND_IE_ID_0 ,
WIFI_VND_IE_ID_1 ,
} wifi_vendor_ie_id_t ;
2017-06-29 07:20:45 +00:00
# define WIFI_VENDOR_IE_ELEMENT_ID 0xDD
/**
* @ brief Vendor Information Element header
*
* The first bytes of the Information Element will match this header . Payload follows .
*/
typedef struct {
uint8_t element_id ; /**< Should be set to WIFI_VENDOR_IE_ELEMENT_ID (0xDD) */
uint8_t length ; /**< Length of all bytes in the element data following this field. Minimum 4. */
uint8_t vendor_oui [ 3 ] ; /**< Vendor identifier (OUI). */
uint8_t vendor_oui_type ; /**< Vendor-specific OUI type. */
uint8_t payload [ 0 ] ; /**< Payload. Length is equal to value in 'length' field, minus 4. */
} vendor_ie_data_t ;
2017-09-27 01:09:21 +00:00
/** @brief Received packet radio metadata header, this is the common header at the beginning of all promiscuous mode RX callback buffers */
2016-12-12 02:00:24 +00:00
typedef struct {
2018-05-29 12:26:34 +00:00
signed rssi : 8 ; /**< Received Signal Strength Indicator(RSSI) of packet. unit: dBm */
unsigned rate : 5 ; /**< PHY rate encoding of the packet. Only valid for non HT(11bg) packet */
unsigned : 1 ; /**< reserve */
unsigned sig_mode : 2 ; /**< 0: non HT(11bg) packet; 1: HT(11n) packet; 3: VHT(11ac) packet */
unsigned : 16 ; /**< reserve */
unsigned mcs : 7 ; /**< Modulation Coding Scheme. If is HT(11n) packet, shows the modulation, range from 0 to 76(MSC0 ~ MCS76) */
2018-07-17 02:41:32 +00:00
unsigned cwb : 1 ; /**< Channel Bandwidth of the packet. 0: 20MHz; 1: 40MHz */
2018-05-29 12:26:34 +00:00
unsigned : 16 ; /**< reserve */
unsigned smoothing : 1 ; /**< reserve */
unsigned not_sounding : 1 ; /**< reserve */
unsigned : 1 ; /**< reserve */
unsigned aggregation : 1 ; /**< Aggregation. 0: MPDU packet; 1: AMPDU packet */
unsigned stbc : 2 ; /**< Space Time Block Code(STBC). 0: non STBC packet; 1: STBC packet */
unsigned fec_coding : 1 ; /**< Flag is set for 11n packets which are LDPC */
unsigned sgi : 1 ; /**< Short Guide Interval(SGI). 0: Long GI; 1: Short GI */
signed noise_floor : 8 ; /**< noise floor of Radio Frequency Module(RF). unit: 0.25dBm*/
unsigned ampdu_cnt : 8 ; /**< ampdu cnt */
unsigned channel : 4 ; /**< primary channel on which this packet is received */
unsigned secondary_channel : 4 ; /**< secondary channel on which this packet is received. 0: none; 1: above; 2: below */
unsigned : 8 ; /**< reserve */
unsigned timestamp : 32 ; /**< timestamp. The local time when this packet is received. It is precise only if modem sleep or light sleep is not enabled. unit: microsecond */
unsigned : 32 ; /**< reserve */
unsigned : 31 ; /**< reserve */
unsigned ant : 1 ; /**< antenna number from which this packet is received. 0: WiFi antenna 0; 1: WiFi antenna 1 */
unsigned sig_len : 12 ; /**< length of packet including Frame Check Sequence(FCS) */
unsigned : 12 ; /**< reserve */
unsigned rx_state : 8 ; /**< state of the packet. 0: no error; others: error numbers which are not public */
2016-12-12 02:00:24 +00:00
} wifi_pkt_rx_ctrl_t ;
2017-09-27 01:09:21 +00:00
/** @brief Payload passed to 'buf' parameter of promiscuous mode RX callback.
*/
2016-12-12 02:00:24 +00:00
typedef struct {
2017-09-27 01:09:21 +00:00
wifi_pkt_rx_ctrl_t rx_ctrl ; /**< metadata header */
uint8_t payload [ 0 ] ; /**< Data or management payload. Length of payload is described by rx_ctrl.sig_len. Type of content determined by packet type argument of callback. */
2016-12-12 02:00:24 +00:00
} wifi_promiscuous_pkt_t ;
/**
2017-09-27 01:09:21 +00:00
* @ brief Promiscuous frame type
*
* Passed to promiscuous mode RX callback to indicate the type of parameter in the buffer .
2016-12-12 02:00:24 +00:00
*
*/
typedef enum {
2017-09-27 01:09:21 +00:00
WIFI_PKT_MGMT , /**< Management frame, indicates 'buf' argument is wifi_promiscuous_pkt_t */
2018-02-05 03:52:56 +00:00
WIFI_PKT_CTRL , /**< Control frame, indicates 'buf' argument is wifi_promiscuous_pkt_t */
2017-09-27 01:09:21 +00:00
WIFI_PKT_DATA , /**< Data frame, indiciates 'buf' argument is wifi_promiscuous_pkt_t */
WIFI_PKT_MISC , /**< Other type, such as MIMO etc. 'buf' argument is wifi_promiscuous_pkt_t but the payload is zero length. */
2016-12-12 02:00:24 +00:00
} wifi_promiscuous_pkt_type_t ;
2016-09-27 03:47:47 +00:00
2017-05-26 06:11:16 +00:00
# define WIFI_PROMIS_FILTER_MASK_ALL (0xFFFFFFFF) /**< filter all packets */
# define WIFI_PROMIS_FILTER_MASK_MGMT (1) /**< filter the packets with type of WIFI_PKT_MGMT */
2018-02-05 03:52:56 +00:00
# define WIFI_PROMIS_FILTER_MASK_CTRL (1<<1) /**< filter the packets with type of WIFI_PKT_CTRL */
# define WIFI_PROMIS_FILTER_MASK_DATA (1<<2) /**< filter the packets with type of WIFI_PKT_DATA */
# define WIFI_PROMIS_FILTER_MASK_MISC (1<<3) /**< filter the packets with type of WIFI_PKT_MISC */
# define WIFI_PROMIS_FILTER_MASK_DATA_MPDU (1<<4) /**< filter the MPDU which is a kind of WIFI_PKT_DATA */
# define WIFI_PROMIS_FILTER_MASK_DATA_AMPDU (1<<5) /**< filter the AMPDU which is a kind of WIFI_PKT_DATA */
# define WIFI_PROMIS_CTRL_FILTER_MASK_ALL (0xFF800000) /**< filter all control packets */
# define WIFI_PROMIS_CTRL_FILTER_MASK_WRAPPER (1<<23) /**< filter the control packets with subtype of Control Wrapper */
# define WIFI_PROMIS_CTRL_FILTER_MASK_BAR (1<<24) /**< filter the control packets with subtype of Block Ack Request */
# define WIFI_PROMIS_CTRL_FILTER_MASK_BA (1<<25) /**< filter the control packets with subtype of Block Ack */
# define WIFI_PROMIS_CTRL_FILTER_MASK_PSPOLL (1<<26) /**< filter the control packets with subtype of PS-Poll */
# define WIFI_PROMIS_CTRL_FILTER_MASK_RTS (1<<27) /**< filter the control packets with subtype of RTS */
# define WIFI_PROMIS_CTRL_FILTER_MASK_CTS (1<<28) /**< filter the control packets with subtype of CTS */
# define WIFI_PROMIS_CTRL_FILTER_MASK_ACK (1<<29) /**< filter the control packets with subtype of ACK */
# define WIFI_PROMIS_CTRL_FILTER_MASK_CFEND (1<<30) /**< filter the control packets with subtype of CF-END */
# define WIFI_PROMIS_CTRL_FILTER_MASK_CFENDACK (1<<31) /**< filter the control packets with subtype of CF-END+CF-ACK */
2017-05-26 06:11:16 +00:00
2017-09-27 01:09:21 +00:00
/** @brief Mask for filtering different packet types in promiscuous mode. */
2017-05-26 06:11:16 +00:00
typedef struct {
2017-09-27 01:09:21 +00:00
uint32_t filter_mask ; /**< OR of one or more filter values WIFI_PROMIS_FILTER_* */
2017-05-26 06:11:16 +00:00
} wifi_promiscuous_filter_t ;
2018-03-16 03:43:21 +00:00
# define WIFI_EVENT_MASK_ALL (0xFFFFFFFF) /**< mask all WiFi events */
# define WIFI_EVENT_MASK_NONE (0) /**< mask none of the WiFi events */
# define WIFI_EVENT_MASK_AP_PROBEREQRECVED (BIT(0)) /**< mask SYSTEM_EVENT_AP_PROBEREQRECVED event */
2018-05-09 08:44:06 +00:00
/**
* @ brief Channel state information ( CSI ) configuration type
*
*/
typedef struct {
2018-05-29 12:26:34 +00:00
bool lltf_en ; /**< enable to receive legacy long training field(lltf) data. Default enabled */
bool htltf_en ; /**< enable to receive HT long training field(htltf) data. Default enabled */
bool stbc_htltf2_en ; /**< enable to receive space time block code HT long training field(stbc-htltf2) data. Default enabled */
2018-09-03 07:28:46 +00:00
bool ltf_merge_en ; /**< enable to generate htlft data by averaging lltf and ht_ltf data when receiving HT packet. Otherwise, use ht_ltf data directly. Default enabled */
bool channel_filter_en ; /**< enable to turn on channel filter to smooth adjacent sub-carrier. Disable it to keep independence of adjacent sub-carrier. Default enabled */
2018-05-29 12:26:34 +00:00
bool manu_scale ; /**< manually scale the CSI data by left shifting or automatically scale the CSI data. If set true, please set the shift bits. false: automatically. true: manually. Default false */
2018-05-09 08:44:06 +00:00
uint8_t shift ; /**< manually left shift bits of the scale of the CSI data. The range of the left shift bits is 0~15 */
} wifi_csi_config_t ;
/**
* @ brief CSI data type
*
*/
typedef struct {
wifi_pkt_rx_ctrl_t rx_ctrl ; /**< received packet radio metadata header of the CSI data */
uint8_t mac [ 6 ] ; /**< source MAC address of the CSI data */
bool last_word_invalid ; /**< last four bytes of the CSI data is invalid or not */
2018-07-04 03:39:14 +00:00
int8_t * buf ; /**< buffer of CSI data */
2018-05-09 08:44:06 +00:00
uint16_t len ; /**< length of CSI data */
} wifi_csi_info_t ;
2018-05-15 03:59:32 +00:00
/**
* @ brief WiFi GPIO configuration for antenna selection
*
*/
typedef struct {
uint8_t gpio_select : 1 , /**< Whether this GPIO is connected to external antenna switch */
gpio_num : 7 ; /**< The GPIO number that connects to external antenna switch */
} wifi_ant_gpio_t ;
/**
* @ brief WiFi GPIOs configuration for antenna selection
*
*/
typedef struct {
wifi_ant_gpio_t gpio_cfg [ 4 ] ; /**< The configurations of GPIOs that connect to external antenna switch */
} wifi_ant_gpio_config_t ;
/**
* @ brief WiFi antenna mode
*
*/
typedef enum {
WIFI_ANT_MODE_ANT0 , /**< Enable WiFi antenna 0 only */
WIFI_ANT_MODE_ANT1 , /**< Enable WiFi antenna 1 only */
WIFI_ANT_MODE_AUTO , /**< Enable WiFi antenna 0 and 1, automatically select an antenna */
WIFI_ANT_MODE_MAX , /**< Invalid WiFi enabled antenna */
} wifi_ant_mode_t ;
/**
* @ brief WiFi antenna configuration
*
*/
typedef struct {
wifi_ant_mode_t rx_ant_mode ; /**< WiFi antenna mode for receiving */
wifi_ant_t rx_ant_default ; /**< Default antenna mode for receiving, it's ignored if rx_ant_mode is not WIFI_ANT_MODE_AUTO */
wifi_ant_mode_t tx_ant_mode ; /**< WiFi antenna mode for transmission, it can be set to WIFI_ANT_MODE_AUTO only if rx_ant_mode is set to WIFI_ANT_MODE_AUTO */
uint8_t enabled_ant0 : 4 , /**< Index (in antenna GPIO configuration) of enabled WIFI_ANT_MODE_ANT0 */
enabled_ant1 : 4 ; /**< Index (in antenna GPIO configuration) of enabled WIFI_ANT_MODE_ANT1 */
} wifi_ant_config_t ;
2018-07-23 08:39:50 +00:00
/**
* @ brief WiFi PHY rate encodings
*
*/
typedef enum {
WIFI_PHY_RATE_1M_L = 0x00 , /**< 1 Mbps with long preamble */
WIFI_PHY_RATE_2M_L = 0x01 , /**< 2 Mbps with long preamble */
WIFI_PHY_RATE_5M_L = 0x02 , /**< 5.5 Mbps with long preamble */
WIFI_PHY_RATE_11M_L = 0x03 , /**< 11 Mbps with long preamble */
WIFI_PHY_RATE_2M_S = 0x05 , /**< 2 Mbps with short preamble */
WIFI_PHY_RATE_5M_S = 0x06 , /**< 5.5 Mbps with short preamble */
WIFI_PHY_RATE_11M_S = 0x07 , /**< 11 Mbps with short preamble */
WIFI_PHY_RATE_48M = 0x08 , /**< 48 Mbps */
WIFI_PHY_RATE_24M = 0x09 , /**< 24 Mbps */
WIFI_PHY_RATE_12M = 0x0A , /**< 12 Mbps */
WIFI_PHY_RATE_6M = 0x0B , /**< 6 Mbps */
WIFI_PHY_RATE_54M = 0x0C , /**< 54 Mbps */
WIFI_PHY_RATE_36M = 0x0D , /**< 36 Mbps */
WIFI_PHY_RATE_18M = 0x0E , /**< 18 Mbps */
WIFI_PHY_RATE_9M = 0x0F , /**< 9 Mbps */
WIFI_PHY_RATE_MCS0_LGI = 0x10 , /**< MCS0 with long GI, 6.5 Mbps for 20MHz, 13.5 Mbps for 40MHz */
WIFI_PHY_RATE_MCS1_LGI = 0x11 , /**< MCS1 with long GI, 13 Mbps for 20MHz, 27 Mbps for 40MHz */
WIFI_PHY_RATE_MCS2_LGI = 0x12 , /**< MCS2 with long GI, 19.5 Mbps for 20MHz, 40.5 Mbps for 40MHz */
WIFI_PHY_RATE_MCS3_LGI = 0x13 , /**< MCS3 with long GI, 26 Mbps for 20MHz, 54 Mbps for 40MHz */
WIFI_PHY_RATE_MCS4_LGI = 0x14 , /**< MCS4 with long GI, 39 Mbps for 20MHz, 81 Mbps for 40MHz */
WIFI_PHY_RATE_MCS5_LGI = 0x15 , /**< MCS5 with long GI, 52 Mbps for 20MHz, 108 Mbps for 40MHz */
WIFI_PHY_RATE_MCS6_LGI = 0x16 , /**< MCS6 with long GI, 58.5 Mbps for 20MHz, 121.5 Mbps for 40MHz */
WIFI_PHY_RATE_MCS7_LGI = 0x17 , /**< MCS7 with long GI, 65 Mbps for 20MHz, 135 Mbps for 40MHz */
WIFI_PHY_RATE_MCS0_SGI = 0x18 , /**< MCS0 with short GI, 7.2 Mbps for 20MHz, 15 Mbps for 40MHz */
WIFI_PHY_RATE_MCS1_SGI = 0x19 , /**< MCS1 with short GI, 14.4 Mbps for 20MHz, 30 Mbps for 40MHz */
WIFI_PHY_RATE_MCS2_SGI = 0x1A , /**< MCS2 with short GI, 21.7 Mbps for 20MHz, 45 Mbps for 40MHz */
WIFI_PHY_RATE_MCS3_SGI = 0x1B , /**< MCS3 with short GI, 28.9 Mbps for 20MHz, 60 Mbps for 40MHz */
WIFI_PHY_RATE_MCS4_SGI = 0x1C , /**< MCS4 with short GI, 43.3 Mbps for 20MHz, 90 Mbps for 40MHz */
WIFI_PHY_RATE_MCS5_SGI = 0x1D , /**< MCS5 with short GI, 57.8 Mbps for 20MHz, 120 Mbps for 40MHz */
WIFI_PHY_RATE_MCS6_SGI = 0x1E , /**< MCS6 with short GI, 65 Mbps for 20MHz, 135 Mbps for 40MHz */
WIFI_PHY_RATE_MCS7_SGI = 0x1F , /**< MCS7 with short GI, 72.2 Mbps for 20MHz, 150 Mbps for 40MHz */
WIFI_PHY_RATE_LORA_250K = 0x29 , /**< 250 Kbps */
WIFI_PHY_RATE_LORA_500K = 0x2A , /**< 500 Kbps */
WIFI_PHY_RATE_MAX ,
} wifi_phy_rate_t ;
2016-09-27 03:47:47 +00:00
# ifdef __cplusplus
}
# endif
# endif /* __ESP_WIFI_TYPES_H__ */