Updated through tag hostap_2_5 from git://w1.fi/hostap.git
[mech_eap.git] / libeap / src / drivers / driver.h
index 9a0b7be..3cdab5a 100644 (file)
@@ -1,15 +1,9 @@
 /*
  * Driver interface definition
- * Copyright (c) 2003-2010, Jouni Malinen <j@w1.fi>
+ * Copyright (c) 2003-2015, Jouni Malinen <j@w1.fi>
  *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- *
- * Alternatively, this software may be distributed under the terms of BSD
- * license.
- *
- * See README and COPYING for more details.
+ * This software may be distributed under the terms of the BSD license.
+ * See README for more details.
  *
  * This file defines a driver interface used by both %wpa_supplicant and
  * hostapd. The first part of the file defines data structures used in various
 #define WPA_SUPPLICANT_DRIVER_VERSION 4
 
 #include "common/defs.h"
+#include "common/ieee802_11_defs.h"
+#include "utils/list.h"
 
 #define HOSTAPD_CHAN_DISABLED 0x00000001
-#define HOSTAPD_CHAN_PASSIVE_SCAN 0x00000002
-#define HOSTAPD_CHAN_NO_IBSS 0x00000004
+#define HOSTAPD_CHAN_NO_IR 0x00000002
 #define HOSTAPD_CHAN_RADAR 0x00000008
+#define HOSTAPD_CHAN_HT40PLUS 0x00000010
+#define HOSTAPD_CHAN_HT40MINUS 0x00000020
+#define HOSTAPD_CHAN_HT40 0x00000040
+#define HOSTAPD_CHAN_SURVEY_LIST_INITIALIZED 0x00000080
+
+#define HOSTAPD_CHAN_DFS_UNKNOWN 0x00000000
+#define HOSTAPD_CHAN_DFS_USABLE 0x00000100
+#define HOSTAPD_CHAN_DFS_UNAVAILABLE 0x00000200
+#define HOSTAPD_CHAN_DFS_AVAILABLE 0x00000300
+#define HOSTAPD_CHAN_DFS_MASK 0x00000300
+
+#define HOSTAPD_CHAN_VHT_10_70 0x00000800
+#define HOSTAPD_CHAN_VHT_30_50 0x00001000
+#define HOSTAPD_CHAN_VHT_50_30 0x00002000
+#define HOSTAPD_CHAN_VHT_70_10 0x00004000
+
+#define HOSTAPD_CHAN_INDOOR_ONLY 0x00010000
+#define HOSTAPD_CHAN_GO_CONCURRENT 0x00020000
+
+/**
+ * enum reg_change_initiator - Regulatory change initiator
+ */
+enum reg_change_initiator {
+       REGDOM_SET_BY_CORE,
+       REGDOM_SET_BY_USER,
+       REGDOM_SET_BY_DRIVER,
+       REGDOM_SET_BY_COUNTRY_IE,
+       REGDOM_BEACON_HINT,
+};
+
+/**
+ * enum reg_type - Regulatory change types
+ */
+enum reg_type {
+       REGDOM_TYPE_UNKNOWN,
+       REGDOM_TYPE_COUNTRY,
+       REGDOM_TYPE_WORLD,
+       REGDOM_TYPE_CUSTOM_WORLD,
+       REGDOM_TYPE_INTERSECTION,
+};
 
 /**
  * struct hostapd_channel_data - Channel information
@@ -44,7 +79,7 @@ struct hostapd_channel_data {
        /**
         * freq - Frequency in MHz
         */
-       short freq;
+       int freq;
 
        /**
         * flag - Channel flags (HOSTAPD_CHAN_*)
@@ -52,11 +87,39 @@ struct hostapd_channel_data {
        int flag;
 
        /**
-        * max_tx_power - maximum transmit power in dBm
+        * max_tx_power - Regulatory transmit power limit in dBm
         */
        u8 max_tx_power;
+
+       /**
+        * survey_list - Linked list of surveys (struct freq_survey)
+        */
+       struct dl_list survey_list;
+
+       /**
+        * min_nf - Minimum observed noise floor, in dBm, based on all
+        * surveyed channel data
+        */
+       s8 min_nf;
+
+#ifdef CONFIG_ACS
+       /**
+        * interference_factor - Computed interference factor on this
+        * channel (used internally in src/ap/acs.c; driver wrappers do not
+        * need to set this)
+        */
+       long double interference_factor;
+#endif /* CONFIG_ACS */
+
+       /**
+        * dfs_cac_ms - DFS CAC time in milliseconds
+        */
+       unsigned int dfs_cac_ms;
 };
 
+#define HOSTAPD_MODE_FLAG_HT_INFO_KNOWN BIT(0)
+#define HOSTAPD_MODE_FLAG_VHT_INFO_KNOWN BIT(1)
+
 /**
  * struct hostapd_hw_modes - Supported hardware mode information
  */
@@ -100,22 +163,42 @@ struct hostapd_hw_modes {
         * a_mpdu_params - A-MPDU (IEEE 802.11n) parameters
         */
        u8 a_mpdu_params;
+
+       /**
+        * vht_capab - VHT (IEEE 802.11ac) capabilities
+        */
+       u32 vht_capab;
+
+       /**
+        * vht_mcs_set - VHT MCS (IEEE 802.11ac) rate parameters
+        */
+       u8 vht_mcs_set[8];
+
+       unsigned int flags; /* HOSTAPD_MODE_FLAG_* */
 };
 
 
 #define IEEE80211_MODE_INFRA   0
 #define IEEE80211_MODE_IBSS    1
 #define IEEE80211_MODE_AP      2
+#define IEEE80211_MODE_MESH    5
 
 #define IEEE80211_CAP_ESS      0x0001
 #define IEEE80211_CAP_IBSS     0x0002
 #define IEEE80211_CAP_PRIVACY  0x0010
+#define IEEE80211_CAP_RRM      0x1000
+
+/* DMG (60 GHz) IEEE 802.11ad */
+/* type - bits 0..1 */
+#define IEEE80211_CAP_DMG_MASK 0x0003
+#define IEEE80211_CAP_DMG_IBSS 0x0001 /* Tx by: STA */
+#define IEEE80211_CAP_DMG_PBSS 0x0002 /* Tx by: PCP */
+#define IEEE80211_CAP_DMG_AP   0x0003 /* Tx by: AP */
 
 #define WPA_SCAN_QUAL_INVALID          BIT(0)
 #define WPA_SCAN_NOISE_INVALID         BIT(1)
 #define WPA_SCAN_LEVEL_INVALID         BIT(2)
 #define WPA_SCAN_LEVEL_DBM             BIT(3)
-#define WPA_SCAN_AUTHENTICATED         BIT(4)
 #define WPA_SCAN_ASSOCIATED            BIT(5)
 
 /**
@@ -131,6 +214,9 @@ struct hostapd_hw_modes {
  * @tsf: Timestamp
  * @age: Age of the information in milliseconds (i.e., how many milliseconds
  * ago the last Beacon or Probe Response frame was received)
+ * @est_throughput: Estimated throughput in kbps (this is calculated during
+ * scan result processing if left zero by the driver wrapper)
+ * @snr: Signal-to-noise ratio in dB (calculated during scan result processing)
  * @ie_len: length of the following IE field in octets
  * @beacon_ie_len: length of the following Beacon IE field in octets
  *
@@ -142,6 +228,11 @@ struct hostapd_hw_modes {
  * constructed of the IEs that are available. This field will also need to
  * include SSID in IE format. All drivers are encouraged to be extended to
  * report all IEs to make it easier to support future additions.
+ *
+ * This structure data is followed by ie_len octets of IEs from Probe Response
+ * frame (or if the driver does not indicate source of IEs, these may also be
+ * from Beacon frame). After the first set of IEs, another set of IEs may follow
+ * (with beacon_ie_len octets of data) if the driver provides both IE sets.
  */
 struct wpa_scan_res {
        unsigned int flags;
@@ -154,25 +245,23 @@ struct wpa_scan_res {
        int level;
        u64 tsf;
        unsigned int age;
+       unsigned int est_throughput;
+       int snr;
        size_t ie_len;
        size_t beacon_ie_len;
-       /*
-        * Followed by ie_len octets of IEs from Probe Response frame (or if
-        * the driver does not indicate source of IEs, these may also be from
-        * Beacon frame). After the first set of IEs, another set of IEs may
-        * follow (with beacon_ie_len octets of data) if the driver provides
-        * both IE sets.
-        */
+       /* Followed by ie_len + beacon_ie_len octets of IE data */
 };
 
 /**
  * struct wpa_scan_results - Scan results
  * @res: Array of pointers to allocated variable length scan result entries
  * @num: Number of entries in the scan result array
+ * @fetch_time: Time when the results were fetched from the driver
  */
 struct wpa_scan_results {
        struct wpa_scan_res **res;
        size_t num;
+       struct os_reltime fetch_time;
 };
 
 /**
@@ -192,7 +281,7 @@ struct wpa_interface_info {
        const char *drv_name;
 };
 
-#define WPAS_MAX_SCAN_SSIDS 4
+#define WPAS_MAX_SCAN_SSIDS 16
 
 /**
  * struct wpa_driver_scan_params - Scan parameters
@@ -253,7 +342,7 @@ struct wpa_driver_scan_params {
         * is not needed anymore.
         */
        struct wpa_driver_scan_filter {
-               u8 ssid[32];
+               u8 ssid[SSID_MAX_LEN];
                size_t ssid_len;
        } *filter_ssids;
 
@@ -261,6 +350,68 @@ struct wpa_driver_scan_params {
         * num_filter_ssids - Number of entries in filter_ssids array
         */
        size_t num_filter_ssids;
+
+       /**
+        * filter_rssi - Filter by RSSI
+        *
+        * The driver may filter scan results in firmware to reduce host
+        * wakeups and thereby save power. Specify the RSSI threshold in s32
+        * dBm.
+        */
+       s32 filter_rssi;
+
+       /**
+        * p2p_probe - Used to disable CCK (802.11b) rates for P2P probes
+        *
+        * When set, the driver is expected to remove rates 1, 2, 5.5, and 11
+        * Mbps from the support rates element(s) in the Probe Request frames
+        * and not to transmit the frames at any of those rates.
+        */
+       unsigned int p2p_probe:1;
+
+       /**
+        * only_new_results - Request driver to report only new results
+        *
+        * This is used to request the driver to report only BSSes that have
+        * been detected after this scan request has been started, i.e., to
+        * flush old cached BSS entries.
+        */
+       unsigned int only_new_results:1;
+
+       /**
+        * low_priority - Requests driver to use a lower scan priority
+        *
+        * This is used to request the driver to use a lower scan priority
+        * if it supports such a thing.
+        */
+       unsigned int low_priority:1;
+
+       /**
+        * mac_addr_rand - Requests driver to randomize MAC address
+        */
+       unsigned int mac_addr_rand:1;
+
+       /**
+        * mac_addr - MAC address used with randomization. The address cannot be
+        * a multicast one, i.e., bit 0 of byte 0 should not be set.
+        */
+       const u8 *mac_addr;
+
+       /**
+        * mac_addr_mask - MAC address mask used with randomization.
+        *
+        * Bits that are 0 in the mask should be randomized. Bits that are 1 in
+        * the mask should be taken as is from mac_addr. The mask should not
+        * allow the generation of a multicast address, i.e., bit 0 of byte 0
+        * must be set.
+        */
+       const u8 *mac_addr_mask;
+
+       /*
+        * NOTE: Whenever adding new parameters here, please make sure
+        * wpa_scan_clone_params() and wpa_scan_free_params() get updated with
+        * matching changes.
+        */
 };
 
 /**
@@ -279,13 +430,102 @@ struct wpa_driver_auth_params {
        size_t wep_key_len[4];
        int wep_tx_keyidx;
        int local_state_change;
+
+       /**
+        * p2p - Whether this connection is a P2P group
+        */
+       int p2p;
+
+       /**
+        * sae_data - SAE elements for Authentication frame
+        *
+        * This buffer starts with the Authentication transaction sequence
+        * number field. If SAE is not used, this pointer is %NULL.
+        */
+       const u8 *sae_data;
+
+       /**
+        * sae_data_len - Length of sae_data buffer in octets
+        */
+       size_t sae_data_len;
 };
 
+/**
+ * enum wps_mode - WPS mode
+ */
 enum wps_mode {
-       WPS_MODE_NONE /* no WPS provisioning being used */,
-       WPS_MODE_OPEN /* WPS provisioning with AP that is in open mode */,
-       WPS_MODE_PRIVACY /* WPS provisioning with AP that is using protection
-                         */
+       /**
+        * WPS_MODE_NONE - No WPS provisioning being used
+        */
+       WPS_MODE_NONE,
+
+       /**
+        * WPS_MODE_OPEN - WPS provisioning with AP that is in open mode
+        */
+       WPS_MODE_OPEN,
+
+       /**
+        * WPS_MODE_PRIVACY - WPS provisioning with AP that is using protection
+        */
+       WPS_MODE_PRIVACY
+};
+
+/**
+ * struct hostapd_freq_params - Channel parameters
+ */
+struct hostapd_freq_params {
+       /**
+        * mode - Mode/band (HOSTAPD_MODE_IEEE80211A, ..)
+        */
+       enum hostapd_hw_mode mode;
+
+       /**
+        * freq - Primary channel center frequency in MHz
+        */
+       int freq;
+
+       /**
+        * channel - Channel number
+        */
+       int channel;
+
+       /**
+        * ht_enabled - Whether HT is enabled
+        */
+       int ht_enabled;
+
+       /**
+        * sec_channel_offset - Secondary channel offset for HT40
+        *
+        * 0 = HT40 disabled,
+        * -1 = HT40 enabled, secondary channel below primary,
+        * 1 = HT40 enabled, secondary channel above primary
+        */
+       int sec_channel_offset;
+
+       /**
+        * vht_enabled - Whether VHT is enabled
+        */
+       int vht_enabled;
+
+       /**
+        * center_freq1 - Segment 0 center frequency in MHz
+        *
+        * Valid for both HT and VHT.
+        */
+       int center_freq1;
+
+       /**
+        * center_freq2 - Segment 1 center frequency in MHz
+        *
+        * Non-zero only for bandwidth 80 and an 80+80 channel
+        */
+       int center_freq2;
+
+       /**
+        * bandwidth - Channel bandwidth in MHz (20, 40, 80, 160)
+        */
+       int bandwidth;
 };
 
 /**
@@ -300,6 +540,16 @@ struct wpa_driver_associate_params {
        const u8 *bssid;
 
        /**
+        * bssid_hint - BSSID of a proposed AP
+        *
+        * This indicates which BSS has been found a suitable candidate for
+        * initial association for drivers that use driver/firmwate-based BSS
+        * selection. Unlike the @bssid parameter, @bssid_hint does not limit
+        * the driver from selecting other BSSes in the ESS.
+        */
+       const u8 *bssid_hint;
+
+       /**
         * ssid - The selected SSID
         */
        const u8 *ssid;
@@ -310,11 +560,31 @@ struct wpa_driver_associate_params {
        size_t ssid_len;
 
        /**
-        * freq - Frequency of the channel the selected AP is using
-        * Frequency that the selected AP is using (in MHz as
-        * reported in the scan results)
+        * freq - channel parameters
         */
-       int freq;
+       struct hostapd_freq_params freq;
+
+       /**
+        * freq_hint - Frequency of the channel the proposed AP is using
+        *
+        * This provides a channel on which a suitable BSS has been found as a
+        * hint for the driver. Unlike the @freq parameter, @freq_hint does not
+        * limit the driver from selecting other channels for
+        * driver/firmware-based BSS selection.
+        */
+       int freq_hint;
+
+       /**
+        * bg_scan_period - Background scan period in seconds, 0 to disable
+        * background scan, or -1 to indicate no change to default driver
+        * configuration
+        */
+       int bg_scan_period;
+
+       /**
+        * beacon_int - Beacon interval for IBSS or 0 to use driver default
+        */
+       int beacon_int;
 
        /**
         * wpa_ie - WPA information element for (Re)Association Request
@@ -342,25 +612,30 @@ struct wpa_driver_associate_params {
        size_t wpa_ie_len;
 
        /**
-        * pairwise_suite - Selected pairwise cipher suite
+        * wpa_proto - Bitfield of WPA_PROTO_* values to indicate WPA/WPA2
+        */
+       unsigned int wpa_proto;
+
+       /**
+        * pairwise_suite - Selected pairwise cipher suite (WPA_CIPHER_*)
         *
         * This is usually ignored if @wpa_ie is used.
         */
-       enum wpa_cipher pairwise_suite;
+       unsigned int pairwise_suite;
 
        /**
-        * group_suite - Selected group cipher suite
+        * group_suite - Selected group cipher suite (WPA_CIPHER_*)
         *
         * This is usually ignored if @wpa_ie is used.
         */
-       enum wpa_cipher group_suite;
+       unsigned int group_suite;
 
        /**
-        * key_mgmt_suite - Selected key management suite
+        * key_mgmt_suite - Selected key management suite (WPA_KEY_MGMT_*)
         *
         * This is usually ignored if @wpa_ie is used.
         */
-       enum wpa_key_mgmt key_mgmt_suite;
+       unsigned int key_mgmt_suite;
 
        /**
         * auth_alg - Allowed authentication algorithms
@@ -489,1423 +764,2681 @@ struct wpa_driver_associate_params {
         * STA mode: bits 0..3 UAPSD enabled for VO,VI,BK,BE
         */
        int uapsd;
-};
-
-/**
- * struct wpa_driver_capa - Driver capability information
- */
-struct wpa_driver_capa {
-#define WPA_DRIVER_CAPA_KEY_MGMT_WPA           0x00000001
-#define WPA_DRIVER_CAPA_KEY_MGMT_WPA2          0x00000002
-#define WPA_DRIVER_CAPA_KEY_MGMT_WPA_PSK       0x00000004
-#define WPA_DRIVER_CAPA_KEY_MGMT_WPA2_PSK      0x00000008
-#define WPA_DRIVER_CAPA_KEY_MGMT_WPA_NONE      0x00000010
-#define WPA_DRIVER_CAPA_KEY_MGMT_FT            0x00000020
-#define WPA_DRIVER_CAPA_KEY_MGMT_FT_PSK                0x00000040
-       unsigned int key_mgmt;
 
-#define WPA_DRIVER_CAPA_ENC_WEP40      0x00000001
-#define WPA_DRIVER_CAPA_ENC_WEP104     0x00000002
-#define WPA_DRIVER_CAPA_ENC_TKIP       0x00000004
-#define WPA_DRIVER_CAPA_ENC_CCMP       0x00000008
-       unsigned int enc;
+       /**
+        * fixed_bssid - Whether to force this BSSID in IBSS mode
+        * 1 = Fix this BSSID and prevent merges.
+        * 0 = Do not fix BSSID.
+        */
+       int fixed_bssid;
 
-#define WPA_DRIVER_AUTH_OPEN           0x00000001
-#define WPA_DRIVER_AUTH_SHARED         0x00000002
-#define WPA_DRIVER_AUTH_LEAP           0x00000004
-       unsigned int auth;
+       /**
+        * fixed_freq - Fix control channel in IBSS mode
+        * 0 = don't fix control channel (default)
+        * 1 = fix control channel; this prevents IBSS merging with another
+        *      channel
+        */
+       int fixed_freq;
 
-/* Driver generated WPA/RSN IE */
-#define WPA_DRIVER_FLAGS_DRIVER_IE     0x00000001
-/* Driver needs static WEP key setup after association command */
-#define WPA_DRIVER_FLAGS_SET_KEYS_AFTER_ASSOC 0x00000002
-#define WPA_DRIVER_FLAGS_USER_SPACE_MLME 0x00000004
-/* Driver takes care of RSN 4-way handshake internally; PMK is configured with
- * struct wpa_driver_ops::set_key using alg = WPA_ALG_PMK */
-#define WPA_DRIVER_FLAGS_4WAY_HANDSHAKE 0x00000008
-#define WPA_DRIVER_FLAGS_WIRED         0x00000010
-/* Driver provides separate commands for authentication and association (SME in
- * wpa_supplicant). */
-#define WPA_DRIVER_FLAGS_SME           0x00000020
-/* Driver supports AP mode */
-#define WPA_DRIVER_FLAGS_AP            0x00000040
-/* Driver needs static WEP key setup after association has been completed */
-#define WPA_DRIVER_FLAGS_SET_KEYS_AFTER_ASSOC_DONE     0x00000080
-/* Driver takes care of P2P management operations */
-#define WPA_DRIVER_FLAGS_P2P_MGMT      0x00000100
-/* Driver supports concurrent P2P operations */
-#define WPA_DRIVER_FLAGS_P2P_CONCURRENT        0x00000200
-/*
- * Driver uses the initial interface as a dedicated management interface, i.e.,
- * it cannot be used for P2P group operations.
- */
-#define WPA_DRIVER_FLAGS_P2P_DEDICATED_INTERFACE       0x00000400
-/* This interface is P2P capable (P2P Device, GO, or P2P Client */
-#define WPA_DRIVER_FLAGS_P2P_CAPABLE   0x00000800
-/* Driver supports concurrent operations on multiple channels */
-#define WPA_DRIVER_FLAGS_MULTI_CHANNEL_CONCURRENT      0x00001000
-       unsigned int flags;
+       /**
+        * disable_ht - Disable HT (IEEE 802.11n) for this connection
+        */
+       int disable_ht;
 
-       int max_scan_ssids;
+       /**
+        * htcaps - HT Capabilities over-rides
+        *
+        * Only bits set in the mask will be used, and not all values are used
+        * by the kernel anyway. Currently, MCS, MPDU and MSDU fields are used.
+        *
+        * Pointer to struct ieee80211_ht_capabilities.
+        */
+       const u8 *htcaps;
 
        /**
-        * max_remain_on_chan - Maximum remain-on-channel duration in msec
+        * htcaps_mask - HT Capabilities over-rides mask
+        *
+        * Pointer to struct ieee80211_ht_capabilities.
         */
-       unsigned int max_remain_on_chan;
+       const u8 *htcaps_mask;
 
+#ifdef CONFIG_VHT_OVERRIDES
        /**
-        * max_stations - Maximum number of associated stations the driver
-        * supports in AP mode
+        * disable_vht - Disable VHT for this connection
         */
-       unsigned int max_stations;
-};
+       int disable_vht;
 
+       /**
+        * VHT capability overrides.
+        */
+       const struct ieee80211_vht_capabilities *vhtcaps;
+       const struct ieee80211_vht_capabilities *vhtcaps_mask;
+#endif /* CONFIG_VHT_OVERRIDES */
 
-struct hostapd_data;
+       /**
+        * req_key_mgmt_offload - Request key management offload for connection
+        *
+        * Request key management offload for this connection if the device
+        * supports it.
+        */
+       int req_key_mgmt_offload;
 
-struct hostap_sta_driver_data {
-       unsigned long rx_packets, tx_packets, rx_bytes, tx_bytes;
-       unsigned long current_tx_rate;
-       unsigned long inactive_msec;
-       unsigned long flags;
-       unsigned long num_ps_buf_frames;
-       unsigned long tx_retry_failed;
-       unsigned long tx_retry_count;
-       int last_rssi;
-       int last_ack_rssi;
+       /**
+        * Flag for indicating whether this association includes support for
+        * RRM (Radio Resource Measurements)
+        */
+       int rrm_used;
 };
 
