Sync with wireless-testing.git include/uapi/linux/nl80211.h
Signed-hostap: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
f6c2b8c367
commit
3505743395
1 changed files with 218 additions and 25 deletions
|
@ -125,6 +125,31 @@
|
||||||
* interfaces that a given device supports.
|
* interfaces that a given device supports.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* DOC: packet coalesce support
|
||||||
|
*
|
||||||
|
* In most cases, host that receives IPv4 and IPv6 multicast/broadcast
|
||||||
|
* packets does not do anything with these packets. Therefore the
|
||||||
|
* reception of these unwanted packets causes unnecessary processing
|
||||||
|
* and power consumption.
|
||||||
|
*
|
||||||
|
* Packet coalesce feature helps to reduce number of received interrupts
|
||||||
|
* to host by buffering these packets in firmware/hardware for some
|
||||||
|
* predefined time. Received interrupt will be generated when one of the
|
||||||
|
* following events occur.
|
||||||
|
* a) Expiration of hardware timer whose expiration time is set to maximum
|
||||||
|
* coalescing delay of matching coalesce rule.
|
||||||
|
* b) Coalescing buffer in hardware reaches it's limit.
|
||||||
|
* c) Packet doesn't match any of the configured coalesce rules.
|
||||||
|
*
|
||||||
|
* User needs to configure following parameters for creating a coalesce
|
||||||
|
* rule.
|
||||||
|
* a) Maximum coalescing delay
|
||||||
|
* b) List of packet patterns which needs to be matched
|
||||||
|
* c) Condition for coalescence. pattern 'match' or 'no match'
|
||||||
|
* Multiple such rules can be created.
|
||||||
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* enum nl80211_commands - supported nl80211 commands
|
* enum nl80211_commands - supported nl80211 commands
|
||||||
*
|
*
|
||||||
|
@ -648,6 +673,19 @@
|
||||||
* @NL80211_CMD_CRIT_PROTOCOL_STOP: Indicates the connection reliability can
|
* @NL80211_CMD_CRIT_PROTOCOL_STOP: Indicates the connection reliability can
|
||||||
* return back to normal.
|
* return back to normal.
|
||||||
*
|
*
|
||||||
|
* @NL80211_CMD_GET_COALESCE: Get currently supported coalesce rules.
|
||||||
|
* @NL80211_CMD_SET_COALESCE: Configure coalesce rules or clear existing rules.
|
||||||
|
*
|
||||||
|
* @NL80211_CMD_CHANNEL_SWITCH: Perform a channel switch by announcing the
|
||||||
|
* the new channel information (Channel Switch Announcement - CSA)
|
||||||
|
* in the beacon for some time (as defined in the
|
||||||
|
* %NL80211_ATTR_CH_SWITCH_COUNT parameter) and then change to the
|
||||||
|
* new channel. Userspace provides the new channel information (using
|
||||||
|
* %NL80211_ATTR_WIPHY_FREQ and the attributes determining channel
|
||||||
|
* width). %NL80211_ATTR_CH_SWITCH_BLOCK_TX may be supplied to inform
|
||||||
|
* other station that transmission must be blocked until the channel
|
||||||
|
* switch is complete.
|
||||||
|
*
|
||||||
* @NL80211_CMD_MAX: highest used command number
|
* @NL80211_CMD_MAX: highest used command number
|
||||||
* @__NL80211_CMD_AFTER_LAST: internal use
|
* @__NL80211_CMD_AFTER_LAST: internal use
|
||||||
*/
|
*/
|
||||||
|
@ -810,6 +848,11 @@ enum nl80211_commands {
|
||||||
NL80211_CMD_CRIT_PROTOCOL_START,
|
NL80211_CMD_CRIT_PROTOCOL_START,
|
||||||
NL80211_CMD_CRIT_PROTOCOL_STOP,
|
NL80211_CMD_CRIT_PROTOCOL_STOP,
|
||||||
|
|
||||||
|
NL80211_CMD_GET_COALESCE,
|
||||||
|
NL80211_CMD_SET_COALESCE,
|
||||||
|
|
||||||
|
NL80211_CMD_CHANNEL_SWITCH,
|
||||||
|
|
||||||
/* add new commands above here */
|
/* add new commands above here */
|
||||||
|
|
||||||
/* used to define NL80211_CMD_MAX below */
|
/* used to define NL80211_CMD_MAX below */
|
||||||
|
@ -945,7 +988,7 @@ enum nl80211_commands {
|
||||||
* to query the CRDA to retrieve one regulatory domain. This attribute can
|
* to query the CRDA to retrieve one regulatory domain. This attribute can
|
||||||
* also be used by userspace to query the kernel for the currently set
|
* also be used by userspace to query the kernel for the currently set
|
||||||
* regulatory domain. We chose an alpha2 as that is also used by the
|
* regulatory domain. We chose an alpha2 as that is also used by the
|
||||||
* IEEE-802.11d country information element to identify a country.
|
* IEEE-802.11 country information element to identify a country.
|
||||||
* Users can also simply ask the wireless core to set regulatory domain
|
* Users can also simply ask the wireless core to set regulatory domain
|
||||||
* to a specific alpha2.
|
* to a specific alpha2.
|
||||||
* @NL80211_ATTR_REG_RULES: a nested array of regulatory domain regulatory
|
* @NL80211_ATTR_REG_RULES: a nested array of regulatory domain regulatory
|
||||||
|
@ -1436,6 +1479,35 @@ enum nl80211_commands {
|
||||||
* allowed to be used with the first @NL80211_CMD_SET_STATION command to
|
* allowed to be used with the first @NL80211_CMD_SET_STATION command to
|
||||||
* update a TDLS peer STA entry.
|
* update a TDLS peer STA entry.
|
||||||
*
|
*
|
||||||
|
* @NL80211_ATTR_COALESCE_RULE: Coalesce rule information.
|
||||||
|
*
|
||||||
|
* @NL80211_ATTR_CH_SWITCH_COUNT: u32 attribute specifying the number of TBTT's
|
||||||
|
* until the channel switch event.
|
||||||
|
* @NL80211_ATTR_CH_SWITCH_BLOCK_TX: flag attribute specifying that transmission
|
||||||
|
* must be blocked on the current channel (before the channel switch
|
||||||
|
* operation).
|
||||||
|
* @NL80211_ATTR_CSA_IES: Nested set of attributes containing the IE information
|
||||||
|
* for the time while performing a channel switch.
|
||||||
|
* @NL80211_ATTR_CSA_C_OFF_BEACON: Offset of the channel switch counter
|
||||||
|
* field in the beacons tail (%NL80211_ATTR_BEACON_TAIL).
|
||||||
|
* @NL80211_ATTR_CSA_C_OFF_PRESP: Offset of the channel switch counter
|
||||||
|
* field in the probe response (%NL80211_ATTR_PROBE_RESP).
|
||||||
|
*
|
||||||
|
* @NL80211_ATTR_RXMGMT_FLAGS: flags for nl80211_send_mgmt(), u32.
|
||||||
|
* As specified in the &enum nl80211_rxmgmt_flags.
|
||||||
|
*
|
||||||
|
* @NL80211_ATTR_STA_SUPPORTED_CHANNELS: array of supported channels.
|
||||||
|
*
|
||||||
|
* @NL80211_ATTR_STA_SUPPORTED_OPER_CLASSES: array of supported
|
||||||
|
* supported operating classes.
|
||||||
|
*
|
||||||
|
* @NL80211_ATTR_HANDLE_DFS: A flag indicating whether user space
|
||||||
|
* controls DFS operation in IBSS mode. If the flag is included in
|
||||||
|
* %NL80211_CMD_JOIN_IBSS request, the driver will allow use of DFS
|
||||||
|
* channels and reports radar events to userspace. Userspace is required
|
||||||
|
* to react to radar events, e.g. initiate a channel switch or leave the
|
||||||
|
* IBSS network.
|
||||||
|
*
|
||||||
* @NL80211_ATTR_MAX: highest attribute number currently defined
|
* @NL80211_ATTR_MAX: highest attribute number currently defined
|
||||||
* @__NL80211_ATTR_AFTER_LAST: internal use
|
* @__NL80211_ATTR_AFTER_LAST: internal use
|
||||||
*/
|
*/
|
||||||
|
@ -1736,6 +1808,22 @@ enum nl80211_attrs {
|
||||||
|
|
||||||
NL80211_ATTR_PEER_AID,
|
NL80211_ATTR_PEER_AID,
|
||||||
|
|
||||||
|
NL80211_ATTR_COALESCE_RULE,
|
||||||
|
|
||||||
|
NL80211_ATTR_CH_SWITCH_COUNT,
|
||||||
|
NL80211_ATTR_CH_SWITCH_BLOCK_TX,
|
||||||
|
NL80211_ATTR_CSA_IES,
|
||||||
|
NL80211_ATTR_CSA_C_OFF_BEACON,
|
||||||
|
NL80211_ATTR_CSA_C_OFF_PRESP,
|
||||||
|
|
||||||
|
NL80211_ATTR_RXMGMT_FLAGS,
|
||||||
|
|
||||||
|
NL80211_ATTR_STA_SUPPORTED_CHANNELS,
|
||||||
|
|
||||||
|
NL80211_ATTR_STA_SUPPORTED_OPER_CLASSES,
|
||||||
|
|
||||||
|
NL80211_ATTR_HANDLE_DFS,
|
||||||
|
|
||||||
/* add attributes here, update the policy in nl80211.c */
|
/* add attributes here, update the policy in nl80211.c */
|
||||||
|
|
||||||
__NL80211_ATTR_AFTER_LAST,
|
__NL80211_ATTR_AFTER_LAST,
|
||||||
|
@ -2428,6 +2516,8 @@ enum nl80211_survey_info {
|
||||||
* @NL80211_MNTR_FLAG_OTHER_BSS: disable BSSID filtering
|
* @NL80211_MNTR_FLAG_OTHER_BSS: disable BSSID filtering
|
||||||
* @NL80211_MNTR_FLAG_COOK_FRAMES: report frames after processing.
|
* @NL80211_MNTR_FLAG_COOK_FRAMES: report frames after processing.
|
||||||
* overrides all other flags.
|
* overrides all other flags.
|
||||||
|
* @NL80211_MNTR_FLAG_ACTIVE: use the configured MAC address
|
||||||
|
* and ACK incoming unicast packets.
|
||||||
*
|
*
|
||||||
* @__NL80211_MNTR_FLAG_AFTER_LAST: internal use
|
* @__NL80211_MNTR_FLAG_AFTER_LAST: internal use
|
||||||
* @NL80211_MNTR_FLAG_MAX: highest possible monitor flag
|
* @NL80211_MNTR_FLAG_MAX: highest possible monitor flag
|
||||||
|
@ -2439,6 +2529,7 @@ enum nl80211_mntr_flags {
|
||||||
NL80211_MNTR_FLAG_CONTROL,
|
NL80211_MNTR_FLAG_CONTROL,
|
||||||
NL80211_MNTR_FLAG_OTHER_BSS,
|
NL80211_MNTR_FLAG_OTHER_BSS,
|
||||||
NL80211_MNTR_FLAG_COOK_FRAMES,
|
NL80211_MNTR_FLAG_COOK_FRAMES,
|
||||||
|
NL80211_MNTR_FLAG_ACTIVE,
|
||||||
|
|
||||||
/* keep last */
|
/* keep last */
|
||||||
__NL80211_MNTR_FLAG_AFTER_LAST,
|
__NL80211_MNTR_FLAG_AFTER_LAST,
|
||||||
|
@ -2574,6 +2665,10 @@ enum nl80211_mesh_power_mode {
|
||||||
*
|
*
|
||||||
* @NL80211_MESHCONF_AWAKE_WINDOW: awake window duration (in TUs)
|
* @NL80211_MESHCONF_AWAKE_WINDOW: awake window duration (in TUs)
|
||||||
*
|
*
|
||||||
|
* @NL80211_MESHCONF_PLINK_TIMEOUT: If no tx activity is seen from a STA we've
|
||||||
|
* established peering with for longer than this time (in seconds), then
|
||||||
|
* remove it from the STA's list of peers. Default is 30 minutes.
|
||||||
|
*
|
||||||
* @__NL80211_MESHCONF_ATTR_AFTER_LAST: internal use
|
* @__NL80211_MESHCONF_ATTR_AFTER_LAST: internal use
|
||||||
*/
|
*/
|
||||||
enum nl80211_meshconf_params {
|
enum nl80211_meshconf_params {
|
||||||
|
@ -2605,6 +2700,7 @@ enum nl80211_meshconf_params {
|
||||||
NL80211_MESHCONF_HWMP_CONFIRMATION_INTERVAL,
|
NL80211_MESHCONF_HWMP_CONFIRMATION_INTERVAL,
|
||||||
NL80211_MESHCONF_POWER_MODE,
|
NL80211_MESHCONF_POWER_MODE,
|
||||||
NL80211_MESHCONF_AWAKE_WINDOW,
|
NL80211_MESHCONF_AWAKE_WINDOW,
|
||||||
|
NL80211_MESHCONF_PLINK_TIMEOUT,
|
||||||
|
|
||||||
/* keep last */
|
/* keep last */
|
||||||
__NL80211_MESHCONF_ATTR_AFTER_LAST,
|
__NL80211_MESHCONF_ATTR_AFTER_LAST,
|
||||||
|
@ -2750,6 +2846,8 @@ enum nl80211_channel_type {
|
||||||
* and %NL80211_ATTR_CENTER_FREQ2 attributes must be provided as well
|
* and %NL80211_ATTR_CENTER_FREQ2 attributes must be provided as well
|
||||||
* @NL80211_CHAN_WIDTH_160: 160 MHz channel, the %NL80211_ATTR_CENTER_FREQ1
|
* @NL80211_CHAN_WIDTH_160: 160 MHz channel, the %NL80211_ATTR_CENTER_FREQ1
|
||||||
* attribute must be provided as well
|
* attribute must be provided as well
|
||||||
|
* @NL80211_CHAN_WIDTH_5: 5 MHz OFDM channel
|
||||||
|
* @NL80211_CHAN_WIDTH_10: 10 MHz OFDM channel
|
||||||
*/
|
*/
|
||||||
enum nl80211_chan_width {
|
enum nl80211_chan_width {
|
||||||
NL80211_CHAN_WIDTH_20_NOHT,
|
NL80211_CHAN_WIDTH_20_NOHT,
|
||||||
|
@ -2758,6 +2856,23 @@ enum nl80211_chan_width {
|
||||||
NL80211_CHAN_WIDTH_80,
|
NL80211_CHAN_WIDTH_80,
|
||||||
NL80211_CHAN_WIDTH_80P80,
|
NL80211_CHAN_WIDTH_80P80,
|
||||||
NL80211_CHAN_WIDTH_160,
|
NL80211_CHAN_WIDTH_160,
|
||||||
|
NL80211_CHAN_WIDTH_5,
|
||||||
|
NL80211_CHAN_WIDTH_10,
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* enum nl80211_bss_scan_width - control channel width for a BSS
|
||||||
|
*
|
||||||
|
* These values are used with the %NL80211_BSS_CHAN_WIDTH attribute.
|
||||||
|
*
|
||||||
|
* @NL80211_BSS_CHAN_WIDTH_20: control channel is 20 MHz wide or compatible
|
||||||
|
* @NL80211_BSS_CHAN_WIDTH_10: control channel is 10 MHz wide
|
||||||
|
* @NL80211_BSS_CHAN_WIDTH_5: control channel is 5 MHz wide
|
||||||
|
*/
|
||||||
|
enum nl80211_bss_scan_width {
|
||||||
|
NL80211_BSS_CHAN_WIDTH_20,
|
||||||
|
NL80211_BSS_CHAN_WIDTH_10,
|
||||||
|
NL80211_BSS_CHAN_WIDTH_5,
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -2784,6 +2899,8 @@ enum nl80211_chan_width {
|
||||||
* @NL80211_BSS_BEACON_IES: binary attribute containing the raw information
|
* @NL80211_BSS_BEACON_IES: binary attribute containing the raw information
|
||||||
* elements from a Beacon frame (bin); not present if no Beacon frame has
|
* elements from a Beacon frame (bin); not present if no Beacon frame has
|
||||||
* yet been received
|
* yet been received
|
||||||
|
* @NL80211_BSS_CHAN_WIDTH: channel width of the control channel
|
||||||
|
* (u32, enum nl80211_bss_scan_width)
|
||||||
* @__NL80211_BSS_AFTER_LAST: internal
|
* @__NL80211_BSS_AFTER_LAST: internal
|
||||||
* @NL80211_BSS_MAX: highest BSS attribute
|
* @NL80211_BSS_MAX: highest BSS attribute
|
||||||
*/
|
*/
|
||||||
|
@ -2800,6 +2917,7 @@ enum nl80211_bss {
|
||||||
NL80211_BSS_STATUS,
|
NL80211_BSS_STATUS,
|
||||||
NL80211_BSS_SEEN_MS_AGO,
|
NL80211_BSS_SEEN_MS_AGO,
|
||||||
NL80211_BSS_BEACON_IES,
|
NL80211_BSS_BEACON_IES,
|
||||||
|
NL80211_BSS_CHAN_WIDTH,
|
||||||
|
|
||||||
/* keep last */
|
/* keep last */
|
||||||
__NL80211_BSS_AFTER_LAST,
|
__NL80211_BSS_AFTER_LAST,
|
||||||
|
@ -3048,11 +3166,11 @@ enum nl80211_tx_power_setting {
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* enum nl80211_wowlan_packet_pattern_attr - WoWLAN packet pattern attribute
|
* enum nl80211_packet_pattern_attr - packet pattern attribute
|
||||||
* @__NL80211_WOWLAN_PKTPAT_INVALID: invalid number for nested attribute
|
* @__NL80211_PKTPAT_INVALID: invalid number for nested attribute
|
||||||
* @NL80211_WOWLAN_PKTPAT_PATTERN: the pattern, values where the mask has
|
* @NL80211_PKTPAT_PATTERN: the pattern, values where the mask has
|
||||||
* a zero bit are ignored
|
* a zero bit are ignored
|
||||||
* @NL80211_WOWLAN_PKTPAT_MASK: pattern mask, must be long enough to have
|
* @NL80211_PKTPAT_MASK: pattern mask, must be long enough to have
|
||||||
* a bit for each byte in the pattern. The lowest-order bit corresponds
|
* a bit for each byte in the pattern. The lowest-order bit corresponds
|
||||||
* to the first byte of the pattern, but the bytes of the pattern are
|
* to the first byte of the pattern, but the bytes of the pattern are
|
||||||
* in a little-endian-like format, i.e. the 9th byte of the pattern
|
* in a little-endian-like format, i.e. the 9th byte of the pattern
|
||||||
|
@ -3063,39 +3181,50 @@ enum nl80211_tx_power_setting {
|
||||||
* Note that the pattern matching is done as though frames were not
|
* Note that the pattern matching is done as though frames were not
|
||||||
* 802.11 frames but 802.3 frames, i.e. the frame is fully unpacked
|
* 802.11 frames but 802.3 frames, i.e. the frame is fully unpacked
|
||||||
* first (including SNAP header unpacking) and then matched.
|
* first (including SNAP header unpacking) and then matched.
|
||||||
* @NL80211_WOWLAN_PKTPAT_OFFSET: packet offset, pattern is matched after
|
* @NL80211_PKTPAT_OFFSET: packet offset, pattern is matched after
|
||||||
* these fixed number of bytes of received packet
|
* these fixed number of bytes of received packet
|
||||||
* @NUM_NL80211_WOWLAN_PKTPAT: number of attributes
|
* @NUM_NL80211_PKTPAT: number of attributes
|
||||||
* @MAX_NL80211_WOWLAN_PKTPAT: max attribute number
|
* @MAX_NL80211_PKTPAT: max attribute number
|
||||||
*/
|
*/
|
||||||
enum nl80211_wowlan_packet_pattern_attr {
|
enum nl80211_packet_pattern_attr {
|
||||||
__NL80211_WOWLAN_PKTPAT_INVALID,
|
__NL80211_PKTPAT_INVALID,
|
||||||
NL80211_WOWLAN_PKTPAT_MASK,
|
NL80211_PKTPAT_MASK,
|
||||||
NL80211_WOWLAN_PKTPAT_PATTERN,
|
NL80211_PKTPAT_PATTERN,
|
||||||
NL80211_WOWLAN_PKTPAT_OFFSET,
|
NL80211_PKTPAT_OFFSET,
|
||||||
|
|
||||||
NUM_NL80211_WOWLAN_PKTPAT,
|
NUM_NL80211_PKTPAT,
|
||||||
MAX_NL80211_WOWLAN_PKTPAT = NUM_NL80211_WOWLAN_PKTPAT - 1,
|
MAX_NL80211_PKTPAT = NUM_NL80211_PKTPAT - 1,
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* struct nl80211_wowlan_pattern_support - pattern support information
|
* struct nl80211_pattern_support - packet pattern support information
|
||||||
* @max_patterns: maximum number of patterns supported
|
* @max_patterns: maximum number of patterns supported
|
||||||
* @min_pattern_len: minimum length of each pattern
|
* @min_pattern_len: minimum length of each pattern
|
||||||
* @max_pattern_len: maximum length of each pattern
|
* @max_pattern_len: maximum length of each pattern
|
||||||
* @max_pkt_offset: maximum Rx packet offset
|
* @max_pkt_offset: maximum Rx packet offset
|
||||||
*
|
*
|
||||||
* This struct is carried in %NL80211_WOWLAN_TRIG_PKT_PATTERN when
|
* This struct is carried in %NL80211_WOWLAN_TRIG_PKT_PATTERN when
|
||||||
* that is part of %NL80211_ATTR_WOWLAN_TRIGGERS_SUPPORTED in the
|
* that is part of %NL80211_ATTR_WOWLAN_TRIGGERS_SUPPORTED or in
|
||||||
* capability information given by the kernel to userspace.
|
* %NL80211_ATTR_COALESCE_RULE_PKT_PATTERN when that is part of
|
||||||
|
* %NL80211_ATTR_COALESCE_RULE in the capability information given
|
||||||
|
* by the kernel to userspace.
|
||||||
*/
|
*/
|
||||||
struct nl80211_wowlan_pattern_support {
|
struct nl80211_pattern_support {
|
||||||
__u32 max_patterns;
|
__u32 max_patterns;
|
||||||
__u32 min_pattern_len;
|
__u32 min_pattern_len;
|
||||||
__u32 max_pattern_len;
|
__u32 max_pattern_len;
|
||||||
__u32 max_pkt_offset;
|
__u32 max_pkt_offset;
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
/* only for backward compatibility */
|
||||||
|
#define __NL80211_WOWLAN_PKTPAT_INVALID __NL80211_PKTPAT_INVALID
|
||||||
|
#define NL80211_WOWLAN_PKTPAT_MASK NL80211_PKTPAT_MASK
|
||||||
|
#define NL80211_WOWLAN_PKTPAT_PATTERN NL80211_PKTPAT_PATTERN
|
||||||
|
#define NL80211_WOWLAN_PKTPAT_OFFSET NL80211_PKTPAT_OFFSET
|
||||||
|
#define NUM_NL80211_WOWLAN_PKTPAT NUM_NL80211_PKTPAT
|
||||||
|
#define MAX_NL80211_WOWLAN_PKTPAT MAX_NL80211_PKTPAT
|
||||||
|
#define nl80211_wowlan_pattern_support nl80211_pattern_support
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* enum nl80211_wowlan_triggers - WoWLAN trigger definitions
|
* enum nl80211_wowlan_triggers - WoWLAN trigger definitions
|
||||||
* @__NL80211_WOWLAN_TRIG_INVALID: invalid number for nested attributes
|
* @__NL80211_WOWLAN_TRIG_INVALID: invalid number for nested attributes
|
||||||
|
@ -3115,7 +3244,7 @@ struct nl80211_wowlan_pattern_support {
|
||||||
* pattern matching is done after the packet is converted to the MSDU.
|
* pattern matching is done after the packet is converted to the MSDU.
|
||||||
*
|
*
|
||||||
* In %NL80211_ATTR_WOWLAN_TRIGGERS_SUPPORTED, it is a binary attribute
|
* In %NL80211_ATTR_WOWLAN_TRIGGERS_SUPPORTED, it is a binary attribute
|
||||||
* carrying a &struct nl80211_wowlan_pattern_support.
|
* carrying a &struct nl80211_pattern_support.
|
||||||
*
|
*
|
||||||
* When reporting wakeup. it is a u32 attribute containing the 0-based
|
* When reporting wakeup. it is a u32 attribute containing the 0-based
|
||||||
* index of the pattern that caused the wakeup, in the patterns passed
|
* index of the pattern that caused the wakeup, in the patterns passed
|
||||||
|
@ -3272,7 +3401,7 @@ struct nl80211_wowlan_tcp_data_token_feature {
|
||||||
* @NL80211_WOWLAN_TCP_WAKE_PAYLOAD: wake packet payload, for advertising a
|
* @NL80211_WOWLAN_TCP_WAKE_PAYLOAD: wake packet payload, for advertising a
|
||||||
* u32 attribute holding the maximum length
|
* u32 attribute holding the maximum length
|
||||||
* @NL80211_WOWLAN_TCP_WAKE_MASK: Wake packet payload mask, not used for
|
* @NL80211_WOWLAN_TCP_WAKE_MASK: Wake packet payload mask, not used for
|
||||||
* feature advertising. The mask works like @NL80211_WOWLAN_PKTPAT_MASK
|
* feature advertising. The mask works like @NL80211_PKTPAT_MASK
|
||||||
* but on the TCP payload only.
|
* but on the TCP payload only.
|
||||||
* @NUM_NL80211_WOWLAN_TCP: number of TCP attributes
|
* @NUM_NL80211_WOWLAN_TCP: number of TCP attributes
|
||||||
* @MAX_NL80211_WOWLAN_TCP: highest attribute number
|
* @MAX_NL80211_WOWLAN_TCP: highest attribute number
|
||||||
|
@ -3296,6 +3425,55 @@ enum nl80211_wowlan_tcp_attrs {
|
||||||
MAX_NL80211_WOWLAN_TCP = NUM_NL80211_WOWLAN_TCP - 1
|
MAX_NL80211_WOWLAN_TCP = NUM_NL80211_WOWLAN_TCP - 1
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* struct nl80211_coalesce_rule_support - coalesce rule support information
|
||||||
|
* @max_rules: maximum number of rules supported
|
||||||
|
* @pat: packet pattern support information
|
||||||
|
* @max_delay: maximum supported coalescing delay in msecs
|
||||||
|
*
|
||||||
|
* This struct is carried in %NL80211_ATTR_COALESCE_RULE in the
|
||||||
|
* capability information given by the kernel to userspace.
|
||||||
|
*/
|
||||||
|
struct nl80211_coalesce_rule_support {
|
||||||
|
__u32 max_rules;
|
||||||
|
struct nl80211_pattern_support pat;
|
||||||
|
__u32 max_delay;
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
/**
|
||||||
|
* enum nl80211_attr_coalesce_rule - coalesce rule attribute
|
||||||
|
* @__NL80211_COALESCE_RULE_INVALID: invalid number for nested attribute
|
||||||
|
* @NL80211_ATTR_COALESCE_RULE_DELAY: delay in msecs used for packet coalescing
|
||||||
|
* @NL80211_ATTR_COALESCE_RULE_CONDITION: condition for packet coalescence,
|
||||||
|
* see &enum nl80211_coalesce_condition.
|
||||||
|
* @NL80211_ATTR_COALESCE_RULE_PKT_PATTERN: packet offset, pattern is matched
|
||||||
|
* after these fixed number of bytes of received packet
|
||||||
|
* @NUM_NL80211_ATTR_COALESCE_RULE: number of attributes
|
||||||
|
* @NL80211_ATTR_COALESCE_RULE_MAX: max attribute number
|
||||||
|
*/
|
||||||
|
enum nl80211_attr_coalesce_rule {
|
||||||
|
__NL80211_COALESCE_RULE_INVALID,
|
||||||
|
NL80211_ATTR_COALESCE_RULE_DELAY,
|
||||||
|
NL80211_ATTR_COALESCE_RULE_CONDITION,
|
||||||
|
NL80211_ATTR_COALESCE_RULE_PKT_PATTERN,
|
||||||
|
|
||||||
|
/* keep last */
|
||||||
|
NUM_NL80211_ATTR_COALESCE_RULE,
|
||||||
|
NL80211_ATTR_COALESCE_RULE_MAX = NUM_NL80211_ATTR_COALESCE_RULE - 1
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* enum nl80211_coalesce_condition - coalesce rule conditions
|
||||||
|
* @NL80211_COALESCE_CONDITION_MATCH: coalaesce Rx packets when patterns
|
||||||
|
* in a rule are matched.
|
||||||
|
* @NL80211_COALESCE_CONDITION_NO_MATCH: coalesce Rx packets when patterns
|
||||||
|
* in a rule are not matched.
|
||||||
|
*/
|
||||||
|
enum nl80211_coalesce_condition {
|
||||||
|
NL80211_COALESCE_CONDITION_MATCH,
|
||||||
|
NL80211_COALESCE_CONDITION_NO_MATCH
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* enum nl80211_iface_limit_attrs - limit attributes
|
* enum nl80211_iface_limit_attrs - limit attributes
|
||||||
* @NL80211_IFACE_LIMIT_UNSPEC: (reserved)
|
* @NL80211_IFACE_LIMIT_UNSPEC: (reserved)
|
||||||
|
@ -3576,6 +3754,10 @@ enum nl80211_ap_sme_features {
|
||||||
* Peering Management entity which may be implemented by registering for
|
* Peering Management entity which may be implemented by registering for
|
||||||
* beacons or NL80211_CMD_NEW_PEER_CANDIDATE events. The mesh beacon is
|
* beacons or NL80211_CMD_NEW_PEER_CANDIDATE events. The mesh beacon is
|
||||||
* still generated by the driver.
|
* still generated by the driver.
|
||||||
|
* @NL80211_FEATURE_ACTIVE_MONITOR: This driver supports an active monitor
|
||||||
|
* interface. An active monitor interface behaves like a normal monitor
|
||||||
|
* interface, but gets added to the driver. It ensures that incoming
|
||||||
|
* unicast packets directed at the configured interface address get ACKed.
|
||||||
*/
|
*/
|
||||||
enum nl80211_feature_flags {
|
enum nl80211_feature_flags {
|
||||||
NL80211_FEATURE_SK_TX_STATUS = 1 << 0,
|
NL80211_FEATURE_SK_TX_STATUS = 1 << 0,
|
||||||
|
@ -3595,6 +3777,7 @@ enum nl80211_feature_flags {
|
||||||
NL80211_FEATURE_ADVERTISE_CHAN_LIMITS = 1 << 14,
|
NL80211_FEATURE_ADVERTISE_CHAN_LIMITS = 1 << 14,
|
||||||
NL80211_FEATURE_FULL_AP_CLIENT_STATE = 1 << 15,
|
NL80211_FEATURE_FULL_AP_CLIENT_STATE = 1 << 15,
|
||||||
NL80211_FEATURE_USERSPACE_MPM = 1 << 16,
|
NL80211_FEATURE_USERSPACE_MPM = 1 << 16,
|
||||||
|
NL80211_FEATURE_ACTIVE_MONITOR = 1 << 17,
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -3695,13 +3878,12 @@ enum nl80211_radar_event {
|
||||||
*
|
*
|
||||||
* Channel states used by the DFS code.
|
* Channel states used by the DFS code.
|
||||||
*
|
*
|
||||||
* @IEEE80211_DFS_USABLE: The channel can be used, but channel availability
|
* @NL80211_DFS_USABLE: The channel can be used, but channel availability
|
||||||
* check (CAC) must be performed before using it for AP or IBSS.
|
* check (CAC) must be performed before using it for AP or IBSS.
|
||||||
* @IEEE80211_DFS_UNAVAILABLE: A radar has been detected on this channel, it
|
* @NL80211_DFS_UNAVAILABLE: A radar has been detected on this channel, it
|
||||||
* is therefore marked as not available.
|
* is therefore marked as not available.
|
||||||
* @IEEE80211_DFS_AVAILABLE: The channel has been CAC checked and is available.
|
* @NL80211_DFS_AVAILABLE: The channel has been CAC checked and is available.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
enum nl80211_dfs_state {
|
enum nl80211_dfs_state {
|
||||||
NL80211_DFS_USABLE,
|
NL80211_DFS_USABLE,
|
||||||
NL80211_DFS_UNAVAILABLE,
|
NL80211_DFS_UNAVAILABLE,
|
||||||
|
@ -3741,4 +3923,15 @@ enum nl80211_crit_proto_id {
|
||||||
/* maximum duration for critical protocol measures */
|
/* maximum duration for critical protocol measures */
|
||||||
#define NL80211_CRIT_PROTO_MAX_DURATION 5000 /* msec */
|
#define NL80211_CRIT_PROTO_MAX_DURATION 5000 /* msec */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* enum nl80211_rxmgmt_flags - flags for received management frame.
|
||||||
|
*
|
||||||
|
* Used by cfg80211_rx_mgmt()
|
||||||
|
*
|
||||||
|
* @NL80211_RXMGMT_FLAG_ANSWERED: frame was answered by device/driver.
|
||||||
|
*/
|
||||||
|
enum nl80211_rxmgmt_flags {
|
||||||
|
NL80211_RXMGMT_FLAG_ANSWERED = 1 << 0,
|
||||||
|
};
|
||||||
|
|
||||||
#endif /* __LINUX_NL80211_H */
|
#endif /* __LINUX_NL80211_H */
|
||||||
|
|
Loading…
Reference in a new issue