-struct hostapd_sta_add_params {
-       const u8 *addr;
-       u16 aid;
-       u16 capability;
-       const u8 *supp_rates;
-       size_t supp_rates_len;
-       u16 listen_interval;
-       const struct ieee80211_ht_capabilities *ht_capabilities;
+enum hide_ssid {
+       NO_SSID_HIDING,
+       HIDDEN_SSID_ZERO_LEN,
+       HIDDEN_SSID_ZERO_CONTENTS
 };
 
-struct hostapd_freq_params {
-       int mode;
-       int freq;
-       int channel;
-       int ht_enabled;
-       int sec_channel_offset; /* 0 = HT40 disabled, -1 = HT40 enabled,
-                                * secondary channel below primary, 1 = HT40
-                                * enabled, secondary channel above primary */
+struct wowlan_triggers {
+       u8 any;
+       u8 disconnect;
+       u8 magic_pkt;
+       u8 gtk_rekey_failure;
+       u8 eap_identity_req;
+       u8 four_way_handshake;
+       u8 rfkill_release;
 };
 
-enum wpa_driver_if_type {
+struct wpa_driver_ap_params {
        /**
-        * WPA_IF_STATION - Station mode interface
+        * head - Beacon head from IEEE 802.11 header to IEs before TIM IE
         */
-       WPA_IF_STATION,
+       u8 *head;
 
        /**
-        * WPA_IF_AP_VLAN - AP mode VLAN interface
-        *
-        * This interface shares its address and Beacon frame with the main
-        * BSS.
+        * head_len - Length of the head buffer in octets
         */
-       WPA_IF_AP_VLAN,
+       size_t head_len;
 
        /**
-        * WPA_IF_AP_BSS - AP mode BSS interface
-        *
-        * This interface has its own address and Beacon frame.
+        * tail - Beacon tail following TIM IE
         */
-       WPA_IF_AP_BSS,
+       u8 *tail;
 
        /**
-        * WPA_IF_P2P_GO - P2P Group Owner
+        * tail_len - Length of the tail buffer in octets
         */
-       WPA_IF_P2P_GO,
+       size_t tail_len;
 
        /**
-        * WPA_IF_P2P_CLIENT - P2P Client
+        * dtim_period - DTIM period
         */
-       WPA_IF_P2P_CLIENT,
+       int dtim_period;
 
        /**
-        * WPA_IF_P2P_GROUP - P2P Group interface (will become either
-        * WPA_IF_P2P_GO or WPA_IF_P2P_CLIENT, but the role is not yet known)
+        * beacon_int - Beacon interval
         */
-       WPA_IF_P2P_GROUP
-};
+       int beacon_int;
 
-struct wpa_init_params {
-       const u8 *bssid;
-       const char *ifname;
-       const u8 *ssid;
+       /**
+        * basic_rates: -1 terminated array of basic rates in 100 kbps
+        *
+        * This parameter can be used to set a specific basic rate set for the
+        * BSS. If %NULL, default basic rate set is used.
+        */
+       int *basic_rates;
+
+       /**
+        * proberesp - Probe Response template
+        *
+        * This is used by drivers that reply to Probe Requests internally in
+        * AP mode and require the full Probe Response template.
+        */
+       u8 *proberesp;
+
+       /**
+        * proberesp_len - Length of the proberesp buffer in octets
+        */
+       size_t proberesp_len;
+
+       /**
+        * ssid - The SSID to use in Beacon/Probe Response frames
+        */
+       const u8 *ssid;
+
+       /**
+        * ssid_len - Length of the SSID (1..32)
+        */
        size_t ssid_len;
-       const char *test_socket;
-       int use_pae_group_addr;
-       char **bridge;
-       size_t num_bridge;
 
-       u8 *own_addr; /* buffer for writing own MAC address */
-};
+       /**
+        * hide_ssid - Whether to hide the SSID
+        */
+       enum hide_ssid hide_ssid;
 
+       /**
+        * pairwise_ciphers - WPA_CIPHER_* bitfield
+        */
+       unsigned int pairwise_ciphers;
 
-struct wpa_bss_params {
-       /** Interface name (for multi-SSID/VLAN support) */
-       const char *ifname;
-       /** Whether IEEE 802.1X or WPA/WPA2 is enabled */
-       int enabled;
+       /**
+        * group_cipher - WPA_CIPHER_*
+        */
+       unsigned int group_cipher;
 
-       int wpa;
-       int ieee802_1x;
-       int wpa_group;
-       int wpa_pairwise;
-       int wpa_key_mgmt;
-       int rsn_preauth;
+       /**
+        * key_mgmt_suites - WPA_KEY_MGMT_* bitfield
+        */
+       unsigned int key_mgmt_suites;
+
+       /**
+        * auth_algs - WPA_AUTH_ALG_* bitfield
+        */
+       unsigned int auth_algs;
+
+       /**
+        * wpa_version - WPA_PROTO_* bitfield
+        */
+       unsigned int wpa_version;
+
+       /**
+        * privacy - Whether privacy is used in the BSS
+        */
+       int privacy;
+
+       /**
+        * beacon_ies - WPS/P2P IE(s) for Beacon frames
+        *
+        * This is used to add IEs like WPS IE and P2P IE by drivers that do
+        * not use the full Beacon template.
+        */
+       const struct wpabuf *beacon_ies;
+
+       /**
+        * proberesp_ies - P2P/WPS IE(s) for Probe Response frames
+        *
+        * This is used to add IEs like WPS IE and P2P IE by drivers that
+        * reply to Probe Request frames internally.
+        */
+       const struct wpabuf *proberesp_ies;
+
+       /**
+        * assocresp_ies - WPS IE(s) for (Re)Association Response frames
+        *
+        * This is used to add IEs like WPS IE by drivers that reply to
+        * (Re)Association Request frames internally.
+        */
+       const struct wpabuf *assocresp_ies;
+
+       /**
+        * isolate - Whether to isolate frames between associated stations
+        *
+        * If this is non-zero, the AP is requested to disable forwarding of
+        * frames between associated stations.
+        */
+       int isolate;
+
+       /**
+        * cts_protect - Whether CTS protection is enabled
+        */
+       int cts_protect;
+
+       /**
+        * preamble - Whether short preamble is enabled
+        */
+       int preamble;
+
+       /**
+        * short_slot_time - Whether short slot time is enabled
+        *
+        * 0 = short slot time disable, 1 = short slot time enabled, -1 = do
+        * not set (e.g., when 802.11g mode is not in use)
+        */
+       int short_slot_time;
+
+       /**
+        * ht_opmode - HT operation mode or -1 if HT not in use
+        */
+       int ht_opmode;
+
+       /**
+        * interworking - Whether Interworking is enabled
+        */
+       int interworking;
+
+       /**
+        * hessid - Homogeneous ESS identifier or %NULL if not set
+        */
+       const u8 *hessid;
+
+       /**
+        * access_network_type - Access Network Type (0..15)
+        *
+        * This is used for filtering Probe Request frames when Interworking is
+        * enabled.
+        */
+       u8 access_network_type;
+
+       /**
+        * ap_max_inactivity - Timeout in seconds to detect STA's inactivity
+        *
+        * This is used by driver which advertises this capability.
+        */
+       int ap_max_inactivity;
+
+       /**
+        * ctwindow - Client Traffic Window (in TUs)
+        */
+       u8 p2p_go_ctwindow;
+
+       /**
+        * smps_mode - SMPS mode
+        *
+        * SMPS mode to be used by the AP, specified as the relevant bits of
+        * ht_capab (i.e. HT_CAP_INFO_SMPS_*).
+        */
+       unsigned int smps_mode;
+
+       /**
+        * disable_dgaf - Whether group-addressed frames are disabled
+        */
+       int disable_dgaf;
+
+       /**
+        * osen - Whether OSEN security is enabled
+        */
+       int osen;
+
+       /**
+        * freq - Channel parameters for dynamic bandwidth changes
+        */
+       struct hostapd_freq_params *freq;
+
+       /**
+        * reenable - Whether this is to re-enable beaconing
+        */
+       int reenable;
 };
 
-#define WPA_STA_AUTHORIZED BIT(0)
-#define WPA_STA_WMM BIT(1)
-#define WPA_STA_SHORT_PREAMBLE BIT(2)
-#define WPA_STA_MFP BIT(3)
+struct wpa_driver_mesh_bss_params {
+#define WPA_DRIVER_MESH_CONF_FLAG_AUTO_PLINKS  0x00000001
+       /*
+        * TODO: Other mesh configuration parameters would go here.
+        * See NL80211_MESHCONF_* for all the mesh config parameters.
+        */
+       unsigned int flags;
+       int peer_link_timeout;
+};
+
+struct wpa_driver_mesh_join_params {
+       const u8 *meshid;
+       int meshid_len;
+       const int *basic_rates;
+       const u8 *ies;
+       int ie_len;
+       struct hostapd_freq_params freq;
+       int beacon_int;
+       int max_peer_links;
+       struct wpa_driver_mesh_bss_params conf;
+#define WPA_DRIVER_MESH_FLAG_USER_MPM  0x00000001
+#define WPA_DRIVER_MESH_FLAG_DRIVER_MPM        0x00000002
+#define WPA_DRIVER_MESH_FLAG_SAE_AUTH  0x00000004
+#define WPA_DRIVER_MESH_FLAG_AMPE      0x00000008
+       unsigned int flags;
+};
 
 /**
- * struct wpa_driver_ops - Driver interface API definition
- *
- * This structure defines the API that each driver interface needs to implement
- * for core wpa_supplicant code. All driver specific functionality is captured
- * in this wrapper.
+ * struct wpa_driver_capa - Driver capability information
  */
-struct wpa_driver_ops {
-       /** Name of the driver interface */
-       const char *name;
-       /** One line description of the driver interface */
-       const char *desc;
+struct wpa_driver_capa {
+#define WPA_DRIVER_CAPA_KEY_MGMT_WPA           0x00000001
+#define WPA_DRIVER_CAPA_KEY_MGMT_WPA2          0x00000002
+#define WPA_DRIVER_CAPA_KEY_MGMT_WPA_PSK       0x00000004
+#define WPA_DRIVER_CAPA_KEY_MGMT_WPA2_PSK      0x00000008
+#define WPA_DRIVER_CAPA_KEY_MGMT_WPA_NONE      0x00000010
+#define WPA_DRIVER_CAPA_KEY_MGMT_FT            0x00000020
+#define WPA_DRIVER_CAPA_KEY_MGMT_FT_PSK                0x00000040
+#define WPA_DRIVER_CAPA_KEY_MGMT_WAPI_PSK      0x00000080
+#define WPA_DRIVER_CAPA_KEY_MGMT_SUITE_B       0x00000100
+#define WPA_DRIVER_CAPA_KEY_MGMT_SUITE_B_192   0x00000200
+       /** Bitfield of supported key management suites */
+       unsigned int key_mgmt;
+
+#define WPA_DRIVER_CAPA_ENC_WEP40      0x00000001
+#define WPA_DRIVER_CAPA_ENC_WEP104     0x00000002
+#define WPA_DRIVER_CAPA_ENC_TKIP       0x00000004
+#define WPA_DRIVER_CAPA_ENC_CCMP       0x00000008
+#define WPA_DRIVER_CAPA_ENC_WEP128     0x00000010
+#define WPA_DRIVER_CAPA_ENC_GCMP       0x00000020
+#define WPA_DRIVER_CAPA_ENC_GCMP_256   0x00000040
+#define WPA_DRIVER_CAPA_ENC_CCMP_256   0x00000080
+#define WPA_DRIVER_CAPA_ENC_BIP                0x00000100
+#define WPA_DRIVER_CAPA_ENC_BIP_GMAC_128       0x00000200
+#define WPA_DRIVER_CAPA_ENC_BIP_GMAC_256       0x00000400
+#define WPA_DRIVER_CAPA_ENC_BIP_CMAC_256       0x00000800
+#define WPA_DRIVER_CAPA_ENC_GTK_NOT_USED       0x00001000
+       /** Bitfield of supported cipher suites */
+       unsigned int enc;
+
+#define WPA_DRIVER_AUTH_OPEN           0x00000001
+#define WPA_DRIVER_AUTH_SHARED         0x00000002
+#define WPA_DRIVER_AUTH_LEAP           0x00000004
+       /** Bitfield of supported IEEE 802.11 authentication algorithms */
+       unsigned int auth;
+
+/** Driver generated WPA/RSN IE */
+#define WPA_DRIVER_FLAGS_DRIVER_IE     0x00000001
+/** Driver needs static WEP key setup after association command */
+#define WPA_DRIVER_FLAGS_SET_KEYS_AFTER_ASSOC 0x00000002
+/** Driver takes care of all DFS operations */
+#define WPA_DRIVER_FLAGS_DFS_OFFLOAD                   0x00000004
+/** Driver takes care of RSN 4-way handshake internally; PMK is configured with
+ * struct wpa_driver_ops::set_key using alg = WPA_ALG_PMK */
+#define WPA_DRIVER_FLAGS_4WAY_HANDSHAKE 0x00000008
+/** Driver is for a wired Ethernet interface */
+#define WPA_DRIVER_FLAGS_WIRED         0x00000010
+/** Driver provides separate commands for authentication and association (SME in
+ * wpa_supplicant). */
+#define WPA_DRIVER_FLAGS_SME           0x00000020
+/** Driver supports AP mode */
+#define WPA_DRIVER_FLAGS_AP            0x00000040
+/** Driver needs static WEP key setup after association has been completed */
+#define WPA_DRIVER_FLAGS_SET_KEYS_AFTER_ASSOC_DONE     0x00000080
+/** Driver supports dynamic HT 20/40 MHz channel changes during BSS lifetime */
+#define WPA_DRIVER_FLAGS_HT_2040_COEX                  0x00000100
+/** Driver supports concurrent P2P operations */
+#define WPA_DRIVER_FLAGS_P2P_CONCURRENT        0x00000200
+/**
+ * Driver uses the initial interface as a dedicated management interface, i.e.,
+ * it cannot be used for P2P group operations or non-P2P purposes.
+ */
+#define WPA_DRIVER_FLAGS_P2P_DEDICATED_INTERFACE       0x00000400
+/** This interface is P2P capable (P2P GO or P2P Client) */
+#define WPA_DRIVER_FLAGS_P2P_CAPABLE   0x00000800
+/** Driver supports station and key removal when stopping an AP */
+#define WPA_DRIVER_FLAGS_AP_TEARDOWN_SUPPORT           0x00001000
+/**
+ * Driver uses the initial interface for P2P management interface and non-P2P
+ * purposes (e.g., connect to infra AP), but this interface cannot be used for
+ * P2P group operations.
+ */
+#define WPA_DRIVER_FLAGS_P2P_MGMT_AND_NON_P2P          0x00002000
+/**
+ * Driver is known to use sane error codes, i.e., when it indicates that
+ * something (e.g., association) fails, there was indeed a failure and the
+ * operation does not end up getting completed successfully later.
+ */
+#define WPA_DRIVER_FLAGS_SANE_ERROR_CODES              0x00004000
+/** Driver supports off-channel TX */
+#define WPA_DRIVER_FLAGS_OFFCHANNEL_TX                 0x00008000
+/** Driver indicates TX status events for EAPOL Data frames */
+#define WPA_DRIVER_FLAGS_EAPOL_TX_STATUS               0x00010000
+/** Driver indicates TX status events for Deauth/Disassoc frames */
+#define WPA_DRIVER_FLAGS_DEAUTH_TX_STATUS              0x00020000
+/** Driver supports roaming (BSS selection) in firmware */
+#define WPA_DRIVER_FLAGS_BSS_SELECTION                 0x00040000
+/** Driver supports operating as a TDLS peer */
+#define WPA_DRIVER_FLAGS_TDLS_SUPPORT                  0x00080000
+/** Driver requires external TDLS setup/teardown/discovery */
+#define WPA_DRIVER_FLAGS_TDLS_EXTERNAL_SETUP           0x00100000
+/** Driver indicates support for Probe Response offloading in AP mode */
+#define WPA_DRIVER_FLAGS_PROBE_RESP_OFFLOAD            0x00200000
+/** Driver supports U-APSD in AP mode */
+#define WPA_DRIVER_FLAGS_AP_UAPSD                      0x00400000
+/** Driver supports inactivity timer in AP mode */
+#define WPA_DRIVER_FLAGS_INACTIVITY_TIMER              0x00800000
+/** Driver expects user space implementation of MLME in AP mode */
+#define WPA_DRIVER_FLAGS_AP_MLME                       0x01000000
+/** Driver supports SAE with user space SME */
+#define WPA_DRIVER_FLAGS_SAE                           0x02000000
+/** Driver makes use of OBSS scan mechanism in wpa_supplicant */
+#define WPA_DRIVER_FLAGS_OBSS_SCAN                     0x04000000
+/** Driver supports IBSS (Ad-hoc) mode */
+#define WPA_DRIVER_FLAGS_IBSS                          0x08000000
+/** Driver supports radar detection */
+#define WPA_DRIVER_FLAGS_RADAR                         0x10000000
+/** Driver supports a dedicated interface for P2P Device */
+#define WPA_DRIVER_FLAGS_DEDICATED_P2P_DEVICE          0x20000000
+/** Driver supports QoS Mapping */
+#define WPA_DRIVER_FLAGS_QOS_MAPPING                   0x40000000
+/** Driver supports CSA in AP mode */
+#define WPA_DRIVER_FLAGS_AP_CSA                                0x80000000
+/** Driver supports mesh */
+#define WPA_DRIVER_FLAGS_MESH                  0x0000000100000000ULL
+/** Driver support ACS offload */
+#define WPA_DRIVER_FLAGS_ACS_OFFLOAD           0x0000000200000000ULL
+/** Driver supports key management offload */
+#define WPA_DRIVER_FLAGS_KEY_MGMT_OFFLOAD      0x0000000400000000ULL
+/** Driver supports TDLS channel switching */
+#define WPA_DRIVER_FLAGS_TDLS_CHANNEL_SWITCH   0x0000000800000000ULL
+/** Driver supports IBSS with HT datarates */
+#define WPA_DRIVER_FLAGS_HT_IBSS               0x0000001000000000ULL
+/** Driver supports IBSS with VHT datarates */
+#define WPA_DRIVER_FLAGS_VHT_IBSS              0x0000002000000000ULL
+/** Driver supports automatic band selection */
+#define WPA_DRIVER_FLAGS_SUPPORT_HW_MODE_ANY   0x0000004000000000ULL
+       u64 flags;
+
+#define WPA_DRIVER_SMPS_MODE_STATIC                    0x00000001
+#define WPA_DRIVER_SMPS_MODE_DYNAMIC                   0x00000002
+       unsigned int smps_modes;
+
+       unsigned int wmm_ac_supported:1;
+
+       unsigned int mac_addr_rand_scan_supported:1;
+       unsigned int mac_addr_rand_sched_scan_supported:1;
+
+       /** Maximum number of supported active probe SSIDs */
+       int max_scan_ssids;
+
+       /** Maximum number of supported active probe SSIDs for sched_scan */
+       int max_sched_scan_ssids;
+
+       /** Whether sched_scan (offloaded scanning) is supported */
+       int sched_scan_supported;
+
+       /** Maximum number of supported match sets for sched_scan */
+       int max_match_sets;
+
+       /**
+        * max_remain_on_chan - Maximum remain-on-channel duration in msec
+        */
+       unsigned int max_remain_on_chan;
+
+       /**
+        * max_stations - Maximum number of associated stations the driver
+        * supports in AP mode
+        */
+       unsigned int max_stations;
+
+       /**
+        * probe_resp_offloads - Bitmap of supported protocols by the driver
+        * for Probe Response offloading.
+        */
+/** Driver Probe Response offloading support for WPS ver. 1 */
+#define WPA_DRIVER_PROBE_RESP_OFFLOAD_WPS              0x00000001
+/** Driver Probe Response offloading support for WPS ver. 2 */
+#define WPA_DRIVER_PROBE_RESP_OFFLOAD_WPS2             0x00000002
+/** Driver Probe Response offloading support for P2P */
+#define WPA_DRIVER_PROBE_RESP_OFFLOAD_P2P              0x00000004
+/** Driver Probe Response offloading support for IEEE 802.11u (Interworking) */
+#define WPA_DRIVER_PROBE_RESP_OFFLOAD_INTERWORKING     0x00000008
+       unsigned int probe_resp_offloads;
+
+       unsigned int max_acl_mac_addrs;
+
+       /**
+        * Number of supported concurrent channels
+        */
+       unsigned int num_multichan_concurrent;
+
+       /**
+        * extended_capa - extended capabilities in driver/device
+        *
+        * Must be allocated and freed by driver and the pointers must be
+        * valid for the lifetime of the driver, i.e., freed in deinit()
+        */
+       const u8 *extended_capa, *extended_capa_mask;
+       unsigned int extended_capa_len;
+
+       struct wowlan_triggers wowlan_triggers;
+
+/** Driver adds the DS Params Set IE in Probe Request frames */
+#define WPA_DRIVER_FLAGS_DS_PARAM_SET_IE_IN_PROBES     0x00000001
+/** Driver adds the WFA TPC IE in Probe Request frames */
+#define WPA_DRIVER_FLAGS_WFA_TPC_IE_IN_PROBES          0x00000002
+/** Driver handles quiet period requests */
+#define WPA_DRIVER_FLAGS_QUIET                         0x00000004
+/**
+ * Driver is capable of inserting the current TX power value into the body of
+ * transmitted frames.
+ * Background: Some Action frames include a TPC Report IE. This IE contains a
+ * TX power field, which has to be updated by lower layers. One such Action
+ * frame is Link Measurement Report (part of RRM). Another is TPC Report (part
+ * of spectrum management). Note that this insertion takes place at a fixed
+ * offset, namely the 6th byte in the Action frame body.
+ */
+#define WPA_DRIVER_FLAGS_TX_POWER_INSERTION            0x00000008
+       u32 rrm_flags;
+
+       /* Driver concurrency capabilities */
+       unsigned int conc_capab;
+       /* Maximum number of concurrent channels on 2.4 GHz */
+       unsigned int max_conc_chan_2_4;
+       /* Maximum number of concurrent channels on 5 GHz */
+       unsigned int max_conc_chan_5_0;
+};
+
+
+struct hostapd_data;
+
+struct hostap_sta_driver_data {
+       unsigned long rx_packets, tx_packets, rx_bytes, tx_bytes;
+       unsigned long current_tx_rate;
+       unsigned long inactive_msec;
+       unsigned long flags;
+       unsigned long num_ps_buf_frames;
+       unsigned long tx_retry_failed;
+       unsigned long tx_retry_count;
+       int last_rssi;
+       int last_ack_rssi;
+};
+
+struct hostapd_sta_add_params {
+       const u8 *addr;
+       u16 aid;
+       u16 capability;
+       const u8 *supp_rates;
+       size_t supp_rates_len;
+       u16 listen_interval;
+       const struct ieee80211_ht_capabilities *ht_capabilities;
+       const struct ieee80211_vht_capabilities *vht_capabilities;
+       int vht_opmode_enabled;
+       u8 vht_opmode;
+       u32 flags; /* bitmask of WPA_STA_* flags */
+       u32 flags_mask; /* unset bits in flags */
+#ifdef CONFIG_MESH
+       enum mesh_plink_state plink_state;
+#endif /* CONFIG_MESH */
+       int set; /* Set STA parameters instead of add */
+       u8 qosinfo;
+       const u8 *ext_capab;
+       size_t ext_capab_len;
+       const u8 *supp_channels;
+       size_t supp_channels_len;
+       const u8 *supp_oper_classes;
+       size_t supp_oper_classes_len;
+};
+
+struct mac_address {
+       u8 addr[ETH_ALEN];
+};
+
+struct hostapd_acl_params {
+       u8 acl_policy;
+       unsigned int num_mac_acl;
+       struct mac_address mac_acl[0];
+};
+
+enum wpa_driver_if_type {
+       /**
+        * WPA_IF_STATION - Station mode interface
+        */
+       WPA_IF_STATION,
+
+       /**
+        * WPA_IF_AP_VLAN - AP mode VLAN interface
+        *
+        * This interface shares its address and Beacon frame with the main
+        * BSS.
+        */
+       WPA_IF_AP_VLAN,
+
+       /**
+        * WPA_IF_AP_BSS - AP mode BSS interface
+        *
+        * This interface has its own address and Beacon frame.
+        */
+       WPA_IF_AP_BSS,
+
+       /**
+        * WPA_IF_P2P_GO - P2P Group Owner
+        */
+       WPA_IF_P2P_GO,
+
+       /**
+        * WPA_IF_P2P_CLIENT - P2P Client
+        */
+       WPA_IF_P2P_CLIENT,
+
+       /**
+        * WPA_IF_P2P_GROUP - P2P Group interface (will become either
+        * WPA_IF_P2P_GO or WPA_IF_P2P_CLIENT, but the role is not yet known)
+        */
+       WPA_IF_P2P_GROUP,
+
+       /**
+        * WPA_IF_P2P_DEVICE - P2P Device interface is used to indentify the
+        * abstracted P2P Device function in the driver
+        */
+       WPA_IF_P2P_DEVICE,
+
+       /*
+        * WPA_IF_MESH - Mesh interface
+        */
+       WPA_IF_MESH,
+
+       /*
+        * WPA_IF_TDLS - TDLS offchannel interface (used for pref freq only)
+        */
+       WPA_IF_TDLS,
+
+       /*
+        * WPA_IF_IBSS - IBSS interface (used for pref freq only)
+        */
+       WPA_IF_IBSS,
+};
+
+struct wpa_init_params {
+       void *global_priv;
+       const u8 *bssid;
+       const char *ifname;
+       const char *driver_params;
+       int use_pae_group_addr;
+       char **bridge;
+       size_t num_bridge;
+
+       u8 *own_addr; /* buffer for writing own MAC address */
+};
+
+
+struct wpa_bss_params {
+       /** Interface name (for multi-SSID/VLAN support) */
+       const char *ifname;
+       /** Whether IEEE 802.1X or WPA/WPA2 is enabled */
+       int enabled;
+
+       int wpa;
+       int ieee802_1x;
+       int wpa_group;
+       int wpa_pairwise;
+       int wpa_key_mgmt;
+       int rsn_preauth;
+       enum mfp_options ieee80211w;
+};
+
+#define WPA_STA_AUTHORIZED BIT(0)
+#define WPA_STA_WMM BIT(1)
+#define WPA_STA_SHORT_PREAMBLE BIT(2)
+#define WPA_STA_MFP BIT(3)
+#define WPA_STA_TDLS_PEER BIT(4)
+#define WPA_STA_AUTHENTICATED BIT(5)
+
+enum tdls_oper {
+       TDLS_DISCOVERY_REQ,
+       TDLS_SETUP,
+       TDLS_TEARDOWN,
+       TDLS_ENABLE_LINK,
+       TDLS_DISABLE_LINK,
+       TDLS_ENABLE,
+       TDLS_DISABLE
+};
+
+enum wnm_oper {
+       WNM_SLEEP_ENTER_CONFIRM,
+       WNM_SLEEP_ENTER_FAIL,
+       WNM_SLEEP_EXIT_CONFIRM,
+       WNM_SLEEP_EXIT_FAIL,
+       WNM_SLEEP_TFS_REQ_IE_ADD,   /* STA requests driver to add TFS req IE */
+       WNM_SLEEP_TFS_REQ_IE_NONE,  /* STA requests empty TFS req IE */
+       WNM_SLEEP_TFS_REQ_IE_SET,   /* AP requests driver to set TFS req IE for
+                                    * a STA */
+       WNM_SLEEP_TFS_RESP_IE_ADD,  /* AP requests driver to add TFS resp IE
+                                    * for a STA */
+       WNM_SLEEP_TFS_RESP_IE_NONE, /* AP requests empty TFS resp IE */
+       WNM_SLEEP_TFS_RESP_IE_SET,  /* AP requests driver to set TFS resp IE
+                                    * for a STA */
+       WNM_SLEEP_TFS_IE_DEL        /* AP delete the TFS IE */
+};
+
+/* enum chan_width - Channel width definitions */
+enum chan_width {
+       CHAN_WIDTH_20_NOHT,
+       CHAN_WIDTH_20,
+       CHAN_WIDTH_40,
+       CHAN_WIDTH_80,
+       CHAN_WIDTH_80P80,
+       CHAN_WIDTH_160,
+       CHAN_WIDTH_UNKNOWN
+};
+
+/**
+ * struct wpa_signal_info - Information about channel signal quality
+ */
+struct wpa_signal_info {
+       u32 frequency;
+       int above_threshold;
+       int current_signal;
+       int avg_signal;
+       int avg_beacon_signal;
+       int current_noise;
+       int current_txrate;
+       enum chan_width chanwidth;
+       int center_frq1;
+       int center_frq2;
+};
+
+/**
+ * struct beacon_data - Beacon data
+ * @head: Head portion of Beacon frame (before TIM IE)
+ * @tail: Tail portion of Beacon frame (after TIM IE)
+ * @beacon_ies: Extra information element(s) to add into Beacon frames or %NULL
+ * @proberesp_ies: Extra information element(s) to add into Probe Response
+ *     frames or %NULL
+ * @assocresp_ies: Extra information element(s) to add into (Re)Association
+ *     Response frames or %NULL
+ * @probe_resp: Probe Response frame template
+ * @head_len: Length of @head
+ * @tail_len: Length of @tail
+ * @beacon_ies_len: Length of beacon_ies in octets
+ * @proberesp_ies_len: Length of proberesp_ies in octets
+ * @proberesp_ies_len: Length of proberesp_ies in octets
+ * @probe_resp_len: Length of probe response template (@probe_resp)
+ */
+struct beacon_data {
+       u8 *head, *tail;
+       u8 *beacon_ies;
+       u8 *proberesp_ies;
+       u8 *assocresp_ies;
+       u8 *probe_resp;
+
+       size_t head_len, tail_len;
+       size_t beacon_ies_len;
+       size_t proberesp_ies_len;
+       size_t assocresp_ies_len;
+       size_t probe_resp_len;
+};
+
+/**
+ * struct csa_settings - Settings for channel switch command
+ * @cs_count: Count in Beacon frames (TBTT) to perform the switch
+ * @block_tx: 1 - block transmission for CSA period
+ * @freq_params: Next channel frequency parameter
+ * @beacon_csa: Beacon/probe resp/asooc resp info for CSA period
+ * @beacon_after: Next beacon/probe resp/asooc resp info
+ * @counter_offset_beacon: Offset to the count field in beacon's tail
+ * @counter_offset_presp: Offset to the count field in probe resp.
+ */
+struct csa_settings {
+       u8 cs_count;
+       u8 block_tx;
+
+       struct hostapd_freq_params freq_params;
+       struct beacon_data beacon_csa;
+       struct beacon_data beacon_after;
+
+       u16 counter_offset_beacon;
+       u16 counter_offset_presp;
+};
+
+/* TDLS peer capabilities for send_tdls_mgmt() */
+enum tdls_peer_capability {
+       TDLS_PEER_HT = BIT(0),
+       TDLS_PEER_VHT = BIT(1),
+       TDLS_PEER_WMM = BIT(2),
+};
+
+/* valid info in the wmm_params struct */
+enum wmm_params_valid_info {
+       WMM_PARAMS_UAPSD_QUEUES_INFO = BIT(0),
+};
+
+/**
+ * struct wmm_params - WMM parameterss configured for this association
+ * @info_bitmap: Bitmap of valid wmm_params info; indicates what fields
+ *     of the struct contain valid information.
+ * @uapsd_queues: Bitmap of ACs configured for uapsd (valid only if
+ *     %WMM_PARAMS_UAPSD_QUEUES_INFO is set)
+ */
+struct wmm_params {
+       u8 info_bitmap;
+       u8 uapsd_queues;
+};
+
+#ifdef CONFIG_MACSEC
+struct macsec_init_params {
+       Boolean always_include_sci;
+       Boolean use_es;
+       Boolean use_scb;
+};
+#endif /* CONFIG_MACSEC */
+
+enum drv_br_port_attr {
+       DRV_BR_PORT_ATTR_PROXYARP,
+       DRV_BR_PORT_ATTR_HAIRPIN_MODE,
+};
+
+enum drv_br_net_param {
+       DRV_BR_NET_PARAM_GARP_ACCEPT,
+       DRV_BR_MULTICAST_SNOOPING,
+};
+
+struct drv_acs_params {
+       /* Selected mode (HOSTAPD_MODE_*) */
+       enum hostapd_hw_mode hw_mode;
+
+       /* Indicates whether HT is enabled */
+       int ht_enabled;
+
+       /* Indicates whether HT40 is enabled */
+       int ht40_enabled;
+
+       /* Indicates whether VHT is enabled */
+       int vht_enabled;
+
+       /* Configured ACS channel width */
+       u16 ch_width;
+
+       /* ACS channel list info */
+       unsigned int ch_list_len;
+       const u8 *ch_list;
+       const int *freq_list;
+};
+
+
+/**
+ * struct wpa_driver_ops - Driver interface API definition
+ *
+ * This structure defines the API that each driver interface needs to implement
+ * for core wpa_supplicant code. All driver specific functionality is captured
+ * in this wrapper.
+ */
+struct wpa_driver_ops {
+       /** Name of the driver interface */
+       const char *name;
+       /** One line description of the driver interface */
+       const char *desc;
+
+       /**
+        * get_bssid - Get the current BSSID
+        * @priv: private driver interface data
+        * @bssid: buffer for BSSID (ETH_ALEN = 6 bytes)
+        *
+        * Returns: 0 on success, -1 on failure
+        *
+        * Query kernel driver for the current BSSID and copy it to bssid.
+        * Setting bssid to 00:00:00:00:00:00 is recommended if the STA is not
+        * associated.
+        */
+       int (*get_bssid)(void *priv, u8 *bssid);
+
+       /**
+        * get_ssid - Get the current SSID
+        * @priv: private driver interface data
+        * @ssid: buffer for SSID (at least 32 bytes)
+        *
+        * Returns: Length of the SSID on success, -1 on failure
+        *
+        * Query kernel driver for the current SSID and copy it to ssid.
+        * Returning zero is recommended if the STA is not associated.
+        *
+        * Note: SSID is an array of octets, i.e., it is not nul terminated and
+        * can, at least in theory, contain control characters (including nul)
+        * and as such, should be processed as binary data, not a printable
+        * string.
+        */
+       int (*get_ssid)(void *priv, u8 *ssid);
+
+       /**
+        * set_key - Configure encryption key
+        * @ifname: Interface name (for multi-SSID/VLAN support)
+        * @priv: private driver interface data
+        * @alg: encryption algorithm (%WPA_ALG_NONE, %WPA_ALG_WEP,
+        *      %WPA_ALG_TKIP, %WPA_ALG_CCMP, %WPA_ALG_IGTK, %WPA_ALG_PMK,
+        *      %WPA_ALG_GCMP, %WPA_ALG_GCMP_256, %WPA_ALG_CCMP_256,
+        *      %WPA_ALG_BIP_GMAC_128, %WPA_ALG_BIP_GMAC_256,
+        *      %WPA_ALG_BIP_CMAC_256);
+        *      %WPA_ALG_NONE clears the key.
+        * @addr: Address of the peer STA (BSSID of the current AP when setting
+        *      pairwise key in station mode), ff:ff:ff:ff:ff:ff for
+        *      broadcast keys, %NULL for default keys that are used both for
+        *      broadcast and unicast; when clearing keys, %NULL is used to
+        *      indicate that both the broadcast-only and default key of the
+        *      specified key index is to be cleared
+        * @key_idx: key index (0..3), usually 0 for unicast keys; 0..4095 for
+        *      IGTK
+        * @set_tx: configure this key as the default Tx key (only used when
+        *      driver does not support separate unicast/individual key
+        * @seq: sequence number/packet number, seq_len octets, the next
+        *      packet number to be used for in replay protection; configured
+        *      for Rx keys (in most cases, this is only used with broadcast
+        *      keys and set to zero for unicast keys); %NULL if not set
+        * @seq_len: length of the seq, depends on the algorithm:
+        *      TKIP: 6 octets, CCMP/GCMP: 6 octets, IGTK: 6 octets
+        * @key: key buffer; TKIP: 16-byte temporal key, 8-byte Tx Mic key,
+        *      8-byte Rx Mic Key
+        * @key_len: length of the key buffer in octets (WEP: 5 or 13,
+        *      TKIP: 32, CCMP/GCMP: 16, IGTK: 16)
+        *
+        * Returns: 0 on success, -1 on failure
+        *
+        * Configure the given key for the kernel driver. If the driver
+        * supports separate individual keys (4 default keys + 1 individual),
+        * addr can be used to determine whether the key is default or
+        * individual. If only 4 keys are supported, the default key with key
+        * index 0 is used as the individual key. STA must be configured to use
+        * it as the default Tx key (set_tx is set) and accept Rx for all the
+        * key indexes. In most cases, WPA uses only key indexes 1 and 2 for
+        * broadcast keys, so key index 0 is available for this kind of
+        * configuration.
+        *
+        * Please note that TKIP keys include separate TX and RX MIC keys and
+        * some drivers may expect them in different order than wpa_supplicant
+        * is using. If the TX/RX keys are swapped, all TKIP encrypted packets
+        * will trigger Michael MIC errors. This can be fixed by changing the
+        * order of MIC keys by swapping te bytes 16..23 and 24..31 of the key
+        * in driver_*.c set_key() implementation, see driver_ndis.c for an
+        * example on how this can be done.
+        */
+       int (*set_key)(const char *ifname, void *priv, enum wpa_alg alg,
+                      const u8 *addr, int key_idx, int set_tx,
+                      const u8 *seq, size_t seq_len,
+                      const u8 *key, size_t key_len);
+
+       /**
+        * init - Initialize driver interface
+        * @ctx: context to be used when calling wpa_supplicant functions,
+        * e.g., wpa_supplicant_event()
+        * @ifname: interface name, e.g., wlan0
+        *
+        * Returns: Pointer to private data, %NULL on failure
+        *
+        * Initialize driver interface, including event processing for kernel
+        * driver events (e.g., associated, scan results, Michael MIC failure).
+        * This function can allocate a private configuration data area for
+        * @ctx, file descriptor, interface name, etc. information that may be
+        * needed in future driver operations. If this is not used, non-NULL
+        * value will need to be returned because %NULL is used to indicate
+        * failure. The returned value will be used as 'void *priv' data for
+        * all other driver_ops functions.
+        *
+        * The main event loop (eloop.c) of wpa_supplicant can be used to
+        * register callback for read sockets (eloop_register_read_sock()).
+        *
+        * See below for more information about events and
+        * wpa_supplicant_event() function.
+        */
+       void * (*init)(void *ctx, const char *ifname);
+
+       /**
+        * deinit - Deinitialize driver interface
+        * @priv: private driver interface data from init()
+        *
+        * Shut down driver interface and processing of driver events. Free
+        * private data buffer if one was allocated in init() handler.
+        */
+       void (*deinit)(void *priv);
+
+       /**
+        * set_param - Set driver configuration parameters
+        * @priv: private driver interface data from init()
+        * @param: driver specific configuration parameters
+        *
+        * Returns: 0 on success, -1 on failure
+        *
+        * Optional handler for notifying driver interface about configuration
+        * parameters (driver_param).
+        */
+       int (*set_param)(void *priv, const char *param);
+
+       /**
+        * set_countermeasures - Enable/disable TKIP countermeasures
+        * @priv: private driver interface data
+        * @enabled: 1 = countermeasures enabled, 0 = disabled
+        *
+        * Returns: 0 on success, -1 on failure
+        *
+        * Configure TKIP countermeasures. When these are enabled, the driver
+        * should drop all received and queued frames that are using TKIP.
+        */
+       int (*set_countermeasures)(void *priv, int enabled);
+
+       /**
+        * deauthenticate - Request driver to deauthenticate
+        * @priv: private driver interface data
+        * @addr: peer address (BSSID of the AP)
+        * @reason_code: 16-bit reason code to be sent in the deauthentication
+        *      frame
+        *
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*deauthenticate)(void *priv, const u8 *addr, int reason_code);
+
+       /**
+        * associate - Request driver to associate
+        * @priv: private driver interface data
+        * @params: association parameters
+        *
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*associate)(void *priv,
+                        struct wpa_driver_associate_params *params);
+
+       /**
+        * add_pmkid - Add PMKSA cache entry to the driver
+        * @priv: private driver interface data
+        * @bssid: BSSID for the PMKSA cache entry
+        * @pmkid: PMKID for the PMKSA cache entry
+        *
+        * Returns: 0 on success, -1 on failure
+        *
+        * This function is called when a new PMK is received, as a result of
+        * either normal authentication or RSN pre-authentication.
+        *
+        * If the driver generates RSN IE, i.e., it does not use wpa_ie in
+        * associate(), add_pmkid() can be used to add new PMKSA cache entries
+        * in the driver. If the driver uses wpa_ie from wpa_supplicant, this
+        * driver_ops function does not need to be implemented. Likewise, if
+        * the driver does not support WPA, this function is not needed.
+        */
+       int (*add_pmkid)(void *priv, const u8 *bssid, const u8 *pmkid);
+
+       /**
+        * remove_pmkid - Remove PMKSA cache entry to the driver
+        * @priv: private driver interface data
+        * @bssid: BSSID for the PMKSA cache entry
+        * @pmkid: PMKID for the PMKSA cache entry
+        *
+        * Returns: 0 on success, -1 on failure
+        *
+        * This function is called when the supplicant drops a PMKSA cache
+        * entry for any reason.
+        *
+        * If the driver generates RSN IE, i.e., it does not use wpa_ie in
+        * associate(), remove_pmkid() can be used to synchronize PMKSA caches
+        * between the driver and wpa_supplicant. If the driver uses wpa_ie
+        * from wpa_supplicant, this driver_ops function does not need to be
+        * implemented. Likewise, if the driver does not support WPA, this
+        * function is not needed.
+        */
+       int (*remove_pmkid)(void *priv, const u8 *bssid, const u8 *pmkid);
+
+       /**
+        * flush_pmkid - Flush PMKSA cache
+        * @priv: private driver interface data
+        *
+        * Returns: 0 on success, -1 on failure
+        *
+        * This function is called when the supplicant drops all PMKSA cache
+        * entries for any reason.
+        *
+        * If the driver generates RSN IE, i.e., it does not use wpa_ie in
+        * associate(), remove_pmkid() can be used to synchronize PMKSA caches
+        * between the driver and wpa_supplicant. If the driver uses wpa_ie
+        * from wpa_supplicant, this driver_ops function does not need to be
+        * implemented. Likewise, if the driver does not support WPA, this
+        * function is not needed.
+        */
+       int (*flush_pmkid)(void *priv);
+
+       /**
+        * get_capa - Get driver capabilities
+        * @priv: private driver interface data
+        *
+        * Returns: 0 on success, -1 on failure
+        *
+        * Get driver/firmware/hardware capabilities.
+        */
+       int (*get_capa)(void *priv, struct wpa_driver_capa *capa);
+
+       /**
+        * poll - Poll driver for association information
+        * @priv: private driver interface data
+        *
+        * This is an option callback that can be used when the driver does not
+        * provide event mechanism for association events. This is called when
+        * receiving WPA EAPOL-Key messages that require association
+        * information. The driver interface is supposed to generate associnfo
+        * event before returning from this callback function. In addition, the
+        * driver interface should generate an association event after having
+        * sent out associnfo.
+        */
+       void (*poll)(void *priv);
+
+       /**
+        * get_ifname - Get interface name
+        * @priv: private driver interface data
+        *
+        * Returns: Pointer to the interface name. This can differ from the
+        * interface name used in init() call. Init() is called first.
+        *
+        * This optional function can be used to allow the driver interface to
+        * replace the interface name with something else, e.g., based on an
+        * interface mapping from a more descriptive name.
+        */
+       const char * (*get_ifname)(void *priv);
+
+       /**
+        * get_mac_addr - Get own MAC address
+        * @priv: private driver interface data
+        *
+        * Returns: Pointer to own MAC address or %NULL on failure
+        *
+        * This optional function can be used to get the own MAC address of the
+        * device from the driver interface code. This is only needed if the
+        * l2_packet implementation for the OS does not provide easy access to
+        * a MAC address. */
+       const u8 * (*get_mac_addr)(void *priv);
+
+       /**
+        * set_operstate - Sets device operating state to DORMANT or UP
+        * @priv: private driver interface data
+        * @state: 0 = dormant, 1 = up
+        * Returns: 0 on success, -1 on failure
+        *
+        * This is an optional function that can be used on operating systems
+        * that support a concept of controlling network device state from user
+        * space applications. This function, if set, gets called with
+        * state = 1 when authentication has been completed and with state = 0
+        * when connection is lost.
+        */
+       int (*set_operstate)(void *priv, int state);
+
+       /**
+        * mlme_setprotection - MLME-SETPROTECTION.request primitive
+        * @priv: Private driver interface data
+        * @addr: Address of the station for which to set protection (may be
+        * %NULL for group keys)
+        * @protect_type: MLME_SETPROTECTION_PROTECT_TYPE_*
+        * @key_type: MLME_SETPROTECTION_KEY_TYPE_*
+        * Returns: 0 on success, -1 on failure
+        *
+        * This is an optional function that can be used to set the driver to
+        * require protection for Tx and/or Rx frames. This uses the layer
+        * interface defined in IEEE 802.11i-2004 clause 10.3.22.1
+        * (MLME-SETPROTECTION.request). Many drivers do not use explicit
+        * set protection operation; instead, they set protection implicitly
+        * based on configured keys.
+        */
+       int (*mlme_setprotection)(void *priv, const u8 *addr, int protect_type,
+                                 int key_type);
+
+       /**
+        * get_hw_feature_data - Get hardware support data (channels and rates)
+        * @priv: Private driver interface data
+        * @num_modes: Variable for returning the number of returned modes
+        * flags: Variable for returning hardware feature flags
+        * Returns: Pointer to allocated hardware data on success or %NULL on
+        * failure. Caller is responsible for freeing this.
+        */
+       struct hostapd_hw_modes * (*get_hw_feature_data)(void *priv,
+                                                        u16 *num_modes,
+                                                        u16 *flags);
+
+       /**
+        * send_mlme - Send management frame from MLME
+        * @priv: Private driver interface data
+        * @data: IEEE 802.11 management frame with IEEE 802.11 header
+        * @data_len: Size of the management frame
+        * @noack: Do not wait for this frame to be acked (disable retries)
+        * @freq: Frequency (in MHz) to send the frame on, or 0 to let the
+        * driver decide
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*send_mlme)(void *priv, const u8 *data, size_t data_len,
+                        int noack, unsigned int freq);
+
+       /**
+        * update_ft_ies - Update FT (IEEE 802.11r) IEs
+        * @priv: Private driver interface data
+        * @md: Mobility domain (2 octets) (also included inside ies)
+        * @ies: FT IEs (MDIE, FTIE, ...) or %NULL to remove IEs
+        * @ies_len: Length of FT IEs in bytes
+        * Returns: 0 on success, -1 on failure
+        *
+        * The supplicant uses this callback to let the driver know that keying
+        * material for FT is available and that the driver can use the
+        * provided IEs in the next message in FT authentication sequence.
+        *
+        * This function is only needed for driver that support IEEE 802.11r
+        * (Fast BSS Transition).
+        */
+       int (*update_ft_ies)(void *priv, const u8 *md, const u8 *ies,
+                            size_t ies_len);
+
+       /**
+        * get_scan_results2 - Fetch the latest scan results
+        * @priv: private driver interface data
+        *
+        * Returns: Allocated buffer of scan results (caller is responsible for
+        * freeing the data structure) on success, NULL on failure
+        */
+        struct wpa_scan_results * (*get_scan_results2)(void *priv);
+
+       /**
+        * set_country - Set country
+        * @priv: Private driver interface data
+        * @alpha2: country to which to switch to
+        * Returns: 0 on success, -1 on failure
+        *
+        * This function is for drivers which support some form
+        * of setting a regulatory domain.
+        */
+       int (*set_country)(void *priv, const char *alpha2);
+
+       /**
+        * get_country - Get country
+        * @priv: Private driver interface data
+        * @alpha2: Buffer for returning country code (at least 3 octets)
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*get_country)(void *priv, char *alpha2);
+
+       /**
+        * global_init - Global driver initialization
+        * Returns: Pointer to private data (global), %NULL on failure
+        *
+        * This optional function is called to initialize the driver wrapper
+        * for global data, i.e., data that applies to all interfaces. If this
+        * function is implemented, global_deinit() will also need to be
+        * implemented to free the private data. The driver will also likely
+        * use init2() function instead of init() to get the pointer to global
+        * data available to per-interface initializer.
+        */
+       void * (*global_init)(void);
+
+       /**
+        * global_deinit - Global driver deinitialization
+        * @priv: private driver global data from global_init()
+        *
+        * Terminate any global driver related functionality and free the
+        * global data structure.
+        */
+       void (*global_deinit)(void *priv);
+
+       /**
+        * init2 - Initialize driver interface (with global data)
+        * @ctx: context to be used when calling wpa_supplicant functions,
+        * e.g., wpa_supplicant_event()
+        * @ifname: interface name, e.g., wlan0
+        * @global_priv: private driver global data from global_init()
+        * Returns: Pointer to private data, %NULL on failure
+        *
+        * This function can be used instead of init() if the driver wrapper
+        * uses global data.
+        */
+       void * (*init2)(void *ctx, const char *ifname, void *global_priv);
+
+       /**
+        * get_interfaces - Get information about available interfaces
+        * @global_priv: private driver global data from global_init()
+        * Returns: Allocated buffer of interface information (caller is
+        * responsible for freeing the data structure) on success, NULL on
+        * failure
+        */
+       struct wpa_interface_info * (*get_interfaces)(void *global_priv);
 
        /**
-        * get_bssid - Get the current BSSID
+        * scan2 - Request the driver to initiate scan
         * @priv: private driver interface data
-        * @bssid: buffer for BSSID (ETH_ALEN = 6 bytes)
+        * @params: Scan parameters
         *
         * Returns: 0 on success, -1 on failure
         *
-        * Query kernel driver for the current BSSID and copy it to bssid.
-        * Setting bssid to 00:00:00:00:00:00 is recommended if the STA is not
-        * associated.
+        * Once the scan results are ready, the driver should report scan
+        * results event for wpa_supplicant which will eventually request the
+        * results with wpa_driver_get_scan_results2().
         */
-       int (*get_bssid)(void *priv, u8 *bssid);
+       int (*scan2)(void *priv, struct wpa_driver_scan_params *params);
 
        /**
-        * get_ssid - Get the current SSID
+        * authenticate - Request driver to authenticate
         * @priv: private driver interface data
-        * @ssid: buffer for SSID (at least 32 bytes)
+        * @params: authentication parameters
+        * Returns: 0 on success, -1 on failure
         *
-        * Returns: Length of the SSID on success, -1 on failure
+        * This is an optional function that can be used with drivers that
+        * support separate authentication and association steps, i.e., when
+        * wpa_supplicant can act as the SME. If not implemented, associate()
+        * function is expected to take care of IEEE 802.11 authentication,
+        * too.
+        */
+       int (*authenticate)(void *priv,
+                           struct wpa_driver_auth_params *params);
+
+       /**
+        * set_ap - Set Beacon and Probe Response information for AP mode
+        * @priv: Private driver interface data
+        * @params: Parameters to use in AP mode
         *
-        * Query kernel driver for the current SSID and copy it to ssid.
-        * Returning zero is recommended if the STA is not associated.
+        * This function is used to configure Beacon template and/or extra IEs
+        * to add for Beacon and Probe Response frames for the driver in
+        * AP mode. The driver is responsible for building the full Beacon
+        * frame by concatenating the head part with TIM IE generated by the
+        * driver/firmware and finishing with the tail part. Depending on the
+        * driver architectue, this can be done either by using the full
+        * template or the set of additional IEs (e.g., WPS and P2P IE).
+        * Similarly, Probe Response processing depends on the driver design.
+        * If the driver (or firmware) takes care of replying to Probe Request
+        * frames, the extra IEs provided here needs to be added to the Probe
+        * Response frames.
         *
-        * Note: SSID is an array of octets, i.e., it is not nul terminated and
-        * can, at least in theory, contain control characters (including nul)
-        * and as such, should be processed as binary data, not a printable
-        * string.
+        * Returns: 0 on success, -1 on failure
         */
-       int (*get_ssid)(void *priv, u8 *ssid);
+       int (*set_ap)(void *priv, struct wpa_driver_ap_params *params);
 
        /**
-        * set_key - Configure encryption key
-        * @ifname: Interface name (for multi-SSID/VLAN support)
-        * @priv: private driver interface data
-        * @alg: encryption algorithm (%WPA_ALG_NONE, %WPA_ALG_WEP,
-        *      %WPA_ALG_TKIP, %WPA_ALG_CCMP, %WPA_ALG_IGTK, %WPA_ALG_PMK);
-        *      %WPA_ALG_NONE clears the key.
-        * @addr: address of the peer STA or ff:ff:ff:ff:ff:ff for
-        *      broadcast/default keys
-        * @key_idx: key index (0..3), usually 0 for unicast keys; 0..4095 for
-        *      IGTK
-        * @set_tx: configure this key as the default Tx key (only used when
-        *      driver does not support separate unicast/individual key
-        * @seq: sequence number/packet number, seq_len octets, the next
-        *      packet number to be used for in replay protection; configured
-        *      for Rx keys (in most cases, this is only used with broadcast
-        *      keys and set to zero for unicast keys)
-        * @seq_len: length of the seq, depends on the algorithm:
-        *      TKIP: 6 octets, CCMP: 6 octets, IGTK: 6 octets
-        * @key: key buffer; TKIP: 16-byte temporal key, 8-byte Tx Mic key,
-        *      8-byte Rx Mic Key
-        * @key_len: length of the key buffer in octets (WEP: 5 or 13,
-        *      TKIP: 32, CCMP: 16, IGTK: 16)
-        *
+        * set_acl - Set ACL in AP mode
+        * @priv: Private driver interface data
+        * @params: Parameters to configure ACL
         * Returns: 0 on success, -1 on failure
         *
-        * Configure the given key for the kernel driver. If the driver
-        * supports separate individual keys (4 default keys + 1 individual),
-        * addr can be used to determine whether the key is default or
-        * individual. If only 4 keys are supported, the default key with key
-        * index 0 is used as the individual key. STA must be configured to use
-        * it as the default Tx key (set_tx is set) and accept Rx for all the
-        * key indexes. In most cases, WPA uses only key indexes 1 and 2 for
-        * broadcast keys, so key index 0 is available for this kind of
-        * configuration.
-        *
-        * Please note that TKIP keys include separate TX and RX MIC keys and
-        * some drivers may expect them in different order than wpa_supplicant
-        * is using. If the TX/RX keys are swapped, all TKIP encrypted packets
-        * will tricker Michael MIC errors. This can be fixed by changing the
-        * order of MIC keys by swapping te bytes 16..23 and 24..31 of the key
-        * in driver_*.c set_key() implementation, see driver_ndis.c for an
-        * example on how this can be done.
+        * This is used only for the drivers which support MAC address ACL.
         */
-       int (*set_key)(const char *ifname, void *priv, enum wpa_alg alg,
-                      const u8 *addr, int key_idx, int set_tx,
-                      const u8 *seq, size_t seq_len,
-                      const u8 *key, size_t key_len);
+       int (*set_acl)(void *priv, struct hostapd_acl_params *params);
 
        /**
-        * init - Initialize driver interface
-        * @ctx: context to be used when calling wpa_supplicant functions,
-        * e.g., wpa_supplicant_event()
-        * @ifname: interface name, e.g., wlan0
-        *
+        * hapd_init - Initialize driver interface (hostapd only)
+        * @hapd: Pointer to hostapd context
+        * @params: Configuration for the driver wrapper
         * Returns: Pointer to private data, %NULL on failure
         *
-        * Initialize driver interface, including event processing for kernel
-        * driver events (e.g., associated, scan results, Michael MIC failure).
-        * This function can allocate a private configuration data area for
-        * @ctx, file descriptor, interface name, etc. information that may be
-        * needed in future driver operations. If this is not used, non-NULL
-        * value will need to be returned because %NULL is used to indicate
-        * failure. The returned value will be used as 'void *priv' data for
-        * all other driver_ops functions.
+        * This function is used instead of init() or init2() when the driver
+        * wrapper is used with hostapd.
+        */
+       void * (*hapd_init)(struct hostapd_data *hapd,
+                           struct wpa_init_params *params);
+
+       /**
+        * hapd_deinit - Deinitialize driver interface (hostapd only)
+        * @priv: Private driver interface data from hapd_init()
+        */
+       void (*hapd_deinit)(void *priv);
+
+       /**
+        * set_ieee8021x - Enable/disable IEEE 802.1X support (AP only)
+        * @priv: Private driver interface data
+        * @params: BSS parameters
+        * Returns: 0 on success, -1 on failure
         *
-        * The main event loop (eloop.c) of wpa_supplicant can be used to
-        * register callback for read sockets (eloop_register_read_sock()).
+        * This is an optional function to configure the kernel driver to
+        * enable/disable IEEE 802.1X support and set WPA/WPA2 parameters. This
+        * can be left undefined (set to %NULL) if IEEE 802.1X support is
+        * always enabled and the driver uses set_ap() to set WPA/RSN IE
+        * for Beacon frames.
         *
-        * See below for more information about events and
-        * wpa_supplicant_event() function.
+        * DEPRECATED - use set_ap() instead
         */
-       void * (*init)(void *ctx, const char *ifname);
+       int (*set_ieee8021x)(void *priv, struct wpa_bss_params *params);
 
        /**
-        * deinit - Deinitialize driver interface
-        * @priv: private driver interface data from init()
+        * set_privacy - Enable/disable privacy (AP only)
+        * @priv: Private driver interface data
+        * @enabled: 1 = privacy enabled, 0 = disabled
+        * Returns: 0 on success, -1 on failure
         *
-        * Shut down driver interface and processing of driver events. Free
-        * private data buffer if one was allocated in init() handler.
+        * This is an optional function to configure privacy field in the
+        * kernel driver for Beacon frames. This can be left undefined (set to
+        * %NULL) if the driver uses the Beacon template from set_ap().
+        *
+        * DEPRECATED - use set_ap() instead
         */
-       void (*deinit)(void *priv);
+       int (*set_privacy)(void *priv, int enabled);
 
        /**
-        * set_param - Set driver configuration parameters
-        * @priv: private driver interface data from init()
-        * @param: driver specific configuration parameters
-        *
+        * get_seqnum - Fetch the current TSC/packet number (AP only)
+        * @ifname: The interface name (main or virtual)
+        * @priv: Private driver interface data
+        * @addr: MAC address of the station or %NULL for group keys
+        * @idx: Key index
+        * @seq: Buffer for returning the latest used TSC/packet number
         * Returns: 0 on success, -1 on failure
         *
-        * Optional handler for notifying driver interface about configuration
-        * parameters (driver_param).
+        * This function is used to fetch the last used TSC/packet number for
+        * a TKIP, CCMP, GCMP, or BIP/IGTK key. It is mainly used with group
+        * keys, so there is no strict requirement on implementing support for
+        * unicast keys (i.e., addr != %NULL).
         */
-       int (*set_param)(void *priv, const char *param);
+       int (*get_seqnum)(const char *ifname, void *priv, const u8 *addr,
+                         int idx, u8 *seq);
 
        /**
-        * set_countermeasures - Enable/disable TKIP countermeasures
-        * @priv: private driver interface data
-        * @enabled: 1 = countermeasures enabled, 0 = disabled
-        *
+        * flush - Flush all association stations (AP only)
+        * @priv: Private driver interface data
         * Returns: 0 on success, -1 on failure
         *
-        * Configure TKIP countermeasures. When these are enabled, the driver
-        * should drop all received and queued frames that are using TKIP.
+        * This function requests the driver to disassociate all associated
+        * stations. This function does not need to be implemented if the
+        * driver does not process association frames internally.
         */
-       int (*set_countermeasures)(void *priv, int enabled);
+       int (*flush)(void *priv);
 
        /**
-        * deauthenticate - Request driver to deauthenticate
-        * @priv: private driver interface data
-        * @addr: peer address (BSSID of the AP)
-        * @reason_code: 16-bit reason code to be sent in the deauthentication
-        *      frame
-        *
+        * set_generic_elem - Add IEs into Beacon/Probe Response frames (AP)
+        * @priv: Private driver interface data
+        * @elem: Information elements
+        * @elem_len: Length of the elem buffer in octets
         * Returns: 0 on success, -1 on failure
+        *
+        * This is an optional function to add information elements in the
+        * kernel driver for Beacon and Probe Response frames. This can be left
+        * undefined (set to %NULL) if the driver uses the Beacon template from
+        * set_ap().
+        *
+        * DEPRECATED - use set_ap() instead
         */
-       int (*deauthenticate)(void *priv, const u8 *addr, int reason_code);
+       int (*set_generic_elem)(void *priv, const u8 *elem, size_t elem_len);
 
        /**
-        * disassociate - Request driver to disassociate
-        * @priv: private driver interface data
-        * @addr: peer address (BSSID of the AP)
-        * @reason_code: 16-bit reason code to be sent in the disassociation
-        *      frame
-        *
+        * read_sta_data - Fetch station data
+        * @priv: Private driver interface data
+        * @data: Buffer for returning station information
+        * @addr: MAC address of the station
         * Returns: 0 on success, -1 on failure
         */
-       int (*disassociate)(void *priv, const u8 *addr, int reason_code);
+       int (*read_sta_data)(void *priv, struct hostap_sta_driver_data *data,
+                            const u8 *addr);
 
        /**
-        * associate - Request driver to associate
+        * hapd_send_eapol - Send an EAPOL packet (AP only)
         * @priv: private driver interface data
-        * @params: association parameters
+        * @addr: Destination MAC address
+        * @data: EAPOL packet starting with IEEE 802.1X header
+        * @data_len: Length of the EAPOL packet in octets
+        * @encrypt: Whether the frame should be encrypted
+        * @own_addr: Source MAC address
+        * @flags: WPA_STA_* flags for the destination station
         *
         * Returns: 0 on success, -1 on failure
         */
-       int (*associate)(void *priv,
-                        struct wpa_driver_associate_params *params);
+       int (*hapd_send_eapol)(void *priv, const u8 *addr, const u8 *data,
+                              size_t data_len, int encrypt,
+                              const u8 *own_addr, u32 flags);
 
        /**
-        * add_pmkid - Add PMKSA cache entry to the driver
-        * @priv: private driver interface data
-        * @bssid: BSSID for the PMKSA cache entry
-        * @pmkid: PMKID for the PMKSA cache entry
-        *
+        * sta_deauth - Deauthenticate a station (AP only)
+        * @priv: Private driver interface data
+        * @own_addr: Source address and BSSID for the Deauthentication frame
+        * @addr: MAC address of the station to deauthenticate
+        * @reason: Reason code for the Deauthentiation frame
         * Returns: 0 on success, -1 on failure
         *
-        * This function is called when a new PMK is received, as a result of
-        * either normal authentication or RSN pre-authentication.
-        *
-        * If the driver generates RSN IE, i.e., it does not use wpa_ie in
-        * associate(), add_pmkid() can be used to add new PMKSA cache entries
-        * in the driver. If the driver uses wpa_ie from wpa_supplicant, this
-        * driver_ops function does not need to be implemented. Likewise, if
-        * the driver does not support WPA, this function is not needed.
+        * This function requests a specific station to be deauthenticated and
+        * a Deauthentication frame to be sent to it.
         */
-       int (*add_pmkid)(void *priv, const u8 *bssid, const u8 *pmkid);
+       int (*sta_deauth)(void *priv, const u8 *own_addr, const u8 *addr,
+                         int reason);
 
        /**
-        * remove_pmkid - Remove PMKSA cache entry to the driver
-        * @priv: private driver interface data
-        * @bssid: BSSID for the PMKSA cache entry
-        * @pmkid: PMKID for the PMKSA cache entry
-        *
+        * sta_disassoc - Disassociate a station (AP only)
+        * @priv: Private driver interface data
+        * @own_addr: Source address and BSSID for the Disassociation frame
+        * @addr: MAC address of the station to disassociate
+        * @reason: Reason code for the Disassociation frame
         * Returns: 0 on success, -1 on failure
         *
-        * This function is called when the supplicant drops a PMKSA cache
-        * entry for any reason.
+        * This function requests a specific station to be disassociated and
+        * a Disassociation frame to be sent to it.
+        */
+       int (*sta_disassoc)(void *priv, const u8 *own_addr, const u8 *addr,
+                           int reason);
+
+       /**
+        * sta_remove - Remove a station entry (AP only)
+        * @priv: Private driver interface data
+        * @addr: MAC address of the station to be removed
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*sta_remove)(void *priv, const u8 *addr);
+
+       /**
+        * hapd_get_ssid - Get the current SSID (AP only)
+        * @priv: Private driver interface data
+        * @buf: Buffer for returning the SSID
+        * @len: Maximum length of the buffer
+        * Returns: Length of the SSID on success, -1 on failure
         *
-        * If the driver generates RSN IE, i.e., it does not use wpa_ie in
-        * associate(), remove_pmkid() can be used to synchronize PMKSA caches
-        * between the driver and wpa_supplicant. If the driver uses wpa_ie
-        * from wpa_supplicant, this driver_ops function does not need to be
-        * implemented. Likewise, if the driver does not support WPA, this
-        * function is not needed.
+        * This function need not be implemented if the driver uses Beacon
+        * template from set_ap() and does not reply to Probe Request frames.
         */
-       int (*remove_pmkid)(void *priv, const u8 *bssid, const u8 *pmkid);
+       int (*hapd_get_ssid)(void *priv, u8 *buf, int len);
 
        /**
-        * flush_pmkid - Flush PMKSA cache
-        * @priv: private driver interface data
-        *
+        * hapd_set_ssid - Set SSID (AP only)
+        * @priv: Private driver interface data
+        * @buf: SSID
+        * @len: Length of the SSID in octets
         * Returns: 0 on success, -1 on failure
         *
-        * This function is called when the supplicant drops all PMKSA cache
-        * entries for any reason.
-        *
-        * If the driver generates RSN IE, i.e., it does not use wpa_ie in
-        * associate(), remove_pmkid() can be used to synchronize PMKSA caches
-        * between the driver and wpa_supplicant. If the driver uses wpa_ie
-        * from wpa_supplicant, this driver_ops function does not need to be
-        * implemented. Likewise, if the driver does not support WPA, this
-        * function is not needed.
+        * DEPRECATED - use set_ap() instead
         */
-       int (*flush_pmkid)(void *priv);
+       int (*hapd_set_ssid)(void *priv, const u8 *buf, int len);
 
        /**
-        * get_capa - Get driver capabilities
-        * @priv: private driver interface data
-        *
+        * hapd_set_countermeasures - Enable/disable TKIP countermeasures (AP)
+        * @priv: Private driver interface data
+        * @enabled: 1 = countermeasures enabled, 0 = disabled
         * Returns: 0 on success, -1 on failure
         *
-        * Get driver/firmware/hardware capabilities.
+        * This need not be implemented if the driver does not take care of
+        * association processing.
         */
-       int (*get_capa)(void *priv, struct wpa_driver_capa *capa);
+       int (*hapd_set_countermeasures)(void *priv, int enabled);
 
        /**
-        * poll - Poll driver for association information
-        * @priv: private driver interface data
+        * sta_add - Add a station entry
+        * @priv: Private driver interface data
+        * @params: Station parameters
+        * Returns: 0 on success, -1 on failure
         *
-        * This is an option callback that can be used when the driver does not
-        * provide event mechanism for association events. This is called when
-        * receiving WPA EAPOL-Key messages that require association
-        * information. The driver interface is supposed to generate associnfo
-        * event before returning from this callback function. In addition, the
-        * driver interface should generate an association event after having
-        * sent out associnfo.
+        * This function is used to add a station entry to the driver once the
+        * station has completed association. This is only used if the driver
+        * does not take care of association processing.
+        *
+        * With TDLS, this function is also used to add or set (params->set 1)
+        * TDLS peer entries.
         */
-       void (*poll)(void *priv);
+       int (*sta_add)(void *priv, struct hostapd_sta_add_params *params);
 
        /**
-        * get_ifname - Get interface name
-        * @priv: private driver interface data
-        *
-        * Returns: Pointer to the interface name. This can differ from the
-        * interface name used in init() call. Init() is called first.
-        *
-        * This optional function can be used to allow the driver interface to
-        * replace the interface name with something else, e.g., based on an
-        * interface mapping from a more descriptive name.
+        * get_inact_sec - Get station inactivity duration (AP only)
+        * @priv: Private driver interface data
+        * @addr: Station address
+        * Returns: Number of seconds station has been inactive, -1 on failure
         */
-       const char * (*get_ifname)(void *priv);
+       int (*get_inact_sec)(void *priv, const u8 *addr);
 
        /**
-        * get_mac_addr - Get own MAC address
-        * @priv: private driver interface data
-        *
-        * Returns: Pointer to own MAC address or %NULL on failure
-        *
-        * This optional function can be used to get the own MAC address of the
-        * device from the driver interface code. This is only needed if the
-        * l2_packet implementation for the OS does not provide easy access to
-        * a MAC address. */
-       const u8 * (*get_mac_addr)(void *priv);
+        * sta_clear_stats - Clear station statistics (AP only)
+        * @priv: Private driver interface data
+        * @addr: Station address
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*sta_clear_stats)(void *priv, const u8 *addr);
 
        /**
-        * send_eapol - Optional function for sending EAPOL packets
-        * @priv: private driver interface data
-        * @dest: Destination MAC address
-        * @proto: Ethertype
-        * @data: EAPOL packet starting with IEEE 802.1X header
-        * @data_len: Size of the EAPOL packet
-        *
+        * set_freq - Set channel/frequency (AP only)
+        * @priv: Private driver interface data
+        * @freq: Channel parameters
         * Returns: 0 on success, -1 on failure
-        *
-        * This optional function can be used to override l2_packet operations
-        * with driver specific functionality. If this function pointer is set,
-        * l2_packet module is not used at all and the driver interface code is
-        * responsible for receiving and sending all EAPOL packets. The
-        * received EAPOL packets are sent to core code with EVENT_EAPOL_RX
-        * event. The driver interface is required to implement get_mac_addr()
-        * handler if send_eapol() is used.
         */
-       int (*send_eapol)(void *priv, const u8 *dest, u16 proto,
-                         const u8 *data, size_t data_len);
+       int (*set_freq)(void *priv, struct hostapd_freq_params *freq);
 
        /**
-        * set_operstate - Sets device operating state to DORMANT or UP
-        * @priv: private driver interface data
-        * @state: 0 = dormant, 1 = up
+        * set_rts - Set RTS threshold
+        * @priv: Private driver interface data
+        * @rts: RTS threshold in octets
         * Returns: 0 on success, -1 on failure
-        *
-        * This is an optional function that can be used on operating systems
-        * that support a concept of controlling network device state from user
-        * space applications. This function, if set, gets called with
-        * state = 1 when authentication has been completed and with state = 0
-        * when connection is lost.
         */
-       int (*set_operstate)(void *priv, int state);
+       int (*set_rts)(void *priv, int rts);
 
        /**
-        * mlme_setprotection - MLME-SETPROTECTION.request primitive
+        * set_frag - Set fragmentation threshold
         * @priv: Private driver interface data
-        * @addr: Address of the station for which to set protection (may be
-        * %NULL for group keys)
-        * @protect_type: MLME_SETPROTECTION_PROTECT_TYPE_*
-        * @key_type: MLME_SETPROTECTION_KEY_TYPE_*
+        * @frag: Fragmentation threshold in octets
         * Returns: 0 on success, -1 on failure
-        *
-        * This is an optional function that can be used to set the driver to
-        * require protection for Tx and/or Rx frames. This uses the layer
-        * interface defined in IEEE 802.11i-2004 clause 10.3.22.1
-        * (MLME-SETPROTECTION.request). Many drivers do not use explicit
-        * set protection operation; instead, they set protection implicitly
-        * based on configured keys.
         */
-       int (*mlme_setprotection)(void *priv, const u8 *addr, int protect_type,
-                                 int key_type);
+       int (*set_frag)(void *priv, int frag);
 
        /**
-        * get_hw_feature_data - Get hardware support data (channels and rates)
+        * sta_set_flags - Set station flags (AP only)
         * @priv: Private driver interface data
-        * @num_modes: Variable for returning the number of returned modes
-        * flags: Variable for returning hardware feature flags
-        * Returns: Pointer to allocated hardware data on success or %NULL on
-        * failure. Caller is responsible for freeing this.
-        *
-        * This function is only needed for drivers that export MLME
-        * (management frame processing) to %wpa_supplicant or hostapd.
+        * @addr: Station address
+        * @total_flags: Bitmap of all WPA_STA_* flags currently set
+        * @flags_or: Bitmap of WPA_STA_* flags to add
+        * @flags_and: Bitmap of WPA_STA_* flags to us as a mask
+        * Returns: 0 on success, -1 on failure
         */
-       struct hostapd_hw_modes * (*get_hw_feature_data)(void *priv,
-                                                        u16 *num_modes,
-                                                        u16 *flags);
+       int (*sta_set_flags)(void *priv, const u8 *addr,
+                            unsigned int total_flags, unsigned int flags_or,
+                            unsigned int flags_and);
 
        /**
-        * set_channel - Set channel
+        * set_tx_queue_params - Set TX queue parameters
         * @priv: Private driver interface data
-        * @phymode: HOSTAPD_MODE_IEEE80211B, ..
-        * @chan: IEEE 802.11 channel number
-        * @freq: Frequency of the channel in MHz
+        * @queue: Queue number (0 = VO, 1 = VI, 2 = BE, 3 = BK)
+        * @aifs: AIFS
+        * @cw_min: cwMin
+        * @cw_max: cwMax
+        * @burst_time: Maximum length for bursting in 0.1 msec units
+        */
+       int (*set_tx_queue_params)(void *priv, int queue, int aifs, int cw_min,
+                                  int cw_max, int burst_time);
+
+       /**
+        * if_add - Add a virtual interface
+        * @priv: Private driver interface data
+        * @type: Interface type
+        * @ifname: Interface name for the new virtual interface
+        * @addr: Local address to use for the interface or %NULL to use the
+        *      parent interface address
+        * @bss_ctx: BSS context for %WPA_IF_AP_BSS interfaces
+        * @drv_priv: Pointer for overwriting the driver context or %NULL if
+        *      not allowed (applies only to %WPA_IF_AP_BSS type)
+        * @force_ifname: Buffer for returning an interface name that the
+        *      driver ended up using if it differs from the requested ifname
+        * @if_addr: Buffer for returning the allocated interface address
+        *      (this may differ from the requested addr if the driver cannot
+        *      change interface address)
+        * @bridge: Bridge interface to use or %NULL if no bridge configured
+        * @use_existing: Whether to allow existing interface to be used
         * Returns: 0 on success, -1 on failure
-        *
-        * This function is only needed for drivers that export MLME
-        * (management frame processing) to wpa_supplicant.
         */
-       int (*set_channel)(void *priv, enum hostapd_hw_mode phymode, int chan,
-                          int freq);
+       int (*if_add)(void *priv, enum wpa_driver_if_type type,
+                     const char *ifname, const u8 *addr, void *bss_ctx,
+                     void **drv_priv, char *force_ifname, u8 *if_addr,
+                     const char *bridge, int use_existing);
 
        /**
-        * set_ssid - Set SSID
+        * if_remove - Remove a virtual interface
         * @priv: Private driver interface data
-        * @ssid: SSID
-        * @ssid_len: SSID length
+        * @type: Interface type
+        * @ifname: Interface name of the virtual interface to be removed
         * Returns: 0 on success, -1 on failure
-        *
-        * This function is only needed for drivers that export MLME
-        * (management frame processing) to wpa_supplicant.
         */
-       int (*set_ssid)(void *priv, const u8 *ssid, size_t ssid_len);
+       int (*if_remove)(void *priv, enum wpa_driver_if_type type,
+                        const char *ifname);
 
        /**
-        * set_bssid - Set BSSID
+        * set_sta_vlan - Bind a station into a specific interface (AP only)
         * @priv: Private driver interface data
-        * @bssid: BSSID
+        * @ifname: Interface (main or virtual BSS or VLAN)
+        * @addr: MAC address of the associated station
+        * @vlan_id: VLAN ID
         * Returns: 0 on success, -1 on failure
         *
-        * This function is only needed for drivers that export MLME
-        * (management frame processing) to wpa_supplicant.
+        * This function is used to bind a station to a specific virtual
+        * interface. It is only used if when virtual interfaces are supported,
+        * e.g., to assign stations to different VLAN interfaces based on
+        * information from a RADIUS server. This allows separate broadcast
+        * domains to be used with a single BSS.
         */
-       int (*set_bssid)(void *priv, const u8 *bssid);
+       int (*set_sta_vlan)(void *priv, const u8 *addr, const char *ifname,
+                           int vlan_id);
 
        /**
-        * send_mlme - Send management frame from MLME
-        * @priv: Private driver interface data
-        * @data: IEEE 802.11 management frame with IEEE 802.11 header
-        * @data_len: Size of the management frame
+        * commit - Optional commit changes handler (AP only)
+        * @priv: driver private data
         * Returns: 0 on success, -1 on failure
         *
-        * This function is only needed for drivers that export MLME
-        * (management frame processing) to wpa_supplicant.
+        * This optional handler function can be registered if the driver
+        * interface implementation needs to commit changes (e.g., by setting
+        * network interface up) at the end of initial configuration. If set,
+        * this handler will be called after initial setup has been completed.
+        */
+       int (*commit)(void *priv);
+
+       /**
+        * send_ether - Send an ethernet packet (AP only)
+        * @priv: private driver interface data
+        * @dst: Destination MAC address
+        * @src: Source MAC address
+        * @proto: Ethertype
+        * @data: EAPOL packet starting with IEEE 802.1X header
+        * @data_len: Length of the EAPOL packet in octets
+        * Returns: 0 on success, -1 on failure
         */
-       int (*send_mlme)(void *priv, const u8 *data, size_t data_len);
+       int (*send_ether)(void *priv, const u8 *dst, const u8 *src, u16 proto,
+                         const u8 *data, size_t data_len);
 
        /**
-        * mlme_add_sta - Add a STA entry into the driver/netstack
+        * set_radius_acl_auth - Notification of RADIUS ACL change
         * @priv: Private driver interface data
-        * @addr: MAC address of the STA (e.g., BSSID of the AP)
-        * @supp_rates: Supported rate set (from (Re)AssocResp); in IEEE 802.11
-        * format (one octet per rate, 1 = 0.5 Mbps)
-        * @supp_rates_len: Number of entries in supp_rates
+        * @mac: MAC address of the station
+        * @accepted: Whether the station was accepted
+        * @session_timeout: Session timeout for the station
         * Returns: 0 on success, -1 on failure
-        *
-        * This function is only needed for drivers that export MLME
-        * (management frame processing) to wpa_supplicant. When the MLME code
-        * completes association with an AP, this function is called to
-        * configure the driver/netstack with a STA entry for data frame
-        * processing (TX rate control, encryption/decryption).
         */
-       int (*mlme_add_sta)(void *priv, const u8 *addr, const u8 *supp_rates,
-                           size_t supp_rates_len);
+       int (*set_radius_acl_auth)(void *priv, const u8 *mac, int accepted,
+                                  u32 session_timeout);
 
        /**
-        * mlme_remove_sta - Remove a STA entry from the driver/netstack
+        * set_radius_acl_expire - Notification of RADIUS ACL expiration
         * @priv: Private driver interface data
-        * @addr: MAC address of the STA (e.g., BSSID of the AP)
+        * @mac: MAC address of the station
         * Returns: 0 on success, -1 on failure
-        *
-        * This function is only needed for drivers that export MLME
-        * (management frame processing) to wpa_supplicant.
         */
-       int (*mlme_remove_sta)(void *priv, const u8 *addr);
+       int (*set_radius_acl_expire)(void *priv, const u8 *mac);
 
        /**
-        * update_ft_ies - Update FT (IEEE 802.11r) IEs
+        * set_ap_wps_ie - Add WPS IE(s) into Beacon/Probe Response frames (AP)
         * @priv: Private driver interface data
-        * @md: Mobility domain (2 octets) (also included inside ies)
-        * @ies: FT IEs (MDIE, FTIE, ...) or %NULL to remove IEs
-        * @ies_len: Length of FT IEs in bytes
+        * @beacon: WPS IE(s) for Beacon frames or %NULL to remove extra IE(s)
+        * @proberesp: WPS IE(s) for Probe Response frames or %NULL to remove
+        *      extra IE(s)
+        * @assocresp: WPS IE(s) for (Re)Association Response frames or %NULL
+        *      to remove extra IE(s)
         * Returns: 0 on success, -1 on failure
         *
-        * The supplicant uses this callback to let the driver know that keying
-        * material for FT is available and that the driver can use the
-        * provided IEs in the next message in FT authentication sequence.
+        * This is an optional function to add WPS IE in the kernel driver for
+        * Beacon and Probe Response frames. This can be left undefined (set
+        * to %NULL) if the driver uses the Beacon template from set_ap()
+        * and does not process Probe Request frames. If the driver takes care
+        * of (Re)Association frame processing, the assocresp buffer includes
+        * WPS IE(s) that need to be added to (Re)Association Response frames
+        * whenever a (Re)Association Request frame indicated use of WPS.
         *
-        * This function is only needed for driver that support IEEE 802.11r
-        * (Fast BSS Transition).
-        */
-       int (*update_ft_ies)(void *priv, const u8 *md, const u8 *ies,
-                            size_t ies_len);
+        * This will also be used to add P2P IE(s) into Beacon/Probe Response
+        * frames when operating as a GO. The driver is responsible for adding
+        * timing related attributes (e.g., NoA) in addition to the IEs
+        * included here by appending them after these buffers. This call is
+        * also used to provide Probe Response IEs for P2P Listen state
+        * operations for drivers that generate the Probe Response frames
+        * internally.
+        *
+        * DEPRECATED - use set_ap() instead
+        */
+       int (*set_ap_wps_ie)(void *priv, const struct wpabuf *beacon,
+                            const struct wpabuf *proberesp,
+                            const struct wpabuf *assocresp);
 
        /**
-        * send_ft_action - Send FT Action frame (IEEE 802.11r)
+        * set_supp_port - Set IEEE 802.1X Supplicant Port status
         * @priv: Private driver interface data
-        * @action: Action field value
-        * @target_ap: Target AP address
-        * @ies: FT IEs (MDIE, FTIE, ...) (FT Request action frame body)
-        * @ies_len: Length of FT IEs in bytes
+        * @authorized: Whether the port is authorized
         * Returns: 0 on success, -1 on failure
-        *
-        * The supplicant uses this callback to request the driver to transmit
-        * an FT Action frame (action category 6) for over-the-DS fast BSS
-        * transition.
         */
-       int (*send_ft_action)(void *priv, u8 action, const u8 *target_ap,
-                             const u8 *ies, size_t ies_len);
+       int (*set_supp_port)(void *priv, int authorized);
 
        /**
-        * get_scan_results2 - Fetch the latest scan results
-        * @priv: private driver interface data
-        *
-        * Returns: Allocated buffer of scan results (caller is responsible for
-        * freeing the data structure) on success, NULL on failure
+        * set_wds_sta - Bind a station into a 4-address WDS (AP only)
+        * @priv: Private driver interface data
+        * @addr: MAC address of the associated station
+        * @aid: Association ID
+        * @val: 1 = bind to 4-address WDS; 0 = unbind
+        * @bridge_ifname: Bridge interface to use for the WDS station or %NULL
+        *      to indicate that bridge is not to be used
+        * @ifname_wds: Buffer to return the interface name for the new WDS
+        *      station or %NULL to indicate name is not returned.
+        * Returns: 0 on success, -1 on failure
         */
-        struct wpa_scan_results * (*get_scan_results2)(void *priv);
+       int (*set_wds_sta)(void *priv, const u8 *addr, int aid, int val,
+                          const char *bridge_ifname, char *ifname_wds);
 
        /**
-        * set_country - Set country
+        * send_action - Transmit an Action frame
         * @priv: Private driver interface data
-        * @alpha2: country to which to switch to
+        * @freq: Frequency (in MHz) of the channel
+        * @wait: Time to wait off-channel for a response (in ms), or zero
+        * @dst: Destination MAC address (Address 1)
+        * @src: Source MAC address (Address 2)
+        * @bssid: BSSID (Address 3)
+        * @data: Frame body
+        * @data_len: data length in octets
+        @ @no_cck: Whether CCK rates must not be used to transmit this frame
         * Returns: 0 on success, -1 on failure
         *
-        * This function is for drivers which support some form
-        * of setting a regulatory domain.
-        */
-       int (*set_country)(void *priv, const char *alpha2);
-
-       /**
-        * global_init - Global driver initialization
-        * Returns: Pointer to private data (global), %NULL on failure
+        * This command can be used to request the driver to transmit an action
+        * frame to the specified destination.
         *
-        * This optional function is called to initialize the driver wrapper
-        * for global data, i.e., data that applies to all interfaces. If this
-        * function is implemented, global_deinit() will also need to be
-        * implemented to free the private data. The driver will also likely
-        * use init2() function instead of init() to get the pointer to global
-        * data available to per-interface initializer.
+        * If the %WPA_DRIVER_FLAGS_OFFCHANNEL_TX flag is set, the frame will
+        * be transmitted on the given channel and the device will wait for a
+        * response on that channel for the given wait time.
+        *
+        * If the flag is not set, the wait time will be ignored. In this case,
+        * if a remain-on-channel duration is in progress, the frame must be
+        * transmitted on that channel; alternatively the frame may be sent on
+        * the current operational channel (if in associated state in station
+        * mode or while operating as an AP.)
         */
-       void * (*global_init)(void);
+       int (*send_action)(void *priv, unsigned int freq, unsigned int wait,
+                          const u8 *dst, const u8 *src, const u8 *bssid,
+                          const u8 *data, size_t data_len, int no_cck);
 
        /**
-        * global_deinit - Global driver deinitialization
-        * @priv: private driver global data from global_init()
+        * send_action_cancel_wait - Cancel action frame TX wait
+        * @priv: Private driver interface data
         *
-        * Terminate any global driver related functionality and free the
-        * global data structure.
+        * This command cancels the wait time associated with sending an action
+        * frame. It is only available when %WPA_DRIVER_FLAGS_OFFCHANNEL_TX is
+        * set in the driver flags.
         */
-       void (*global_deinit)(void *priv);
+       void (*send_action_cancel_wait)(void *priv);
 
        /**
-        * init2 - Initialize driver interface (with global data)
-        * @ctx: context to be used when calling wpa_supplicant functions,
-        * e.g., wpa_supplicant_event()
-        * @ifname: interface name, e.g., wlan0
-        * @global_priv: private driver global data from global_init()
-        * Returns: Pointer to private data, %NULL on failure
+        * remain_on_channel - Remain awake on a channel
+        * @priv: Private driver interface data
+        * @freq: Frequency (in MHz) of the channel
+        * @duration: Duration in milliseconds
+        * Returns: 0 on success, -1 on failure
         *
-        * This function can be used instead of init() if the driver wrapper
-        * uses global data.
+        * This command is used to request the driver to remain awake on the
+        * specified channel for the specified duration and report received
+        * Action frames with EVENT_RX_MGMT events. Optionally, received
+        * Probe Request frames may also be requested to be reported by calling
+        * probe_req_report(). These will be reported with EVENT_RX_PROBE_REQ.
+        *
+        * The driver may not be at the requested channel when this function
+        * returns, i.e., the return code is only indicating whether the
+        * request was accepted. The caller will need to wait until the
+        * EVENT_REMAIN_ON_CHANNEL event indicates that the driver has
+        * completed the channel change. This may take some time due to other
+        * need for the radio and the caller should be prepared to timing out
+        * its wait since there are no guarantees on when this request can be
+        * executed.
         */
-       void * (*init2)(void *ctx, const char *ifname, void *global_priv);
+       int (*remain_on_channel)(void *priv, unsigned int freq,
+                                unsigned int duration);
 
        /**
-        * get_interfaces - Get information about available interfaces
-        * @global_priv: private driver global data from global_init()
-        * Returns: Allocated buffer of interface information (caller is
-        * responsible for freeing the data structure) on success, NULL on
-        * failure
+        * cancel_remain_on_channel - Cancel remain-on-channel operation
+        * @priv: Private driver interface data
+        *
+        * This command can be used to cancel a remain-on-channel operation
+        * before its originally requested duration has passed. This could be
+        * used, e.g., when remain_on_channel() is used to request extra time
+        * to receive a response to an Action frame and the response is
+        * received when there is still unneeded time remaining on the
+        * remain-on-channel operation.
         */
-       struct wpa_interface_info * (*get_interfaces)(void *global_priv);
+       int (*cancel_remain_on_channel)(void *priv);
 
        /**
-        * scan2 - Request the driver to initiate scan
-        * @priv: private driver interface data
-        * @params: Scan parameters
-        *
-        * Returns: 0 on success, -1 on failure
+        * probe_req_report - Request Probe Request frames to be indicated
+        * @priv: Private driver interface data
+        * @report: Whether to report received Probe Request frames
+        * Returns: 0 on success, -1 on failure (or if not supported)
         *
-        * Once the scan results are ready, the driver should report scan
-        * results event for wpa_supplicant which will eventually request the
-        * results with wpa_driver_get_scan_results2().
+        * This command can be used to request the driver to indicate when
+        * Probe Request frames are received with EVENT_RX_PROBE_REQ events.
+        * Since this operation may require extra resources, e.g., due to less
+        * optimal hardware/firmware RX filtering, many drivers may disable
+        * Probe Request reporting at least in station mode. This command is
+        * used to notify the driver when the Probe Request frames need to be
+        * reported, e.g., during remain-on-channel operations.
         */
-       int (*scan2)(void *priv, struct wpa_driver_scan_params *params);
+       int (*probe_req_report)(void *priv, int report);
 
        /**
-        * authenticate - Request driver to authenticate
-        * @priv: private driver interface data
-        * @params: authentication parameters
-        * Returns: 0 on success, -1 on failure
+        * deinit_ap - Deinitialize AP mode
+        * @priv: Private driver interface data
+        * Returns: 0 on success, -1 on failure (or if not supported)
         *
-        * This is an optional function that can be used with drivers that
-        * support separate authentication and association steps, i.e., when
-        * wpa_supplicant can act as the SME. If not implemented, associate()
-        * function is expected to take care of IEEE 802.11 authentication,
-        * too.
+        * This optional function can be used to disable AP mode related
+        * configuration. If the interface was not dynamically added,
+        * change the driver mode to station mode to allow normal station
+        * operations like scanning to be completed.
         */
-       int (*authenticate)(void *priv,
-                           struct wpa_driver_auth_params *params);
+       int (*deinit_ap)(void *priv);
 
        /**
-        * set_beacon - Set Beacon frame template
+        * deinit_p2p_cli - Deinitialize P2P client mode
         * @priv: Private driver interface data
-        * @head: Beacon head from IEEE 802.11 header to IEs before TIM IE
-        * @head_len: Length of the head buffer in octets
-        * @tail: Beacon tail following TIM IE
-        * @tail_len: Length of the tail buffer in octets
-        * @dtim_period: DTIM period
-        * @beacon_int: Beacon interval
-        * Returns: 0 on success, -1 on failure
+        * Returns: 0 on success, -1 on failure (or if not supported)
         *
-        * This function is used to configure Beacon template for the driver in
-        * AP mode. The driver is responsible for building the full Beacon
-        * frame by concatenating the head part with TIM IE generated by the
-        * driver/firmware and finishing with the tail part.
+        * This optional function can be used to disable P2P client mode. If the
+        * interface was not dynamically added, change the interface type back
+        * to station mode.
         */
-       int (*set_beacon)(void *priv, const u8 *head, size_t head_len,
-                         const u8 *tail, size_t tail_len, int dtim_period,
-                         int beacon_int);
+       int (*deinit_p2p_cli)(void *priv);
 
        /**
-        * hapd_init - Initialize driver interface (hostapd only)
-        * @hapd: Pointer to hostapd context
-        * @params: Configuration for the driver wrapper
-        * Returns: Pointer to private data, %NULL on failure
-        *
-        * This function is used instead of init() or init2() when the driver
-        * wrapper is used withh hostapd.
+        * suspend - Notification on system suspend/hibernate event
+        * @priv: Private driver interface data
         */
-       void * (*hapd_init)(struct hostapd_data *hapd,
-                           struct wpa_init_params *params);
+       void (*suspend)(void *priv);
 
        /**
-        * hapd_deinit - Deinitialize driver interface (hostapd only)
-        * @priv: Private driver interface data from hapd_init()
+        * resume - Notification on system resume/thaw event
+        * @priv: Private driver interface data
         */
-       void (*hapd_deinit)(void *priv);
+       void (*resume)(void *priv);
 
        /**
-        * set_ieee8021x - Enable/disable IEEE 802.1X support (AP only)
+        * signal_monitor - Set signal monitoring parameters
         * @priv: Private driver interface data
-        * @params: BSS parameters
-        * Returns: 0 on success, -1 on failure
+        * @threshold: Threshold value for signal change events; 0 = disabled
+        * @hysteresis: Minimum change in signal strength before indicating a
+        *      new event
+        * Returns: 0 on success, -1 on failure (or if not supported)
         *
-        * This is an optional function to configure the kernel driver to
-        * enable/disable IEEE 802.1X support and set WPA/WPA2 parameters. This
-        * can be left undefined (set to %NULL) if IEEE 802.1X support is
-        * always enabled and the driver uses set_beacon() to set WPA/RSN IE
-        * for Beacon frames.
+        * This function can be used to configure monitoring of signal strength
+        * with the current AP. Whenever signal strength drops below the
+        * %threshold value or increases above it, EVENT_SIGNAL_CHANGE event
+        * should be generated assuming the signal strength has changed at
+        * least %hysteresis from the previously indicated signal change event.
         */
-       int (*set_ieee8021x)(void *priv, struct wpa_bss_params *params);
+       int (*signal_monitor)(void *priv, int threshold, int hysteresis);
 
        /**
-        * set_privacy - Enable/disable privacy (AP only)
+        * send_frame - Send IEEE 802.11 frame (testing use only)
         * @priv: Private driver interface data
-        * @enabled: 1 = privacy enabled, 0 = disabled
+        * @data: IEEE 802.11 frame with IEEE 802.11 header
+        * @data_len: Size of the frame
+        * @encrypt: Whether to encrypt the frame (if keys are set)
         * Returns: 0 on success, -1 on failure
         *
-        * This is an optional function to configure privacy field in the
-        * kernel driver for Beacon frames. This can be left undefined (set to
-        * %NULL) if the driver uses the Beacon template from set_beacon().
+        * This function is only used for debugging purposes and is not
+        * required to be implemented for normal operations.
         */
-       int (*set_privacy)(void *priv, int enabled);
+       int (*send_frame)(void *priv, const u8 *data, size_t data_len,
+                         int encrypt);
 
        /**
-        * get_seqnum - Fetch the current TSC/packet number (AP only)
-        * @ifname: The interface name (main or virtual)
+        * get_noa - Get current Notice of Absence attribute payload
         * @priv: Private driver interface data
-        * @addr: MAC address of the station or %NULL for group keys
-        * @idx: Key index
-        * @seq: Buffer for returning the latest used TSC/packet number
-        * Returns: 0 on success, -1 on failure
+        * @buf: Buffer for returning NoA
+        * @buf_len: Buffer length in octets
+        * Returns: Number of octets used in buf, 0 to indicate no NoA is being
+        * advertized, or -1 on failure
         *
-        * This function is used to fetch the last used TSC/packet number for
-        * a TKIP, CCMP, or BIP/IGTK key. It is mainly used with group keys, so
-        * there is no strict requirement on implementing support for unicast
-        * keys (i.e., addr != %NULL).
+        * This function is used to fetch the current Notice of Absence
+        * attribute value from GO.
         */
-       int (*get_seqnum)(const char *ifname, void *priv, const u8 *addr,
-                         int idx, u8 *seq);
+       int (*get_noa)(void *priv, u8 *buf, size_t buf_len);
 
        /**
-        * flush - Flush all association stations (AP only)
+        * set_noa - Set Notice of Absence parameters for GO (testing)
         * @priv: Private driver interface data
-        * Returns: 0 on success, -1 on failure
+        * @count: Count
+        * @start: Start time in ms from next TBTT
+        * @duration: Duration in ms
+        * Returns: 0 on success or -1 on failure
         *
-        * This function requests the driver to disassociate all associated
-        * stations. This function does not need to be implemented if the
-        * driver does not process association frames internally.
+        * This function is used to set Notice of Absence parameters for GO. It
+        * is used only for testing. To disable NoA, all parameters are set to
+        * 0.
         */
-       int (*flush)(void *priv);
+       int (*set_noa)(void *priv, u8 count, int start, int duration);
 
        /**
-        * set_generic_elem - Add IEs into Beacon/Probe Response frames (AP)
+        * set_p2p_powersave - Set P2P power save options
         * @priv: Private driver interface data
-        * @elem: Information elements
-        * @elem_len: Length of the elem buffer in octets
-        * Returns: 0 on success, -1 on failure
-        *
-        * This is an optional function to add information elements in the
-        * kernel driver for Beacon and Probe Response frames. This can be left
-        * undefined (set to %NULL) if the driver uses the Beacon template from
-        * set_beacon().
+        * @legacy_ps: 0 = disable, 1 = enable, 2 = maximum PS, -1 = no change
+        * @opp_ps: 0 = disable, 1 = enable, -1 = no change
+        * @ctwindow: 0.. = change (msec), -1 = no change
+        * Returns: 0 on success or -1 on failure
         */
-       int (*set_generic_elem)(void *priv, const u8 *elem, size_t elem_len);
+       int (*set_p2p_powersave)(void *priv, int legacy_ps, int opp_ps,
+                                int ctwindow);
 
        /**
-        * read_sta_data - Fetch station data (AP only)
+        * ampdu - Enable/disable aggregation
         * @priv: Private driver interface data
-        * @data: Buffer for returning station information
-        * @addr: MAC address of the station
-        * Returns: 0 on success, -1 on failure
+        * @ampdu: 1/0 = enable/disable A-MPDU aggregation
+        * Returns: 0 on success or -1 on failure
         */
-       int (*read_sta_data)(void *priv, struct hostap_sta_driver_data *data,
-                            const u8 *addr);
+       int (*ampdu)(void *priv, int ampdu);
 
        /**
-        * hapd_send_eapol - Send an EAPOL packet (AP only)
-        * @priv: private driver interface data
-        * @addr: Destination MAC address
-        * @data: EAPOL packet starting with IEEE 802.1X header
-        * @data_len: Length of the EAPOL packet in octets
-        * @encrypt: Whether the frame should be encrypted
-        * @own_addr: Source MAC address
+        * get_radio_name - Get physical radio name for the device
+        * @priv: Private driver interface data
+        * Returns: Radio name or %NULL if not known
+        *
+        * The returned data must not be modified by the caller. It is assumed
+        * that any interface that has the same radio name as another is
+        * sharing the same physical radio. This information can be used to
+        * share scan results etc. information between the virtual interfaces
+        * to speed up various operations.
+        */
+       const char * (*get_radio_name)(void *priv);
+
+       /**
+        * send_tdls_mgmt - for sending TDLS management packets
+        * @priv: private driver interface data
+        * @dst: Destination (peer) MAC address
+        * @action_code: TDLS action code for the mssage
+        * @dialog_token: Dialog Token to use in the message (if needed)
+        * @status_code: Status Code or Reason Code to use (if needed)
+        * @peer_capab: TDLS peer capability (TDLS_PEER_* bitfield)
+        * @initiator: Is the current end the TDLS link initiator
+        * @buf: TDLS IEs to add to the message
+        * @len: Length of buf in octets
+        * Returns: 0 on success, negative (<0) on failure
         *
-        * Returns: 0 on success, -1 on failure
+        * This optional function can be used to send packet to driver which is
+        * responsible for receiving and sending all TDLS packets.
         */
-       int (*hapd_send_eapol)(void *priv, const u8 *addr, const u8 *data,
-                              size_t data_len, int encrypt,
-                              const u8 *own_addr);
+       int (*send_tdls_mgmt)(void *priv, const u8 *dst, u8 action_code,
+                             u8 dialog_token, u16 status_code, u32 peer_capab,
+                             int initiator, const u8 *buf, size_t len);
 
        /**
-        * sta_deauth - Deauthenticate a station (AP only)
+        * tdls_oper - Ask the driver to perform high-level TDLS operations
         * @priv: Private driver interface data
-        * @own_addr: Source address and BSSID for the Deauthentication frame
-        * @addr: MAC address of the station to deauthenticate
-        * @reason: Reason code for the Deauthentiation frame
-        * Returns: 0 on success, -1 on failure
+        * @oper: TDLS high-level operation. See %enum tdls_oper
+        * @peer: Destination (peer) MAC address
+        * Returns: 0 on success, negative (<0) on failure
         *
-        * This function requests a specific station to be deauthenticated and
-        * a Deauthentication frame to be sent to it.
+        * This optional function can be used to send high-level TDLS commands
+        * to the driver.
         */
-       int (*sta_deauth)(void *priv, const u8 *own_addr, const u8 *addr,
-                         int reason);
+       int (*tdls_oper)(void *priv, enum tdls_oper oper, const u8 *peer);
 
        /**
-        * sta_disassoc - Disassociate a station (AP only)
+        * wnm_oper - Notify driver of the WNM frame reception
         * @priv: Private driver interface data
-        * @own_addr: Source address and BSSID for the Disassociation frame
-        * @addr: MAC address of the station to disassociate
-        * @reason: Reason code for the Disassociation frame
-        * Returns: 0 on success, -1 on failure
-        *
-        * This function requests a specific station to be disassociated and
-        * a Disassociation frame to be sent to it.
+        * @oper: WNM operation. See %enum wnm_oper
+        * @peer: Destination (peer) MAC address
+        * @buf: Buffer for the driver to fill in (for getting IE)
+        * @buf_len: Return the len of buf
+        * Returns: 0 on success, negative (<0) on failure
         */
-       int (*sta_disassoc)(void *priv, const u8 *own_addr, const u8 *addr,
-                           int reason);
+       int (*wnm_oper)(void *priv, enum wnm_oper oper, const u8 *peer,
+                       u8 *buf, u16 *buf_len);
 
        /**
-        * sta_remove - Remove a station entry (AP only)
+        * set_qos_map - Set QoS Map
         * @priv: Private driver interface data
-        * @addr: MAC address of the station to be removed
-        * Returns: 0 on success, -1 on failure
+        * @qos_map_set: QoS Map
+        * @qos_map_set_len: Length of QoS Map
         */
-       int (*sta_remove)(void *priv, const u8 *addr);
+       int (*set_qos_map)(void *priv, const u8 *qos_map_set,
+                          u8 qos_map_set_len);
 
        /**
-        * hapd_get_ssid - Get the current SSID (AP only)
+        * br_add_ip_neigh - Add a neigh to the bridge ip neigh table
         * @priv: Private driver interface data
-        * @buf: Buffer for returning the SSID
-        * @len: Maximum length of the buffer
-        * Returns: Length of the SSID on success, -1 on failure
-        *
-        * This function need not be implemented if the driver uses Beacon
-        * template from set_beacon() and does not reply to Probe Request
-        * frames.
+        * @version: IP version of the IP address, 4 or 6
+        * @ipaddr: IP address for the neigh entry
+        * @prefixlen: IP address prefix length
+        * @addr: Corresponding MAC address
+        * Returns: 0 on success, negative (<0) on failure
         */
-       int (*hapd_get_ssid)(void *priv, u8 *buf, int len);
+       int (*br_add_ip_neigh)(void *priv, u8 version, const u8 *ipaddr,
+                              int prefixlen, const u8 *addr);
 
        /**
-        * hapd_set_ssid - Set SSID (AP only)
+        * br_delete_ip_neigh - Remove a neigh from the bridge ip neigh table
         * @priv: Private driver interface data
-        * @buf: SSID
-        * @len: Length of the SSID in octets
-        * Returns: 0 on success, -1 on failure
+        * @version: IP version of the IP address, 4 or 6
+        * @ipaddr: IP address for the neigh entry
+        * Returns: 0 on success, negative (<0) on failure
         */
-       int (*hapd_set_ssid)(void *priv, const u8 *buf, int len);
+       int (*br_delete_ip_neigh)(void *priv, u8 version, const u8 *ipaddr);
 
        /**
-        * hapd_set_countermeasures - Enable/disable TKIP countermeasures (AP)
+        * br_port_set_attr - Set a bridge port attribute
+        * @attr: Bridge port attribute to set
+        * @val: Value to be set
+        * Returns: 0 on success, negative (<0) on failure
+        */
+       int (*br_port_set_attr)(void *priv, enum drv_br_port_attr attr,
+                               unsigned int val);
+
+       /**
+        * br_port_set_attr - Set a bridge network parameter
+        * @param: Bridge parameter to set
+        * @val: Value to be set
+        * Returns: 0 on success, negative (<0) on failure
+        */
+       int (*br_set_net_param)(void *priv, enum drv_br_net_param param,
+                               unsigned int val);
+
+       /**
+        * set_wowlan - Set wake-on-wireless triggers
         * @priv: Private driver interface data
-        * @enabled: 1 = countermeasures enabled, 0 = disabled
-        * Returns: 0 on success, -1 on failure
-        *
-        * This need not be implemented if the driver does not take care of
-        * association processing.
+        * @triggers: wowlan triggers
         */
-       int (*hapd_set_countermeasures)(void *priv, int enabled);
+       int (*set_wowlan)(void *priv, const struct wowlan_triggers *triggers);
 
        /**
-        * sta_add - Add a station entry
+        * signal_poll - Get current connection information
         * @priv: Private driver interface data
-        * @params: Station parameters
+        * @signal_info: Connection info structure
+        */
+       int (*signal_poll)(void *priv, struct wpa_signal_info *signal_info);
+
+       /**
+        * set_authmode - Set authentication algorithm(s) for static WEP
+        * @priv: Private driver interface data
+        * @authmode: 1=Open System, 2=Shared Key, 3=both
         * Returns: 0 on success, -1 on failure
         *
-        * This function is used to add a station entry to the driver once the
-        * station has completed association. This is only used if the driver
-        * does not take care of association processing.
+        * This function can be used to set authentication algorithms for AP
+        * mode when static WEP is used. If the driver uses user space MLME/SME
+        * implementation, there is no need to implement this function.
+        *
+        * DEPRECATED - use set_ap() instead
         */
-       int (*sta_add)(void *priv, struct hostapd_sta_add_params *params);
+       int (*set_authmode)(void *priv, int authmode);
 
+#ifdef ANDROID
        /**
-        * get_inact_sec - Get station inactivity duration (AP only)
+        * driver_cmd - Execute driver-specific command
         * @priv: Private driver interface data
-        * @addr: Station address
-        * Returns: Number of seconds station has been inactive, -1 on failure
+        * @cmd: Command to execute
+        * @buf: Return buffer
+        * @buf_len: Buffer length
+        * Returns: 0 on success, -1 on failure
         */
-       int (*get_inact_sec)(void *priv, const u8 *addr);
+       int (*driver_cmd)(void *priv, char *cmd, char *buf, size_t buf_len);
+#endif /* ANDROID */
 
        /**
-        * sta_clear_stats - Clear station statistics (AP only)
+        * vendor_cmd - Execute vendor specific command
         * @priv: Private driver interface data
-        * @addr: Station address
-        * Returns: 0 on success, -1 on failure
+        * @vendor_id: Vendor id
+        * @subcmd: Vendor command id
+        * @data: Vendor command parameters (%NULL if no parameters)
+        * @data_len: Data length
+        * @buf: Return buffer (%NULL to ignore reply)
+        * Returns: 0 on success, negative (<0) on failure
+        *
+        * This function handles vendor specific commands that are passed to
+        * the driver/device. The command is identified by vendor id and
+        * command id. Parameters can be passed as argument to the command
+        * in the data buffer. Reply (if any) will be filled in the supplied
+        * return buffer.
+        *
+        * The exact driver behavior is driver interface and vendor specific. As
+        * an example, this will be converted to a vendor specific cfg80211
+        * command in case of the nl80211 driver interface.
         */
-       int (*sta_clear_stats)(void *priv, const u8 *addr);
+       int (*vendor_cmd)(void *priv, unsigned int vendor_id,
+                         unsigned int subcmd, const u8 *data, size_t data_len,
+                         struct wpabuf *buf);
 
        /**
-        * set_freq - Set channel/frequency (AP only)
+        * set_rekey_info - Set rekey information
         * @priv: Private driver interface data
-        * @freq: Channel parameters
-        * Returns: 0 on success, -1 on failure
+        * @kek: Current KEK
+        * @kek_len: KEK length in octets
+        * @kck: Current KCK
+        * @kck_len: KCK length in octets
+        * @replay_ctr: Current EAPOL-Key Replay Counter
+        *
+        * This optional function can be used to provide information for the
+        * driver/firmware to process EAPOL-Key frames in Group Key Handshake
+        * while the host (including wpa_supplicant) is sleeping.
         */
-       int (*set_freq)(void *priv, struct hostapd_freq_params *freq);
+       void (*set_rekey_info)(void *priv, const u8 *kek, size_t kek_len,
+                              const u8 *kck, size_t kck_len,
+                              const u8 *replay_ctr);
 
        /**
-        * set_rts - Set RTS threshold
+        * sta_assoc - Station association indication
         * @priv: Private driver interface data
-        * @rts: RTS threshold in octets
+        * @own_addr: Source address and BSSID for association frame
+        * @addr: MAC address of the station to associate
+        * @reassoc: flag to indicate re-association
+        * @status: association response status code
+        * @ie: assoc response ie buffer
+        * @len: ie buffer length
         * Returns: 0 on success, -1 on failure
+        *
+        * This function indicates the driver to send (Re)Association
+        * Response frame to the station.
         */
-       int (*set_rts)(void *priv, int rts);
+        int (*sta_assoc)(void *priv, const u8 *own_addr, const u8 *addr,
+                         int reassoc, u16 status, const u8 *ie, size_t len);
 
        /**
-        * set_frag - Set fragmentation threshold
+        * sta_auth - Station authentication indication
         * @priv: Private driver interface data
-        * @frag: Fragmentation threshold in octets
-        * Returns: 0 on success, -1 on failure
+        * @own_addr: Source address and BSSID for authentication frame
+        * @addr: MAC address of the station to associate
+        * @seq: authentication sequence number
+        * @status: authentication response status code
+        * @ie: authentication frame ie buffer
+        * @len: ie buffer length
+        *
+        * This function indicates the driver to send Authentication frame
+        * to the station.
         */
-       int (*set_frag)(void *priv, int frag);
+        int (*sta_auth)(void *priv, const u8 *own_addr, const u8 *addr,
+                        u16 seq, u16 status, const u8 *ie, size_t len);
 
        /**
-        * sta_set_flags - Set station flags (AP only)
+        * add_tspec - Add traffic stream
         * @priv: Private driver interface data
-        * @addr: Station address
-        * @total_flags: Bitmap of all WPA_STA_* flags currently set
-        * @flags_or: Bitmap of WPA_STA_* flags to add
-        * @flags_and: Bitmap of WPA_STA_* flags to us as a mask
+        * @addr: MAC address of the station to associate
+        * @tspec_ie: tspec ie buffer
+        * @tspec_ielen: tspec ie length
         * Returns: 0 on success, -1 on failure
+        *
+        * This function adds the traffic steam for the station
+        * and fills the medium_time in tspec_ie.
         */
-       int (*sta_set_flags)(void *priv, const u8 *addr,
-                            int total_flags, int flags_or, int flags_and);
+        int (*add_tspec)(void *priv, const u8 *addr, u8 *tspec_ie,
+                         size_t tspec_ielen);
 
        /**
-        * set_rate_sets - Set supported and basic rate sets (AP only)
+        * add_sta_node - Add a station node in the driver
         * @priv: Private driver interface data
-        * @supp_rates: -1 terminated array of supported rates in 100 kbps
-        * @basic_rates: -1 terminated array of basic rates in 100 kbps
-        * @mode: hardware mode (HOSTAPD_MODE_*)
+        * @addr: MAC address of the station to add
+        * @auth_alg: authentication algorithm used by the station
         * Returns: 0 on success, -1 on failure
+        *
+        * This function adds the station node in the driver, when
+        * the station gets added by FT-over-DS.
         */
-       int (*set_rate_sets)(void *priv, int *supp_rates, int *basic_rates,
-                            int mode);
+       int (*add_sta_node)(void *priv, const u8 *addr, u16 auth_alg);
 
        /**
-        * set_cts_protect - Set CTS protection mode (AP only)
+        * sched_scan - Request the driver to initiate scheduled scan
         * @priv: Private driver interface data
-        * @value: Whether CTS protection is enabled
+        * @params: Scan parameters
+        * @interval: Interval between scan cycles in milliseconds
         * Returns: 0 on success, -1 on failure
+        *
+        * This operation should be used for scheduled scan offload to
+        * the hardware. Every time scan results are available, the
+        * driver should report scan results event for wpa_supplicant
+        * which will eventually request the results with
+        * wpa_driver_get_scan_results2(). This operation is optional
+        * and if not provided or if it returns -1, we fall back to
+        * normal host-scheduled scans.
         */
-       int (*set_cts_protect)(void *priv, int value);
+       int (*sched_scan)(void *priv, struct wpa_driver_scan_params *params,
+                         u32 interval);
 
        /**
-        * set_preamble - Set preamble mode (AP only)
+        * stop_sched_scan - Request the driver to stop a scheduled scan
         * @priv: Private driver interface data
-        * @value: Whether short preamble is enabled
         * Returns: 0 on success, -1 on failure
+        *
+        * This should cause the scheduled scan to be stopped and
+        * results should stop being sent. Must be supported if
+        * sched_scan is supported.
         */
-       int (*set_preamble)(void *priv, int value);
+       int (*stop_sched_scan)(void *priv);
 
        /**
-        * set_short_slot_time - Set short slot time (AP only)
+        * poll_client - Probe (null data or such) the given station
         * @priv: Private driver interface data
-        * @value: Whether short slot time is enabled
-        * Returns: 0 on success, -1 on failure
+        * @own_addr: MAC address of sending interface
+        * @addr: MAC address of the station to probe
+        * @qos: Indicates whether station is QoS station
+        *
+        * This function is used to verify whether an associated station is
+        * still present. This function does not need to be implemented if the
+        * driver provides such inactivity polling mechanism.
         */
-       int (*set_short_slot_time)(void *priv, int value);
+       void (*poll_client)(void *priv, const u8 *own_addr,
+                           const u8 *addr, int qos);
 
        /**
-        * set_tx_queue_params - Set TX queue parameters
+        * radio_disable - Disable/enable radio
         * @priv: Private driver interface data
-        * @queue: Queue number
-        * @aifs: AIFS
-        * @cw_min: cwMin
-        * @cw_max: cwMax
-        * @burst_time: Maximum length for bursting in 0.1 msec units
+        * @disabled: 1=disable 0=enable radio
+        * Returns: 0 on success, -1 on failure
+        *
+        * This optional command is for testing purposes. It can be used to
+        * disable the radio on a testbed device to simulate out-of-radio-range
+        * conditions.
         */
-       int (*set_tx_queue_params)(void *priv, int queue, int aifs, int cw_min,
-                                  int cw_max, int burst_time);
+       int (*radio_disable)(void *priv, int disabled);
 
        /**
-        * valid_bss_mask - Validate BSSID mask
+        * switch_channel - Announce channel switch and migrate the GO to the
+        * given frequency
         * @priv: Private driver interface data
-        * @addr: Address
-        * @mask: Mask
-        * Returns: 0 if mask is valid, -1 if mask is not valid, 1 if mask can
-        * be used, but the main interface address must be the first address in
-        * the block if mask is applied
+        * @settings: Settings for CSA period and new channel
+        * Returns: 0 on success, -1 on failure
+        *
+        * This function is used to move the GO to the legacy STA channel to
+        * avoid frequency conflict in single channel concurrency.
         */
-       int (*valid_bss_mask)(void *priv, const u8 *addr, const u8 *mask);
+       int (*switch_channel)(void *priv, struct csa_settings *settings);
 
        /**
-        * if_add - Add a virtual interface
+        * add_tx_ts - Add traffic stream
         * @priv: Private driver interface data
-        * @type: Interface type
-        * @ifname: Interface name for the new virtual interface
-        * @addr: Local address to use for the interface or %NULL to use the
-        *      parent interface address
-        * @bss_ctx: BSS context for %WPA_IF_AP_BSS interfaces
-        * @drv_priv: Pointer for overwriting the driver context or %NULL if
-        *      not allowed (applies only to %WPA_IF_AP_BSS type)
-        * @force_ifname: Buffer for returning an interface name that the
-        *      driver ended up using if it differs from the requested ifname
-        * @if_addr: Buffer for returning the allocated interface address
-        *      (this may differ from the requested addr if the driver cannot
-        *      change interface address)
+        * @tsid: Traffic stream ID
+        * @addr: Receiver address
+        * @user_prio: User priority of the traffic stream
+        * @admitted_time: Admitted time for this TS in units of
+        *      32 microsecond periods (per second).
         * Returns: 0 on success, -1 on failure
         */
-       int (*if_add)(void *priv, enum wpa_driver_if_type type,
-                     const char *ifname, const u8 *addr, void *bss_ctx,
-                     void **drv_priv, char *force_ifname, u8 *if_addr);
+       int (*add_tx_ts)(void *priv, u8 tsid, const u8 *addr, u8 user_prio,
+                        u16 admitted_time);
 
        /**
-        * if_remove - Remove a virtual interface
+        * del_tx_ts - Delete traffic stream
         * @priv: Private driver interface data
-        * @type: Interface type
-        * @ifname: Interface name of the virtual interface to be removed
+        * @tsid: Traffic stream ID
+        * @addr: Receiver address
         * Returns: 0 on success, -1 on failure
         */
-       int (*if_remove)(void *priv, enum wpa_driver_if_type type,
-                        const char *ifname);
+       int (*del_tx_ts)(void *priv, u8 tsid, const u8 *addr);
 
        /**
-        * set_sta_vlan - Bind a station into a specific interface (AP only)
+        * Enable channel-switching with TDLS peer
         * @priv: Private driver interface data
-        * @ifname: Interface (main or virtual BSS or VLAN)
-        * @addr: MAC address of the associated station
-        * @vlan_id: VLAN ID
+        * @addr: MAC address of the TDLS peer
+        * @oper_class: Operating class of the switch channel
+        * @params: Channel specification
         * Returns: 0 on success, -1 on failure
         *
-        * This function is used to bind a station to a specific virtual
-        * interface. It is only used if when virtual interfaces are supported,
-        * e.g., to assign stations to different VLAN interfaces based on
-        * information from a RADIUS server. This allows separate broadcast
-        * domains to be used with a single BSS.
+        * The function indicates to driver that it can start switching to a
+        * different channel with a specified TDLS peer. The switching is
+        * assumed on until canceled with tdls_disable_channel_switch().
         */
-       int (*set_sta_vlan)(void *priv, const u8 *addr, const char *ifname,
-                           int vlan_id);
+       int (*tdls_enable_channel_switch)(
+               void *priv, const u8 *addr, u8 oper_class,
+               const struct hostapd_freq_params *params);
 
        /**
-        * commit - Optional commit changes handler (AP only)
-        * @priv: driver private data
+        * Disable channel switching with TDLS peer
+        * @priv: Private driver interface data
+        * @addr: MAC address of the TDLS peer
         * Returns: 0 on success, -1 on failure
         *
-        * This optional handler function can be registered if the driver
-        * interface implementation needs to commit changes (e.g., by setting
-        * network interface up) at the end of initial configuration. If set,
-        * this handler will be called after initial setup has been completed.
+        * This function indicates to the driver that it should stop switching
+        * with a given TDLS peer.
         */
-       int (*commit)(void *priv);
+       int (*tdls_disable_channel_switch)(void *priv, const u8 *addr);
 
        /**
-        * send_ether - Send an ethernet packet (AP only)
-        * @priv: private driver interface data
-        * @dst: Destination MAC address
-        * @src: Source MAC address
-        * @proto: Ethertype
-        * @data: EAPOL packet starting with IEEE 802.1X header
-        * @data_len: Length of the EAPOL packet in octets
+        * start_dfs_cac - Listen for radar interference on the channel
+        * @priv: Private driver interface data
+        * @freq: Channel parameters
         * Returns: 0 on success, -1 on failure
         */
-       int (*send_ether)(void *priv, const u8 *dst, const u8 *src, u16 proto,
-                         const u8 *data, size_t data_len);
+       int (*start_dfs_cac)(void *priv, struct hostapd_freq_params *freq);
 
        /**
-        * set_radius_acl_auth - Notification of RADIUS ACL change
+        * stop_ap - Removes beacon from AP
         * @priv: Private driver interface data
-        * @mac: MAC address of the station
-        * @accepted: Whether the station was accepted
-        * @session_timeout: Session timeout for the station
-        * Returns: 0 on success, -1 on failure
+        * Returns: 0 on success, -1 on failure (or if not supported)
+        *
+        * This optional function can be used to disable AP mode related
+        * configuration. Unlike deinit_ap, it does not change to station
+        * mode.
         */
-       int (*set_radius_acl_auth)(void *priv, const u8 *mac, int accepted, 
-                                  u32 session_timeout);
+       int (*stop_ap)(void *priv);
 
        /**
-        * set_radius_acl_expire - Notification of RADIUS ACL expiration
+        * get_survey - Retrieve survey data
         * @priv: Private driver interface data
-        * @mac: MAC address of the station
+        * @freq: If set, survey data for the specified frequency is only
+        *      being requested. If not set, all survey data is requested.
         * Returns: 0 on success, -1 on failure
+        *
+        * Use this to retrieve:
+        *
+        * - the observed channel noise floor
+        * - the amount of time we have spent on the channel
+        * - the amount of time during which we have spent on the channel that
+        *   the radio has determined the medium is busy and we cannot
+        *   transmit
+        * - the amount of time we have spent receiving data
+        * - the amount of time we have spent transmitting data
+        *
+        * This data can be used for spectrum heuristics. One example is
+        * Automatic Channel Selection (ACS). The channel survey data is
+        * kept on a linked list on the channel data, one entry is added
+        * for each survey. The min_nf of the channel is updated for each
+        * survey.
         */
-       int (*set_radius_acl_expire)(void *priv, const u8 *mac);
+       int (*get_survey)(void *priv, unsigned int freq);
 
        /**
-        * set_ht_params - Set HT parameters (AP only)
+        * status - Get driver interface status information
         * @priv: Private driver interface data
-        * @ht_capab: HT Capabilities IE
-        * @ht_capab_len: Length of ht_capab in octets
-        * @ht_oper: HT Operation IE
-        * @ht_oper_len: Length of ht_oper in octets
-        * Returns: 0 on success, -1 on failure
+        * @buf: Buffer for printing tou the status information
+        * @buflen: Maximum length of the buffer
+        * Returns: Length of written status information or -1 on failure
         */
-       int (*set_ht_params)(void *priv,
-                            const u8 *ht_capab, size_t ht_capab_len,
-                            const u8 *ht_oper, size_t ht_oper_len);
+       int (*status)(void *priv, char *buf, size_t buflen);
 
        /**
-        * set_ap_wps_ie - Add WPS IE(s) into Beacon/Probe Response frames (AP)
+        * roaming - Set roaming policy for driver-based BSS selection
         * @priv: Private driver interface data
-        * @beacon: WPS IE(s) for Beacon frames or %NULL to remove extra IE(s)
-        * @proberesp: WPS IE(s) for Probe Response frames or %NULL to remove
-        *      extra IE(s)
-        * @assocresp: WPS IE(s) for (Re)Association Response frames or %NULL
-        *      to remove extra IE(s)
-        * Returns: 0 on success, -1 on failure
-        *
-        * This is an optional function to add WPS IE in the kernel driver for
-        * Beacon and Probe Response frames. This can be left undefined (set
-        * to %NULL) if the driver uses the Beacon template from set_beacon()
-        * and does not process Probe Request frames. If the driver takes care
-        * of (Re)Association frame processing, the assocresp buffer includes
-        * WPS IE(s) that need to be added to (Re)Association Response frames
-        * whenever a (Re)Association Request frame indicated use of WPS.
+        * @allowed: Whether roaming within ESS is allowed
+        * @bssid: Forced BSSID if roaming is disabled or %NULL if not set
+        * Returns: Length of written status information or -1 on failure
         *
-        * This will also be used to add P2P IE(s) into Beacon/Probe Response
-        * frames when operating as a GO. The driver is responsible for adding
-        * timing related attributes (e.g., NoA) in addition to the IEs
-        * included here by appending them after these buffers. This call is
-        * also used to provide Probe Response IEs for P2P Listen state
-        * operations for drivers that generate the Probe Response frames
-        * internally.
+        * This optional callback can be used to update roaming policy from the
+        * associate() command (bssid being set there indicates that the driver
+        * should not roam before getting this roaming() call to allow roaming.
+        * If the driver does not indicate WPA_DRIVER_FLAGS_BSS_SELECTION
+        * capability, roaming policy is handled within wpa_supplicant and there
+        * is no need to implement or react to this callback.
         */
-       int (*set_ap_wps_ie)(void *priv, const struct wpabuf *beacon,
-                            const struct wpabuf *proberesp,
-                            const struct wpabuf *assocresp);
+       int (*roaming)(void *priv, int allowed, const u8 *bssid);
 
        /**
-        * set_supp_port - Set IEEE 802.1X Supplicant Port status
+        * set_mac_addr - Set MAC address
         * @priv: Private driver interface data
-        * @authorized: Whether the port is authorized
+        * @addr: MAC address to use or %NULL for setting back to permanent
         * Returns: 0 on success, -1 on failure
         */
-       int (*set_supp_port)(void *priv, int authorized);
+       int (*set_mac_addr)(void *priv, const u8 *addr);
+
+#ifdef CONFIG_MACSEC
+       int (*macsec_init)(void *priv, struct macsec_init_params *params);
+
+       int (*macsec_deinit)(void *priv);
 
        /**
-        * set_wds_sta - Bind a station into a 4-address WDS (AP only)
+        * enable_protect_frames - Set protect frames status
         * @priv: Private driver interface data
-        * @addr: MAC address of the associated station
-        * @aid: Association ID
-        * @val: 1 = bind to 4-address WDS; 0 = unbind
-        * Returns: 0 on success, -1 on failure
+        * @enabled: TRUE = protect frames enabled
+        *           FALSE = protect frames disabled
+        * Returns: 0 on success, -1 on failure (or if not supported)
         */
-       int (*set_wds_sta)(void *priv, const u8 *addr, int aid, int val);
+       int (*enable_protect_frames)(void *priv, Boolean enabled);
 
        /**
-        * send_action - Transmit an Action frame
+        * set_replay_protect - Set replay protect status and window size
         * @priv: Private driver interface data
-        * @freq: Frequency (in MHz) of the channel
-        * @dst: Destination MAC address (Address 1)
-        * @src: Source MAC address (Address 2)
-        * @bssid: BSSID (Address 3)
-        * @data: Frame body
-        * @data_len: data length in octets
-        * Returns: 0 on success, -1 on failure
-        *
-        * This command can be used to request the driver to transmit an action
-        * frame to the specified destination. If a remain-on-channel duration
-        * is in progress, the frame is transmitted on that channel. Otherwise,
-        * the frame is transmitted on the current operational channel if in
-        * associated state in station mode or if operating as an AP. If none
-        * of these conditions is in effect, send_action() cannot be used.
+        * @enabled: TRUE = replay protect enabled
+        *           FALSE = replay protect disabled
+        * @window: replay window size, valid only when replay protect enabled
+        * Returns: 0 on success, -1 on failure (or if not supported)
         */
-       int (*send_action)(void *priv, unsigned int freq,
-                          const u8 *dst, const u8 *src, const u8 *bssid,
-                          const u8 *data, size_t data_len);
+       int (*set_replay_protect)(void *priv, Boolean enabled, u32 window);
 
        /**
-        * remain_on_channel - Remain awake on a channel
+        * set_current_cipher_suite - Set current cipher suite
         * @priv: Private driver interface data
-        * @freq: Frequency (in MHz) of the channel
-        * @duration: Duration in milliseconds
-        * Returns: 0 on success, -1 on failure
-        *
-        * This command is used to request the driver to remain awake on the
-        * specified channel for the specified duration and report received
-        * Action frames with EVENT_RX_ACTION events. Optionally, received
-        * Probe Request frames may also be requested to be reported by calling
-        * probe_req_report(). These will be reported with EVENT_RX_PROBE_REQ.
-        *
-        * The driver may not be at the requested channel when this function
-        * returns, i.e., the return code is only indicating whether the
-        * request was accepted. The caller will need to wait until the
-        * EVENT_REMAIN_ON_CHANNEL event indicates that the driver has
-        * completed the channel change. This may take some time due to other
-        * need for the radio and the caller should be prepared to timing out
-        * its wait since there are no guarantees on when this request can be
-        * executed.
+        * @cs: EUI64 identifier
+        * @cs_len: Length of the cs buffer in octets
+        * Returns: 0 on success, -1 on failure (or if not supported)
         */
-       int (*remain_on_channel)(void *priv, unsigned int freq,
-                                unsigned int duration);
+       int (*set_current_cipher_suite)(void *priv, const u8 *cs,
+                                       size_t cs_len);
 
        /**
-        * cancel_remain_on_channel - Cancel remain-on-channel operation
+        * enable_controlled_port - Set controlled port status
         * @priv: Private driver interface data
-        *
-        * This command can be used to cancel a remain-on-channel operation
-        * before its originally requested duration has passed. This could be
-        * used, e.g., when remain_on_channel() is used to request extra time
-        * to receive a response to an Action frame and the response is
-        * received when there is still unneeded time remaining on the
-        * remain-on-channel operation.
+        * @enabled: TRUE = controlled port enabled
+        *           FALSE = controlled port disabled
+        * Returns: 0 on success, -1 on failure (or if not supported)
         */
-       int (*cancel_remain_on_channel)(void *priv);
+       int (*enable_controlled_port)(void *priv, Boolean enabled);
 
        /**
-        * probe_req_report - Request Probe Request frames to be indicated
+        * get_receive_lowest_pn - Get receive lowest pn
         * @priv: Private driver interface data
-        * @report: Whether to report received Probe Request frames
+        * @channel: secure channel
+        * @an: association number
+        * @lowest_pn: lowest accept pn
         * Returns: 0 on success, -1 on failure (or if not supported)
-        *
-        * This command can be used to request the driver to indicate when
-        * Probe Request frames are received with EVENT_RX_PROBE_REQ events.
-        * Since this operation may require extra resources, e.g., due to less
-        * optimal hardware/firmware RX filtering, many drivers may disable
-        * Probe Request reporting at least in station mode. This command is
-        * used to notify the driver when the Probe Request frames need to be
-        * reported, e.g., during remain-on-channel operations.
         */
-       int (*probe_req_report)(void *priv, int report);
+       int (*get_receive_lowest_pn)(void *priv, u32 channel, u8 an,
+                                    u32 *lowest_pn);
 
        /**
-        * disable_11b_rates - Set whether IEEE 802.11b rates are used for TX
+        * get_transmit_next_pn - Get transmit next pn
         * @priv: Private driver interface data
-        * @disabled: Whether IEEE 802.11b rates are disabled
+        * @channel: secure channel
+        * @an: association number
+        * @next_pn: next pn
         * Returns: 0 on success, -1 on failure (or if not supported)
-        *
-        * This command is used to disable IEEE 802.11b rates (1, 2, 5.5, and
-        * 11 Mbps) as TX rates for data and management frames. This can be
-        * used to optimize channel use when there is no need to support IEEE
-        * 802.11b-only devices.
         */
-       int (*disable_11b_rates)(void *priv, int disabled);
+       int (*get_transmit_next_pn)(void *priv, u32 channel, u8 an,
+                                   u32 *next_pn);
 
        /**
-        * deinit_ap - Deinitialize AP mode
+        * set_transmit_next_pn - Set transmit next pn
         * @priv: Private driver interface data
+        * @channel: secure channel
+        * @an: association number
+        * @next_pn: next pn
         * Returns: 0 on success, -1 on failure (or if not supported)
-        *
-        * This optional function can be used to disable AP mode related
-        * configuration and change the driver mode to station mode to allow
-        * normal station operations like scanning to be completed.
         */
-       int (*deinit_ap)(void *priv);
+       int (*set_transmit_next_pn)(void *priv, u32 channel, u8 an,
+                                   u32 next_pn);
 
        /**
-        * suspend - Notification on system suspend/hibernate event
+        * get_available_receive_sc - get available receive channel
         * @priv: Private driver interface data
+        * @channel: secure channel
+        * Returns: 0 on success, -1 on failure (or if not supported)
         */
-       void (*suspend)(void *priv);
+       int (*get_available_receive_sc)(void *priv, u32 *channel);
 
        /**
-        * resume - Notification on system resume/thaw event
+        * create_receive_sc - create secure channel for receiving
         * @priv: Private driver interface data
+        * @channel: secure channel
+        * @sci_addr: secure channel identifier - address
+        * @sci_port: secure channel identifier - port
+        * @conf_offset: confidentiality offset (0, 30, or 50)
+        * @validation: frame validation policy (0 = Disabled, 1 = Checked,
+        *      2 = Strict)
+        * Returns: 0 on success, -1 on failure (or if not supported)
         */
-       void (*resume)(void *priv);
+       int (*create_receive_sc)(void *priv, u32 channel, const u8 *sci_addr,
+                                u16 sci_port, unsigned int conf_offset,
+                                int validation);
 
        /**
-        * signal_monitor - Set signal monitoring parameters
+        * delete_receive_sc - delete secure connection for receiving
+        * @priv: private driver interface data from init()
+        * @channel: secure channel
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*delete_receive_sc)(void *priv, u32 channel);
+
+       /**
+        * create_receive_sa - create secure association for receive
+        * @priv: private driver interface data from init()
+        * @channel: secure channel
+        * @an: association number
+        * @lowest_pn: the lowest packet number can be received
+        * @sak: the secure association key
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*create_receive_sa)(void *priv, u32 channel, u8 an,
+                                u32 lowest_pn, const u8 *sak);
+
+       /**
+        * enable_receive_sa - enable the SA for receive
+        * @priv: private driver interface data from init()
+        * @channel: secure channel
+        * @an: association number
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*enable_receive_sa)(void *priv, u32 channel, u8 an);
+
+       /**
+        * disable_receive_sa - disable SA for receive
+        * @priv: private driver interface data from init()
+        * @channel: secure channel index
+        * @an: association number
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*disable_receive_sa)(void *priv, u32 channel, u8 an);
+
+       /**
+        * get_available_transmit_sc - get available transmit channel
         * @priv: Private driver interface data
-        * @threshold: Threshold value for signal change events; 0 = disabled
-        * @hysteresis: Minimum change in signal strength before indicating a
-        *      new event
+        * @channel: secure channel
         * Returns: 0 on success, -1 on failure (or if not supported)
-        *
-        * This function can be used to configure monitoring of signal strength
-        * with the current AP. Whenever signal strength drops below the
-        * %threshold value or increases above it, EVENT_SIGNAL_CHANGE event
-        * should be generated assuming the signal strength has changed at
-        * least %hysteresis from the previously indicated signal change event.
         */
-       int (*signal_monitor)(void *priv, int threshold, int hysteresis);
+       int (*get_available_transmit_sc)(void *priv, u32 *channel);
 
        /**
-        * send_frame - Send IEEE 802.11 frame (testing use only)
+        * create_transmit_sc - create secure connection for transmit
+        * @priv: private driver interface data from init()
+        * @channel: secure channel
+        * @sci_addr: secure channel identifier - address
+        * @sci_port: secure channel identifier - port
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*create_transmit_sc)(void *priv, u32 channel, const u8 *sci_addr,
+                                 u16 sci_port, unsigned int conf_offset);
+
+       /**
+        * delete_transmit_sc - delete secure connection for transmit
+        * @priv: private driver interface data from init()
+        * @channel: secure channel
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*delete_transmit_sc)(void *priv, u32 channel);
+
+       /**
+        * create_transmit_sa - create secure association for transmit
+        * @priv: private driver interface data from init()
+        * @channel: secure channel index
+        * @an: association number
+        * @next_pn: the packet number used as next transmit packet
+        * @confidentiality: True if the SA is to provide confidentiality
+        *                   as well as integrity
+        * @sak: the secure association key
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*create_transmit_sa)(void *priv, u32 channel, u8 an, u32 next_pn,
+                                 Boolean confidentiality, const u8 *sak);
+
+       /**
+        * enable_transmit_sa - enable SA for transmit
+        * @priv: private driver interface data from init()
+        * @channel: secure channel
+        * @an: association number
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*enable_transmit_sa)(void *priv, u32 channel, u8 an);
+
+       /**
+        * disable_transmit_sa - disable SA for transmit
+        * @priv: private driver interface data from init()
+        * @channel: secure channel
+        * @an: association number
+        * Returns: 0 on success, -1 on failure
+        */
+       int (*disable_transmit_sa)(void *priv, u32 channel, u8 an);
+#endif /* CONFIG_MACSEC */
+
+       /**
+        * init_mesh - Driver specific initialization for mesh
         * @priv: Private driver interface data
-        * @data: IEEE 802.11 frame with IEEE 802.11 header
-        * @data_len: Size of the frame
-        * @encrypt: Whether to encrypt the frame (if keys are set)
         * Returns: 0 on success, -1 on failure
-        *
-        * This function is only used for debugging purposes and is not
-        * required to be implemented for normal operations.
         */
-       int (*send_frame)(void *priv, const u8 *data, size_t data_len,
-                         int encrypt);
+       int (*init_mesh)(void *priv);
 
        /**
-        * shared_freq - Get operating frequency of shared interface(s)
+        * join_mesh - Join a mesh network
         * @priv: Private driver interface data
-        * Returns: Operating frequency in MHz, 0 if no shared operation in
-        * use, or -1 on failure
-        *
-        * This command can be used to request the current operating frequency
-        * of any virtual interface that shares the same radio to provide
-        * information for channel selection for other virtual interfaces.
+        * @params: Mesh configuration parameters
+        * Returns: 0 on success, -1 on failure
         */
-       int (*shared_freq)(void *priv);
+       int (*join_mesh)(void *priv,
+                        struct wpa_driver_mesh_join_params *params);
 
        /**
-        * get_noa - Get current Notice of Absence attribute payload
+        * leave_mesh - Leave a mesh network
         * @priv: Private driver interface data
-        * @buf: Buffer for returning NoA
-        * @buf_len: Buffer length in octets
-        * Returns: Number of octets used in buf, 0 to indicate no NoA is being
-        * advertized, or -1 on failure
-        *
-        * This function is used to fetch the current Notice of Absence
-        * attribute value from GO.
+        * Returns 0 on success, -1 on failure
         */
-       int (*get_noa)(void *priv, u8 *buf, size_t buf_len);
+       int (*leave_mesh)(void *priv);
 
        /**
-        * set_noa - Set Notice of Absence parameters for GO (testing)
+        * do_acs - Automatically select channel
         * @priv: Private driver interface data
-        * @count: Count
-        * @start: Start time in ms from next TBTT
-        * @duration: Duration in ms
-        * Returns: 0 on success or -1 on failure
+        * @params: Parameters for ACS
+        * Returns 0 on success, -1 on failure
         *
-        * This function is used to set Notice of Absence parameters for GO. It
-        * is used only for testing. To disable NoA, all parameters are set to
-        * 0.
+        * This command can be used to offload ACS to the driver if the driver
+        * indicates support for such offloading (WPA_DRIVER_FLAGS_ACS_OFFLOAD).
         */
-       int (*set_noa)(void *priv, u8 count, int start, int duration);
+       int (*do_acs)(void *priv, struct drv_acs_params *params);
 
        /**
-        * set_p2p_powersave - Set P2P power save options
+        * set_band - Notify driver of band selection
         * @priv: Private driver interface data
-        * @legacy_ps: 0 = disable, 1 = enable, 2 = maximum PS, -1 = no change
-        * @opp_ps: 0 = disable, 1 = enable, -1 = no change
-        * @ctwindow: 0.. = change (msec), -1 = no change
-        * Returns: 0 on success or -1 on failure
+        * @band: The selected band(s)
+        * Returns 0 on success, -1 on failure
         */
-       int (*set_p2p_powersave)(void *priv, int legacy_ps, int opp_ps,
-                                int ctwindow);
+       int (*set_band)(void *priv, enum set_band band);
 
        /**
-        * ampdu - Enable/disable aggregation
+        * get_pref_freq_list - Get preferred frequency list for an interface
         * @priv: Private driver interface data
-        * @ampdu: 1/0 = enable/disable A-MPDU aggregation
-        * Returns: 0 on success or -1 on failure
+        * @if_type: Interface type
+        * @num: Number of channels
+        * @freq_list: Preferred channel frequency list encoded in MHz values
+        * Returns 0 on success, -1 on failure
+        *
+        * This command can be used to query the preferred frequency list from
+        * the driver specific to a particular interface type.
         */
-       int (*ampdu)(void *priv, int ampdu);
+       int (*get_pref_freq_list)(void *priv, enum wpa_driver_if_type if_type,
+                                 unsigned int *num, unsigned int *freq_list);
 
        /**
-        * set_intra_bss - Enables/Disables intra BSS bridging
+        * set_prob_oper_freq - Indicate probable P2P operating channel
+        * @priv: Private driver interface data
+        * @freq: Channel frequency in MHz
+        * Returns 0 on success, -1 on failure
+        *
+        * This command can be used to inform the driver of the operating
+        * frequency that an ongoing P2P group formation is likely to come up
+        * on. Local device is assuming P2P Client role.
         */
-       int (*set_intra_bss)(void *priv, int enabled);
+       int (*set_prob_oper_freq)(void *priv, unsigned int freq);
 };
 
 
@@ -2028,6 +3561,13 @@ enum wpa_event_type {
        EVENT_STKSTART,
 
        /**
+        * EVENT_TDLS - Request TDLS operation
+        *
+        * This event can be used to request a TDLS operation to be performed.
+        */
+       EVENT_TDLS,
+
+       /**
         * EVENT_FT_RESPONSE - Report FT (IEEE 802.11r) response IEs
         *
         * The driver is expected to report the received FT IEs from
@@ -2068,153 +3608,357 @@ enum wpa_event_type {
        EVENT_DEAUTH,
 
        /**
-        * EVENT_ASSOC_REJECT - Association rejected
+        * EVENT_ASSOC_REJECT - Association rejected
+        *
+        * This event should be called when (re)association attempt has been
+        * rejected by the AP. Information about the association response is
+        * included in union wpa_event_data::assoc_reject.
+        */
+       EVENT_ASSOC_REJECT,
+
+       /**
+        * EVENT_AUTH_TIMED_OUT - Authentication timed out
+        */
+       EVENT_AUTH_TIMED_OUT,
+
+       /**
+        * EVENT_ASSOC_TIMED_OUT - Association timed out
+        */
+       EVENT_ASSOC_TIMED_OUT,
+
+       /**
+        * EVENT_WPS_BUTTON_PUSHED - Report hardware push button press for WPS
+        */
+       EVENT_WPS_BUTTON_PUSHED,
+
+       /**
+        * EVENT_TX_STATUS - Report TX status
+        */
+       EVENT_TX_STATUS,
+
+       /**
+        * EVENT_RX_FROM_UNKNOWN - Report RX from unknown STA
+        */
+       EVENT_RX_FROM_UNKNOWN,
+
+       /**
+        * EVENT_RX_MGMT - Report RX of a management frame
+        */
+       EVENT_RX_MGMT,
+
+       /**
+        * EVENT_REMAIN_ON_CHANNEL - Remain-on-channel duration started
+        *
+        * This event is used to indicate when the driver has started the
+        * requested remain-on-channel duration. Information about the
+        * operation is included in union wpa_event_data::remain_on_channel.
+        */
+       EVENT_REMAIN_ON_CHANNEL,
+
+       /**
+        * EVENT_CANCEL_REMAIN_ON_CHANNEL - Remain-on-channel timed out
+        *
+        * This event is used to indicate when the driver has completed
+        * remain-on-channel duration, i.e., may noot be available on the
+        * requested channel anymore. Information about the
+        * operation is included in union wpa_event_data::remain_on_channel.
+        */
+       EVENT_CANCEL_REMAIN_ON_CHANNEL,
+
+       /**
+        * EVENT_RX_PROBE_REQ - Indicate received Probe Request frame
+        *
+        * This event is used to indicate when a Probe Request frame has been
+        * received. Information about the received frame is included in
+        * union wpa_event_data::rx_probe_req. The driver is required to report
+        * these events only after successfully completed probe_req_report()
+        * commands to request the events (i.e., report parameter is non-zero)
+        * in station mode. In AP mode, Probe Request frames should always be
+        * reported.
+        */
+       EVENT_RX_PROBE_REQ,
+
+       /**
+        * EVENT_NEW_STA - New wired device noticed
+        *
+        * This event is used to indicate that a new device has been detected
+        * in a network that does not use association-like functionality (i.e.,
+        * mainly wired Ethernet). This can be used to start EAPOL
+        * authenticator when receiving a frame from a device. The address of
+        * the device is included in union wpa_event_data::new_sta.
+        */
+       EVENT_NEW_STA,
+
+       /**
+        * EVENT_EAPOL_RX - Report received EAPOL frame
+        *
+        * When in AP mode with hostapd, this event is required to be used to
+        * deliver the receive EAPOL frames from the driver.
+        */
+       EVENT_EAPOL_RX,
+
+       /**
+        * EVENT_SIGNAL_CHANGE - Indicate change in signal strength
+        *
+        * This event is used to indicate changes in the signal strength
+        * observed in frames received from the current AP if signal strength
+        * monitoring has been enabled with signal_monitor().
+        */
+       EVENT_SIGNAL_CHANGE,
+
+       /**
+        * EVENT_INTERFACE_ENABLED - Notify that interface was enabled
+        *
+        * This event is used to indicate that the interface was enabled after
+        * having been previously disabled, e.g., due to rfkill.
+        */
+       EVENT_INTERFACE_ENABLED,
+
+       /**
+        * EVENT_INTERFACE_DISABLED - Notify that interface was disabled
+        *
+        * This event is used to indicate that the interface was disabled,
+        * e.g., due to rfkill.
+        */
+       EVENT_INTERFACE_DISABLED,
+
+       /**
+        * EVENT_CHANNEL_LIST_CHANGED - Channel list changed
+        *
+        * This event is used to indicate that the channel list has changed,
+        * e.g., because of a regulatory domain change triggered by scan
+        * results including an AP advertising a country code.
+        */
+       EVENT_CHANNEL_LIST_CHANGED,
+
+       /**
+        * EVENT_INTERFACE_UNAVAILABLE - Notify that interface is unavailable
+        *
+        * This event is used to indicate that the driver cannot maintain this
+        * interface in its operation mode anymore. The most likely use for
+        * this is to indicate that AP mode operation is not available due to
+        * operating channel would need to be changed to a DFS channel when
+        * the driver does not support radar detection and another virtual
+        * interfaces caused the operating channel to change. Other similar
+        * resource conflicts could also trigger this for station mode
+        * interfaces. This event can be propagated when channel switching
+        * fails.
+        */
+       EVENT_INTERFACE_UNAVAILABLE,
+
+       /**
+        * EVENT_BEST_CHANNEL
+        *
+        * Driver generates this event whenever it detects a better channel
+        * (e.g., based on RSSI or channel use). This information can be used
+        * to improve channel selection for a new AP/P2P group.
+        */
+       EVENT_BEST_CHANNEL,
+
+       /**
+        * EVENT_UNPROT_DEAUTH - Unprotected Deauthentication frame received
         *
-        * This event should be called when (re)association attempt has been
-        * rejected by the AP. Information about authentication result is
-        * included in union wpa_event_data::assoc_reject.
+        * This event should be called when a Deauthentication frame is dropped
+        * due to it not being protected (MFP/IEEE 802.11w).
+        * union wpa_event_data::unprot_deauth is required to provide more
+        * details of the frame.
         */
-       EVENT_ASSOC_REJECT,
+       EVENT_UNPROT_DEAUTH,
 
        /**
-        * EVENT_AUTH_TIMED_OUT - Authentication timed out
+        * EVENT_UNPROT_DISASSOC - Unprotected Disassociation frame received
+        *
+        * This event should be called when a Disassociation frame is dropped
+        * due to it not being protected (MFP/IEEE 802.11w).
+        * union wpa_event_data::unprot_disassoc is required to provide more
+        * details of the frame.
         */
-       EVENT_AUTH_TIMED_OUT,
+       EVENT_UNPROT_DISASSOC,
 
        /**
-        * EVENT_ASSOC_TIMED_OUT - Association timed out
+        * EVENT_STATION_LOW_ACK
+        *
+        * Driver generates this event whenever it detected that a particular
+        * station was lost. Detection can be through massive transmission
+        * failures for example.
         */
-       EVENT_ASSOC_TIMED_OUT,
+       EVENT_STATION_LOW_ACK,
 
        /**
-        * EVENT_FT_RRB_RX - FT (IEEE 802.11r) RRB frame received
+        * EVENT_IBSS_PEER_LOST - IBSS peer not reachable anymore
         */
-       EVENT_FT_RRB_RX,
+       EVENT_IBSS_PEER_LOST,
 
        /**
-        * EVENT_WPS_BUTTON_PUSHED - Report hardware push button press for WPS
+        * EVENT_DRIVER_GTK_REKEY - Device/driver did GTK rekey
+        *
+        * This event carries the new replay counter to notify wpa_supplicant
+        * of the current EAPOL-Key Replay Counter in case the driver/firmware
+        * completed Group Key Handshake while the host (including
+        * wpa_supplicant was sleeping).
         */
-       EVENT_WPS_BUTTON_PUSHED,
+       EVENT_DRIVER_GTK_REKEY,
 
        /**
-        * EVENT_TX_STATUS - Report TX status
+        * EVENT_SCHED_SCAN_STOPPED - Scheduled scan was stopped
         */
-       EVENT_TX_STATUS,
+       EVENT_SCHED_SCAN_STOPPED,
 
        /**
-        * EVENT_RX_FROM_UNKNOWN - Report RX from unknown STA
+        * EVENT_DRIVER_CLIENT_POLL_OK - Station responded to poll
+        *
+        * This event indicates that the station responded to the poll
+        * initiated with @poll_client.
         */
-       EVENT_RX_FROM_UNKNOWN,
+       EVENT_DRIVER_CLIENT_POLL_OK,
 
        /**
-        * EVENT_RX_MGMT - Report RX of a management frame
+        * EVENT_EAPOL_TX_STATUS - notify of EAPOL TX status
         */
-       EVENT_RX_MGMT,
+       EVENT_EAPOL_TX_STATUS,
 
        /**
-        * EVENT_RX_ACTION - Action frame received
+        * EVENT_CH_SWITCH - AP or GO decided to switch channels
         *
-        * This event is used to indicate when an Action frame has been
-        * received. Information about the received frame is included in
-        * union wpa_event_data::rx_action.
+        * Described in wpa_event_data.ch_switch
+        * */
+       EVENT_CH_SWITCH,
+
+       /**
+        * EVENT_WNM - Request WNM operation
+        *
+        * This event can be used to request a WNM operation to be performed.
         */
-       EVENT_RX_ACTION,
+       EVENT_WNM,
 
        /**
-        * EVENT_REMAIN_ON_CHANNEL - Remain-on-channel duration started
+        * EVENT_CONNECT_FAILED_REASON - Connection failure reason in AP mode
         *
-        * This event is used to indicate when the driver has started the
-        * requested remain-on-channel duration. Information about the
-        * operation is included in union wpa_event_data::remain_on_channel.
+        * This event indicates that the driver reported a connection failure
+        * with the specified client (for example, max client reached, etc.) in
+        * AP mode.
         */
-       EVENT_REMAIN_ON_CHANNEL,
+       EVENT_CONNECT_FAILED_REASON,
 
        /**
-        * EVENT_CANCEL_REMAIN_ON_CHANNEL - Remain-on-channel timed out
+        * EVENT_DFS_RADAR_DETECTED - Notify of radar detection
         *
-        * This event is used to indicate when the driver has completed
-        * remain-on-channel duration, i.e., may noot be available on the
-        * requested channel anymore. Information about the
-        * operation is included in union wpa_event_data::remain_on_channel.
+        * A radar has been detected on the supplied frequency, hostapd should
+        * react accordingly (e.g., change channel).
         */
-       EVENT_CANCEL_REMAIN_ON_CHANNEL,
+       EVENT_DFS_RADAR_DETECTED,
 
        /**
-        * EVENT_MLME_RX - Report reception of frame for MLME (test use only)
+        * EVENT_DFS_CAC_FINISHED - Notify that channel availability check has been completed
         *
-        * This event is used only by driver_test.c and userspace MLME.
+        * After a successful CAC, the channel can be marked clear and used.
         */
-       EVENT_MLME_RX,
+       EVENT_DFS_CAC_FINISHED,
 
        /**
-        * EVENT_RX_PROBE_REQ - Indicate received Probe Request frame
+        * EVENT_DFS_CAC_ABORTED - Notify that channel availability check has been aborted
         *
-        * This event is used to indicate when a Probe Request frame has been
-        * received. Information about the received frame is included in
-        * union wpa_event_data::rx_probe_req. The driver is required to report
-        * these events only after successfully completed probe_req_report()
-        * commands to request the events (i.e., report parameter is non-zero)
-        * in station mode. In AP mode, Probe Request frames should always be
-        * reported.
+        * The CAC was not successful, and the channel remains in the previous
+        * state. This may happen due to a radar beeing detected or other
+        * external influences.
         */
-       EVENT_RX_PROBE_REQ,
+       EVENT_DFS_CAC_ABORTED,
 
        /**
-        * EVENT_NEW_STA - New wired device noticed
+        * EVENT_DFS_NOP_FINISHED - Notify that non-occupancy period is over
         *
-        * This event is used to indicate that a new device has been detected
-        * in a network that does not use association-like functionality (i.e.,
-        * mainly wired Ethernet). This can be used to start EAPOL
-        * authenticator when receiving a frame from a device. The address of
-        * the device is included in union wpa_event_data::new_sta.
+        * The channel which was previously unavailable is now available again.
         */
-       EVENT_NEW_STA,
+       EVENT_DFS_NOP_FINISHED,
 
        /**
-        * EVENT_EAPOL_RX - Report received EAPOL frame
+        * EVENT_SURVEY - Received survey data
         *
-        * When in AP mode with hostapd, this event is required to be used to
-        * deliver the receive EAPOL frames from the driver. With
-        * %wpa_supplicant, this event is used only if the send_eapol() handler
-        * is used to override the use of l2_packet for EAPOL frame TX.
+        * This event gets triggered when a driver query is issued for survey
+        * data and the requested data becomes available. The returned data is
+        * stored in struct survey_results. The results provide at most one
+        * survey entry for each frequency and at minimum will provide one
+        * survey entry for one frequency. The survey data can be os_malloc()'d
+        * and then os_free()'d, so the event callback must only copy data.
         */
-       EVENT_EAPOL_RX,
+       EVENT_SURVEY,
 
        /**
-        * EVENT_SIGNAL_CHANGE - Indicate change in signal strength
+        * EVENT_SCAN_STARTED - Scan started
         *
-        * This event is used to indicate changes in the signal strength
-        * observed in frames received from the current AP if signal strength
-        * monitoring has been enabled with signal_monitor().
+        * This indicates that driver has started a scan operation either based
+        * on a request from wpa_supplicant/hostapd or from another application.
+        * EVENT_SCAN_RESULTS is used to indicate when the scan has been
+        * completed (either successfully or by getting cancelled).
         */
-       EVENT_SIGNAL_CHANGE,
+       EVENT_SCAN_STARTED,
 
        /**
-        * EVENT_INTERFACE_ENABLED - Notify that interface was enabled
+        * EVENT_AVOID_FREQUENCIES - Received avoid frequency range
         *
-        * This event is used to indicate that the interface was enabled after
-        * having been previously disabled, e.g., due to rfkill.
+        * This event indicates a set of frequency ranges that should be avoided
+        * to reduce issues due to interference or internal co-existence
+        * information in the driver.
         */
-       EVENT_INTERFACE_ENABLED,
+       EVENT_AVOID_FREQUENCIES,
 
        /**
-        * EVENT_INTERFACE_DISABLED - Notify that interface was disabled
+        * EVENT_NEW_PEER_CANDIDATE - new (unknown) mesh peer notification
+        */
+       EVENT_NEW_PEER_CANDIDATE,
+
+       /**
+        * EVENT_ACS_CHANNEL_SELECTED - Received selected channels by ACS
         *
-        * This event is used to indicate that the interface was disabled,
-        * e.g., due to rfkill.
+        * Indicates a pair of primary and secondary channels chosen by ACS
+        * in device.
         */
-       EVENT_INTERFACE_DISABLED,
+       EVENT_ACS_CHANNEL_SELECTED,
 
        /**
-        * EVENT_CHANNEL_LIST_CHANGED - Channel list changed
+        * EVENT_DFS_CAC_STARTED - Notify that channel availability check has
+        * been started.
         *
-        * This event is used to indicate that the channel list has changed,
-        * e.g., because of a regulatory domain change triggered by scan
-        * results including an AP advertising a country code.
+        * This event indicates that channel availability check has been started
+        * on a DFS frequency by a driver that supports DFS Offload.
         */
-       EVENT_CHANNEL_LIST_CHANGED
+       EVENT_DFS_CAC_STARTED,
+};
+
+
+/**
+ * struct freq_survey - Channel survey info
+ *
+ * @ifidx: Interface index in which this survey was observed
+ * @freq: Center of frequency of the surveyed channel
+ * @nf: Channel noise floor in dBm
+ * @channel_time: Amount of time in ms the radio spent on the channel
+ * @channel_time_busy: Amount of time in ms the radio detected some signal
+ *     that indicated to the radio the channel was not clear
+ * @channel_time_rx: Amount of time the radio spent receiving data
+ * @channel_time_tx: Amount of time the radio spent transmitting data
+ * @filled: bitmask indicating which fields have been reported, see
+ *     SURVEY_HAS_* defines.
+ * @list: Internal list pointers
+ */
+struct freq_survey {
+       u32 ifidx;
+       unsigned int freq;
+       s8 nf;
+       u64 channel_time;
+       u64 channel_time_busy;
+       u64 channel_time_rx;
+       u64 channel_time_tx;
+       unsigned int filled;
+       struct dl_list list;
 };
 
+#define SURVEY_HAS_NF BIT(0)
+#define SURVEY_HAS_CHAN_TIME BIT(1)
+#define SURVEY_HAS_CHAN_TIME_BUSY BIT(2)
+#define SURVEY_HAS_CHAN_TIME_RX BIT(3)
+#define SURVEY_HAS_CHAN_TIME_TX BIT(4)
+
 
 /**
  * union wpa_event_data - Additional data for wpa_supplicant_event() calls
@@ -2230,6 +3974,11 @@ union wpa_event_data {
         */
        struct assoc_info {
                /**
+                * reassoc - Flag to indicate association or reassociation
+                */
+               int reassoc;
+
+               /**
                 * req_ies - (Re)Association Request IEs
                 *
                 * If the driver generates WPA/RSN IE, this event data must be
@@ -2293,9 +4042,62 @@ union wpa_event_data {
                unsigned int freq;
 
                /**
+                * wmm_params - WMM parameters used in this association.
+                */
+               struct wmm_params wmm_params;
+
+               /**
                 * addr - Station address (for AP mode)
                 */
                const u8 *addr;
+
+               /**
+                * The following is the key management offload information
+                * @authorized
+                * @key_replay_ctr
+                * @key_replay_ctr_len
+                * @ptk_kck
+                * @ptk_kek_len
+                * @ptk_kek
+                * @ptk_kek_len
+                */
+
+               /**
+                * authorized - Status of key management offload,
+                * 1 = successful
+                */
+               int authorized;
+
+               /**
+                * key_replay_ctr - Key replay counter value last used
+                * in a valid EAPOL-Key frame
+                */
+               const u8 *key_replay_ctr;
+
+               /**
+                * key_replay_ctr_len - The length of key_replay_ctr
+                */
+               size_t key_replay_ctr_len;
+
+               /**
+                * ptk_kck - The derived PTK KCK
+                */
+               const u8 *ptk_kck;
+
+               /**
+                * ptk_kek_len - The length of ptk_kck
+                */
+               size_t ptk_kck_len;
+
+               /**
+                * ptk_kek - The derived PTK KEK
+                */
+               const u8 *ptk_kek;
+
+               /**
+                * ptk_kek_len - The length of ptk_kek
+                */
+               size_t ptk_kek_len;
        } assoc_info;
 
        /**
@@ -2322,6 +4124,11 @@ union wpa_event_data {
                 * ie_len - Length of ie buffer in octets
                 */
                size_t ie_len;
+
+               /**
+                * locally_generated - Whether the frame was locally generated
+                */
+               int locally_generated;
        } disassoc_info;
 
        /**
@@ -2348,6 +4155,11 @@ union wpa_event_data {
                 * ie_len - Length of ie buffer in octets
                 */
                size_t ie_len;
+
+               /**
+                * locally_generated - Whether the frame was locally generated
+                */
+               int locally_generated;
        } deauth_info;
 
        /**
@@ -2388,6 +4200,37 @@ union wpa_event_data {
        } stkstart;
 
        /**
+        * struct tdls - Data for EVENT_TDLS
+        */
+       struct tdls {
+               u8 peer[ETH_ALEN];
+               enum {
+                       TDLS_REQUEST_SETUP,
+                       TDLS_REQUEST_TEARDOWN,
+                       TDLS_REQUEST_DISCOVER,
+               } oper;
+               u16 reason_code; /* for teardown */
+       } tdls;
+
+       /**
+        * struct wnm - Data for EVENT_WNM
+        */
+       struct wnm {
+               u8 addr[ETH_ALEN];
+               enum {
+                       WNM_OPER_SLEEP,
+               } oper;
+               enum {
+                       WNM_SLEEP_ENTER,
+                       WNM_SLEEP_EXIT
+               } sleep_action;
+               int sleep_intval;
+               u16 reason_code;
+               u8 *buf;
+               u16 buf_len;
+       } wnm;
+
+       /**
         * struct ft_ies - FT information elements (EVENT_FT_RESPONSE)
         *
         * During FT (IEEE 802.11r) authentication sequence, the driver is
@@ -2419,7 +4262,9 @@ union wpa_event_data {
         */
        struct auth_info {
                u8 peer[ETH_ALEN];
+               u8 bssid[ETH_ALEN];
                u16 auth_type;
+               u16 auth_transaction;
                u16 status_code;
                const u8 *ies;
                size_t ies_len;
@@ -2430,6 +4275,11 @@ union wpa_event_data {
         */
        struct assoc_reject {
                /**
+                * bssid - BSSID of the AP that rejected association
+                */
+               const u8 *bssid;
+
+               /**
                 * resp_ies - (Re)Association Response IEs
                 *
                 * Optional association data from the driver. This data is not
@@ -2440,7 +4290,7 @@ union wpa_event_data {
                 * This should start with the first IE (fixed fields before IEs
                 * are not included).
                 */
-               u8 *resp_ies;
+               const u8 *resp_ies;
 
                /**
                 * resp_ies_len - Length of resp_ies in bytes
@@ -2458,15 +4308,6 @@ union wpa_event_data {
        } timeout_event;
 
        /**
-        * struct ft_rrb_rx - Data for EVENT_FT_RRB_RX events
-        */
-       struct ft_rrb_rx {
-               const u8 *src;
-               const u8 *data;
-               size_t data_len;
-       } ft_rrb_rx;
-
-       /**
         * struct tx_status - Data for EVENT_TX_STATUS events
         */
        struct tx_status {
@@ -2482,8 +4323,9 @@ union wpa_event_data {
         * struct rx_from_unknown - Data for EVENT_RX_FROM_UNKNOWN events
         */
        struct rx_from_unknown {
-               const u8 *frame;
-               size_t len;
+               const u8 *bssid;
+               const u8 *addr;
+               int wds;
        } rx_from_unknown;
 
        /**
@@ -2493,48 +4335,26 @@ union wpa_event_data {
                const u8 *frame;
                size_t frame_len;
                u32 datarate;
-               u32 ssi_signal;
-       } rx_mgmt;
-
-       /**
-        * struct rx_action - Data for EVENT_RX_ACTION events
-        */
-       struct rx_action {
-               /**
-                * da - Destination address of the received Action frame
-                */
-               const u8 *da;
-
-               /**
-                * sa - Source address of the received Action frame
-                */
-               const u8 *sa;
-
-               /**
-                * bssid - Address 3 of the received Action frame
-                */
-               const u8 *bssid;
-
-               /**
-                * category - Action frame category
-                */
-               u8 category;
 
                /**
-                * data - Action frame body after category field
+                * drv_priv - Pointer to store driver private BSS information
+                *
+                * If not set to NULL, this is used for comparison with
+                * hostapd_data->drv_priv to determine which BSS should process
+                * the frame.
                 */
-               const u8 *data;
+               void *drv_priv;
 
                /**
-                * len - Length of data in octets
+                * freq - Frequency (in MHz) on which the frame was received
                 */
-               size_t len;
+               int freq;
 
                /**
-                * freq - Frequency (in MHz) on which the frame was received
+                * ssi_signal - Signal strength in dBm (or 0 if not available)
                 */
-               int freq;
-       } rx_action;
+               int ssi_signal;
+       } rx_mgmt;
 
        /**
         * struct remain_on_channel - Data for EVENT_REMAIN_ON_CHANNEL events
@@ -2571,17 +4391,6 @@ union wpa_event_data {
        } scan_info;
 
        /**
-        * struct mlme_rx - Data for EVENT_MLME_RX events
-        */
-       struct mlme_rx {
-               const u8 *buf;
-               size_t len;
-               int freq;
-               int channel;
-               int ssi;
-       } mlme_rx;
-
-       /**
         * struct rx_probe_req - Data for EVENT_RX_PROBE_REQ events
         */
        struct rx_probe_req {
@@ -2591,6 +4400,18 @@ union wpa_event_data {
                const u8 *sa;
 
                /**
+                * da - Destination address of the received Probe Request frame
+                *      or %NULL if not available
+                */
+               const u8 *da;
+
+               /**
+                * bssid - BSSID of the received Probe Request frame or %NULL
+                *      if not available
+                */
+               const u8 *bssid;
+
+               /**
                 * ie - IEs from the Probe Request body
                 */
                const u8 *ie;
@@ -2599,6 +4420,11 @@ union wpa_event_data {
                 * ie_len - Length of ie buffer in octets
                 */
                size_t ie_len;
+
+               /**
+                * signal - signal strength in dBm (or 0 if not available)
+                */
+               int ssi_signal;
        } rx_probe_req;
 
        /**
@@ -2618,15 +4444,192 @@ union wpa_event_data {
        } eapol_rx;
 
        /**
-        * struct signal_change - Data for EVENT_SIGNAL_CHANGE events
+        * signal_change - Data for EVENT_SIGNAL_CHANGE events
+        */
+       struct wpa_signal_info signal_change;
+
+       /**
+        * struct best_channel - Data for EVENT_BEST_CHANNEL events
+        * @freq_24: Best 2.4 GHz band channel frequency in MHz
+        * @freq_5: Best 5 GHz band channel frequency in MHz
+        * @freq_overall: Best channel frequency in MHz
+        *
+        * 0 can be used to indicate no preference in either band.
+        */
+       struct best_channel {
+               int freq_24;
+               int freq_5;
+               int freq_overall;
+       } best_chan;
+
+       struct unprot_deauth {
+               const u8 *sa;
+               const u8 *da;
+               u16 reason_code;
+       } unprot_deauth;
+
+       struct unprot_disassoc {
+               const u8 *sa;
+               const u8 *da;
+               u16 reason_code;
+       } unprot_disassoc;
+
+       /**
+        * struct low_ack - Data for EVENT_STATION_LOW_ACK events
+        * @addr: station address
+        */
+       struct low_ack {
+               u8 addr[ETH_ALEN];
+       } low_ack;
+
+       /**
+        * struct ibss_peer_lost - Data for EVENT_IBSS_PEER_LOST
+        */
+       struct ibss_peer_lost {
+               u8 peer[ETH_ALEN];
+       } ibss_peer_lost;
+
+       /**
+        * struct driver_gtk_rekey - Data for EVENT_DRIVER_GTK_REKEY
+        */
+       struct driver_gtk_rekey {
+               const u8 *bssid;
+               const u8 *replay_ctr;
+       } driver_gtk_rekey;
+
+       /**
+        * struct client_poll - Data for EVENT_DRIVER_CLIENT_POLL_OK events
+        * @addr: station address
+        */
+       struct client_poll {
+               u8 addr[ETH_ALEN];
+       } client_poll;
+
+       /**
+        * struct eapol_tx_status
+        * @dst: Original destination
+        * @data: Data starting with IEEE 802.1X header (!)
+        * @data_len: Length of data
+        * @ack: Indicates ack or lost frame
+        *
+        * This corresponds to hapd_send_eapol if the frame sent
+        * there isn't just reported as EVENT_TX_STATUS.
+        */
+       struct eapol_tx_status {
+               const u8 *dst;
+               const u8 *data;
+               int data_len;
+               int ack;
+       } eapol_tx_status;
+
+       /**
+        * struct ch_switch
+        * @freq: Frequency of new channel in MHz
+        * @ht_enabled: Whether this is an HT channel
+        * @ch_offset: Secondary channel offset
+        * @ch_width: Channel width
+        * @cf1: Center frequency 1
+        * @cf2: Center frequency 2
+        */
+       struct ch_switch {
+               int freq;
+               int ht_enabled;
+               int ch_offset;
+               enum chan_width ch_width;
+               int cf1;
+               int cf2;
+       } ch_switch;
+
+       /**
+        * struct connect_failed - Data for EVENT_CONNECT_FAILED_REASON
+        * @addr: Remote client address
+        * @code: Reason code for connection failure
+        */
+       struct connect_failed_reason {
+               u8 addr[ETH_ALEN];
+               enum {
+                       MAX_CLIENT_REACHED,
+                       BLOCKED_CLIENT
+               } code;
+       } connect_failed_reason;
+
+       /**
+        * struct dfs_event - Data for radar detected events
+        * @freq: Frequency of the channel in MHz
+        */
+       struct dfs_event {
+               int freq;
+               int ht_enabled;
+               int chan_offset;
+               enum chan_width chan_width;
+               int cf1;
+               int cf2;
+       } dfs_event;
+
+       /**
+        * survey_results - Survey result data for EVENT_SURVEY
+        * @freq_filter: Requested frequency survey filter, 0 if request
+        *      was for all survey data
+        * @survey_list: Linked list of survey data (struct freq_survey)
+        */
+       struct survey_results {
+               unsigned int freq_filter;
+               struct dl_list survey_list; /* struct freq_survey */
+       } survey_results;
+
+       /**
+        * channel_list_changed - Data for EVENT_CHANNEL_LIST_CHANGED
+        * @initiator: Initiator of the regulatory change
+        * @type: Regulatory change type
+        * @alpha2: Country code (or "" if not available)
+        */
+       struct channel_list_changed {
+               enum reg_change_initiator initiator;
+               enum reg_type type;
+               char alpha2[3];
+       } channel_list_changed;
+
+       /**
+        * freq_range - List of frequency ranges
+        *
+        * This is used as the data with EVENT_AVOID_FREQUENCIES.
+        */
+       struct wpa_freq_range_list freq_range;
+
+       /**
+        * struct mesh_peer
+        *
+        * @peer: Peer address
+        * @ies: Beacon IEs
+        * @ie_len: Length of @ies
+        *
+        * Notification of new candidate mesh peer.
         */
-       struct signal_change {
-               u32 frequency;
-               int above_threshold;
-               int current_signal;
-               int current_noise;
-               int current_txrate;
-       } signal_change;
+       struct mesh_peer {
+               const u8 *peer;
+               const u8 *ies;
+               size_t ie_len;
+       } mesh_peer;
+
+       /**
+        * struct acs_selected_channels - Data for EVENT_ACS_CHANNEL_SELECTED
+        * @pri_channel: Selected primary channel
+        * @sec_channel: Selected secondary channel
+        * @vht_seg0_center_ch: VHT mode Segment0 center channel
+        * @vht_seg1_center_ch: VHT mode Segment1 center channel
+        * @ch_width: Selected Channel width by driver. Driver may choose to
+        *      change hostapd configured ACS channel width due driver internal
+        *      channel restrictions.
+        * hw_mode: Selected band (used with hw_mode=any)
+        */
+       struct acs_selected_channels {
+               u8 pri_channel;
+               u8 sec_channel;
+               u8 vht_seg0_center_ch;
+               u8 vht_seg1_center_ch;
+               u16 ch_width;
+               enum hostapd_hw_mode hw_mode;
+       } acs_selected_channels;
 };
 
 /**
@@ -2649,10 +4652,11 @@ void wpa_supplicant_event(void *ctx, enum wpa_event_type event,
  */
 
 static inline void drv_event_assoc(void *ctx, const u8 *addr, const u8 *ie,
-                                  size_t ielen)
+                                  size_t ielen, int reassoc)
 {
        union wpa_event_data event;
        os_memset(&event, 0, sizeof(event));
+       event.assoc_info.reassoc = reassoc;
        event.assoc_info.req_ies = ie;
        event.assoc_info.req_ies_len = ielen;
        event.assoc_info.addr = addr;
@@ -2678,4 +4682,23 @@ static inline void drv_event_eapol_rx(void *ctx, const u8 *src, const u8 *data,
        wpa_supplicant_event(ctx, EVENT_EAPOL_RX, &event);
 }
 
+/* driver_common.c */
+void wpa_scan_results_free(struct wpa_scan_results *res);
+
+/* Convert wpa_event_type to a string for logging */
+const char * event_to_string(enum wpa_event_type event);
+
+/* Convert chan_width to a string for logging and control interfaces */
+const char * channel_width_to_string(enum chan_width width);
+
+int ht_supported(const struct hostapd_hw_modes *mode);
+int vht_supported(const struct hostapd_hw_modes *mode);
+
+struct wowlan_triggers *
+wpa_get_wowlan_triggers(const char *wowlan_triggers,
+                       const struct wpa_driver_capa *capa);
+
+/* NULL terminated array of linked in driver wrappers */
+extern const struct wpa_driver_ops *const wpa_drivers[];
+
 #endif /* DRIVER_H */