nl80211: Sync the header file with wireless-testing.git
This commit is contained in:
parent
12970f8a57
commit
7598389afe
1 changed files with 180 additions and 32 deletions
|
@ -39,6 +39,43 @@
|
||||||
* TODO: need more info?
|
* TODO: need more info?
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* DOC: Frame transmission/registration support
|
||||||
|
*
|
||||||
|
* Frame transmission and registration support exists to allow userspace
|
||||||
|
* management entities such as wpa_supplicant react to management frames
|
||||||
|
* that are not being handled by the kernel. This includes, for example,
|
||||||
|
* certain classes of action frames that cannot be handled in the kernel
|
||||||
|
* for various reasons.
|
||||||
|
*
|
||||||
|
* Frame registration is done on a per-interface basis and registrations
|
||||||
|
* cannot be removed other than by closing the socket. It is possible to
|
||||||
|
* specify a registration filter to register, for example, only for a
|
||||||
|
* certain type of action frame. In particular with action frames, those
|
||||||
|
* that userspace registers for will not be returned as unhandled by the
|
||||||
|
* driver, so that the registered application has to take responsibility
|
||||||
|
* for doing that.
|
||||||
|
*
|
||||||
|
* The type of frame that can be registered for is also dependent on the
|
||||||
|
* driver and interface type. The frame types are advertised in wiphy
|
||||||
|
* attributes so applications know what to expect.
|
||||||
|
*
|
||||||
|
* NOTE: When an interface changes type while registrations are active,
|
||||||
|
* these registrations are ignored until the interface type is
|
||||||
|
* changed again. This means that changing the interface type can
|
||||||
|
* lead to a situation that couldn't otherwise be produced, but
|
||||||
|
* any such registrations will be dormant in the sense that they
|
||||||
|
* will not be serviced, i.e. they will not receive any frames.
|
||||||
|
*
|
||||||
|
* Frame transmission allows userspace to send for example the required
|
||||||
|
* responses to action frames. It is subject to some sanity checking,
|
||||||
|
* but many frames can be transmitted. When a frame was transmitted, its
|
||||||
|
* status is indicated to the sending socket.
|
||||||
|
*
|
||||||
|
* For more technical details, see the corresponding command descriptions
|
||||||
|
* below.
|
||||||
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* enum nl80211_commands - supported nl80211 commands
|
* enum nl80211_commands - supported nl80211 commands
|
||||||
*
|
*
|
||||||
|
@ -52,6 +89,8 @@
|
||||||
* %NL80211_ATTR_WIPHY_CHANNEL_TYPE, %NL80211_ATTR_WIPHY_RETRY_SHORT,
|
* %NL80211_ATTR_WIPHY_CHANNEL_TYPE, %NL80211_ATTR_WIPHY_RETRY_SHORT,
|
||||||
* %NL80211_ATTR_WIPHY_RETRY_LONG, %NL80211_ATTR_WIPHY_FRAG_THRESHOLD,
|
* %NL80211_ATTR_WIPHY_RETRY_LONG, %NL80211_ATTR_WIPHY_FRAG_THRESHOLD,
|
||||||
* and/or %NL80211_ATTR_WIPHY_RTS_THRESHOLD.
|
* and/or %NL80211_ATTR_WIPHY_RTS_THRESHOLD.
|
||||||
|
* However, for setting the channel, see %NL80211_CMD_SET_CHANNEL
|
||||||
|
* instead, the support here is for backward compatibility only.
|
||||||
* @NL80211_CMD_NEW_WIPHY: Newly created wiphy, response to get request
|
* @NL80211_CMD_NEW_WIPHY: Newly created wiphy, response to get request
|
||||||
* or rename notification. Has attributes %NL80211_ATTR_WIPHY and
|
* or rename notification. Has attributes %NL80211_ATTR_WIPHY and
|
||||||
* %NL80211_ATTR_WIPHY_NAME.
|
* %NL80211_ATTR_WIPHY_NAME.
|
||||||
|
@ -130,7 +169,7 @@
|
||||||
* %NL80211_ATTR_REG_RULE_POWER_MAX_ANT_GAIN and
|
* %NL80211_ATTR_REG_RULE_POWER_MAX_ANT_GAIN and
|
||||||
* %NL80211_ATTR_REG_RULE_POWER_MAX_EIRP.
|
* %NL80211_ATTR_REG_RULE_POWER_MAX_EIRP.
|
||||||
* @NL80211_CMD_REQ_SET_REG: ask the wireless core to set the regulatory domain
|
* @NL80211_CMD_REQ_SET_REG: ask the wireless core to set the regulatory domain
|
||||||
* to the the specified ISO/IEC 3166-1 alpha2 country code. The core will
|
* to the specified ISO/IEC 3166-1 alpha2 country code. The core will
|
||||||
* store this as a valid request and then query userspace for it.
|
* store this as a valid request and then query userspace for it.
|
||||||
*
|
*
|
||||||
* @NL80211_CMD_GET_MESH_PARAMS: Get mesh networking properties for the
|
* @NL80211_CMD_GET_MESH_PARAMS: Get mesh networking properties for the
|
||||||
|
@ -256,7 +295,9 @@
|
||||||
* auth and assoc steps. For this, you need to specify the SSID in a
|
* auth and assoc steps. For this, you need to specify the SSID in a
|
||||||
* %NL80211_ATTR_SSID attribute, and can optionally specify the association
|
* %NL80211_ATTR_SSID attribute, and can optionally specify the association
|
||||||
* IEs in %NL80211_ATTR_IE, %NL80211_ATTR_AUTH_TYPE, %NL80211_ATTR_MAC,
|
* IEs in %NL80211_ATTR_IE, %NL80211_ATTR_AUTH_TYPE, %NL80211_ATTR_MAC,
|
||||||
* %NL80211_ATTR_WIPHY_FREQ and %NL80211_ATTR_CONTROL_PORT.
|
* %NL80211_ATTR_WIPHY_FREQ, %NL80211_ATTR_CONTROL_PORT,
|
||||||
|
* %NL80211_ATTR_CONTROL_PORT_ETHERTYPE and
|
||||||
|
* %NL80211_ATTR_CONTROL_PORT_NO_ENCRYPT.
|
||||||
* It is also sent as an event, with the BSSID and response IEs when the
|
* It is also sent as an event, with the BSSID and response IEs when the
|
||||||
* connection is established or failed to be established. This can be
|
* connection is established or failed to be established. This can be
|
||||||
* determined by the STATUS_CODE attribute.
|
* determined by the STATUS_CODE attribute.
|
||||||
|
@ -299,16 +340,20 @@
|
||||||
* rate selection. %NL80211_ATTR_IFINDEX is used to specify the interface
|
* rate selection. %NL80211_ATTR_IFINDEX is used to specify the interface
|
||||||
* and @NL80211_ATTR_TX_RATES the set of allowed rates.
|
* and @NL80211_ATTR_TX_RATES the set of allowed rates.
|
||||||
*
|
*
|
||||||
* @NL80211_CMD_REGISTER_ACTION: Register for receiving certain action frames
|
* @NL80211_CMD_REGISTER_FRAME: Register for receiving certain mgmt frames
|
||||||
* (via @NL80211_CMD_ACTION) for processing in userspace. This command
|
* (via @NL80211_CMD_FRAME) for processing in userspace. This command
|
||||||
* requires an interface index and a match attribute containing the first
|
* requires an interface index, a frame type attribute (optional for
|
||||||
* few bytes of the frame that should match, e.g. a single byte for only
|
* backward compatibility reasons, if not given assumes action frames)
|
||||||
* a category match or four bytes for vendor frames including the OUI.
|
* and a match attribute containing the first few bytes of the frame
|
||||||
* The registration cannot be dropped, but is removed automatically
|
* that should match, e.g. a single byte for only a category match or
|
||||||
* when the netlink socket is closed. Multiple registrations can be made.
|
* four bytes for vendor frames including the OUI. The registration
|
||||||
* @NL80211_CMD_ACTION: Action frame TX request and RX notification. This
|
* cannot be dropped, but is removed automatically when the netlink
|
||||||
* command is used both as a request to transmit an Action frame and as an
|
* socket is closed. Multiple registrations can be made.
|
||||||
* event indicating reception of an Action frame that was not processed in
|
* @NL80211_CMD_REGISTER_ACTION: Alias for @NL80211_CMD_REGISTER_FRAME for
|
||||||
|
* backward compatibility
|
||||||
|
* @NL80211_CMD_FRAME: Management frame TX request and RX notification. This
|
||||||
|
* command is used both as a request to transmit a management frame and
|
||||||
|
* as an event indicating reception of a frame that was not processed in
|
||||||
* kernel code, but is for us (i.e., which may need to be processed in a
|
* kernel code, but is for us (i.e., which may need to be processed in a
|
||||||
* user space application). %NL80211_ATTR_FRAME is used to specify the
|
* user space application). %NL80211_ATTR_FRAME is used to specify the
|
||||||
* frame contents (including header). %NL80211_ATTR_WIPHY_FREQ (and
|
* frame contents (including header). %NL80211_ATTR_WIPHY_FREQ (and
|
||||||
|
@ -318,17 +363,29 @@
|
||||||
* operational channel). When called, this operation returns a cookie
|
* operational channel). When called, this operation returns a cookie
|
||||||
* (%NL80211_ATTR_COOKIE) that will be included with the TX status event
|
* (%NL80211_ATTR_COOKIE) that will be included with the TX status event
|
||||||
* pertaining to the TX request.
|
* pertaining to the TX request.
|
||||||
* @NL80211_CMD_ACTION_TX_STATUS: Report TX status of an Action frame
|
* @NL80211_CMD_ACTION: Alias for @NL80211_CMD_FRAME for backward compatibility.
|
||||||
* transmitted with %NL80211_CMD_ACTION. %NL80211_ATTR_COOKIE identifies
|
* @NL80211_CMD_FRAME_TX_STATUS: Report TX status of a management frame
|
||||||
|
* transmitted with %NL80211_CMD_FRAME. %NL80211_ATTR_COOKIE identifies
|
||||||
* the TX command and %NL80211_ATTR_FRAME includes the contents of the
|
* the TX command and %NL80211_ATTR_FRAME includes the contents of the
|
||||||
* frame. %NL80211_ATTR_ACK flag is included if the recipient acknowledged
|
* frame. %NL80211_ATTR_ACK flag is included if the recipient acknowledged
|
||||||
* the frame.
|
* the frame.
|
||||||
|
* @NL80211_CMD_ACTION_TX_STATUS: Alias for @NL80211_CMD_FRAME_TX_STATUS for
|
||||||
|
* backward compatibility.
|
||||||
* @NL80211_CMD_SET_CQM: Connection quality monitor configuration. This command
|
* @NL80211_CMD_SET_CQM: Connection quality monitor configuration. This command
|
||||||
* is used to configure connection quality monitoring notification trigger
|
* is used to configure connection quality monitoring notification trigger
|
||||||
* levels.
|
* levels.
|
||||||
* @NL80211_CMD_NOTIFY_CQM: Connection quality monitor notification. This
|
* @NL80211_CMD_NOTIFY_CQM: Connection quality monitor notification. This
|
||||||
* command is used as an event to indicate the that a trigger level was
|
* command is used as an event to indicate the that a trigger level was
|
||||||
* reached.
|
* reached.
|
||||||
|
* @NL80211_CMD_SET_CHANNEL: Set the channel (using %NL80211_ATTR_WIPHY_FREQ
|
||||||
|
* and %NL80211_ATTR_WIPHY_CHANNEL_TYPE) the given interface (identifed
|
||||||
|
* by %NL80211_ATTR_IFINDEX) shall operate on.
|
||||||
|
* In case multiple channels are supported by the device, the mechanism
|
||||||
|
* with which it switches channels is implementation-defined.
|
||||||
|
* When a monitor interface is given, it can only switch channel while
|
||||||
|
* no other interfaces are operating to avoid disturbing the operation
|
||||||
|
* of any other interfaces, and other interfaces will again take
|
||||||
|
* precedence when they are used.
|
||||||
*
|
*
|
||||||
* @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
|
||||||
|
@ -418,9 +475,12 @@ enum nl80211_commands {
|
||||||
|
|
||||||
NL80211_CMD_SET_TX_BITRATE_MASK,
|
NL80211_CMD_SET_TX_BITRATE_MASK,
|
||||||
|
|
||||||
NL80211_CMD_REGISTER_ACTION,
|
NL80211_CMD_REGISTER_FRAME,
|
||||||
NL80211_CMD_ACTION,
|
NL80211_CMD_REGISTER_ACTION = NL80211_CMD_REGISTER_FRAME,
|
||||||
NL80211_CMD_ACTION_TX_STATUS,
|
NL80211_CMD_FRAME,
|
||||||
|
NL80211_CMD_ACTION = NL80211_CMD_FRAME,
|
||||||
|
NL80211_CMD_FRAME_TX_STATUS,
|
||||||
|
NL80211_CMD_ACTION_TX_STATUS = NL80211_CMD_FRAME_TX_STATUS,
|
||||||
|
|
||||||
NL80211_CMD_SET_POWER_SAVE,
|
NL80211_CMD_SET_POWER_SAVE,
|
||||||
NL80211_CMD_GET_POWER_SAVE,
|
NL80211_CMD_GET_POWER_SAVE,
|
||||||
|
@ -428,6 +488,8 @@ enum nl80211_commands {
|
||||||
NL80211_CMD_SET_CQM,
|
NL80211_CMD_SET_CQM,
|
||||||
NL80211_CMD_NOTIFY_CQM,
|
NL80211_CMD_NOTIFY_CQM,
|
||||||
|
|
||||||
|
NL80211_CMD_SET_CHANNEL,
|
||||||
|
|
||||||
/* add new commands above here */
|
/* add new commands above here */
|
||||||
|
|
||||||
/* used to define NL80211_CMD_MAX below */
|
/* used to define NL80211_CMD_MAX below */
|
||||||
|
@ -626,6 +688,15 @@ enum nl80211_commands {
|
||||||
* request, the driver will assume that the port is unauthorized until
|
* request, the driver will assume that the port is unauthorized until
|
||||||
* authorized by user space. Otherwise, port is marked authorized by
|
* authorized by user space. Otherwise, port is marked authorized by
|
||||||
* default in station mode.
|
* default in station mode.
|
||||||
|
* @NL80211_ATTR_CONTROL_PORT_ETHERTYPE: A 16-bit value indicating the
|
||||||
|
* ethertype that will be used for key negotiation. It can be
|
||||||
|
* specified with the associate and connect commands. If it is not
|
||||||
|
* specified, the value defaults to 0x888E (PAE, 802.1X). This
|
||||||
|
* attribute is also used as a flag in the wiphy information to
|
||||||
|
* indicate that protocols other than PAE are supported.
|
||||||
|
* @NL80211_ATTR_CONTROL_PORT_NO_ENCRYPT: When included along with
|
||||||
|
* %NL80211_ATTR_CONTROL_PORT_ETHERTYPE, indicates that the custom
|
||||||
|
* ethertype frames used for key negotiation must not be encrypted.
|
||||||
*
|
*
|
||||||
* @NL80211_ATTR_TESTDATA: Testmode data blob, passed through to the driver.
|
* @NL80211_ATTR_TESTDATA: Testmode data blob, passed through to the driver.
|
||||||
* We recommend using nested, driver-specific attributes within this.
|
* We recommend using nested, driver-specific attributes within this.
|
||||||
|
@ -695,7 +766,16 @@ enum nl80211_commands {
|
||||||
* is used with %NL80211_CMD_SET_TX_BITRATE_MASK.
|
* is used with %NL80211_CMD_SET_TX_BITRATE_MASK.
|
||||||
*
|
*
|
||||||
* @NL80211_ATTR_FRAME_MATCH: A binary attribute which typically must contain
|
* @NL80211_ATTR_FRAME_MATCH: A binary attribute which typically must contain
|
||||||
* at least one byte, currently used with @NL80211_CMD_REGISTER_ACTION.
|
* at least one byte, currently used with @NL80211_CMD_REGISTER_FRAME.
|
||||||
|
* @NL80211_ATTR_FRAME_TYPE: A u16 indicating the frame type/subtype for the
|
||||||
|
* @NL80211_CMD_REGISTER_FRAME command.
|
||||||
|
* @NL80211_ATTR_TX_FRAME_TYPES: wiphy capability attribute, which is a
|
||||||
|
* nested attribute of %NL80211_ATTR_FRAME_TYPE attributes, containing
|
||||||
|
* information about which frame types can be transmitted with
|
||||||
|
* %NL80211_CMD_FRAME.
|
||||||
|
* @NL80211_ATTR_RX_FRAME_TYPES: wiphy capability attribute, which is a
|
||||||
|
* nested attribute of %NL80211_ATTR_FRAME_TYPE attributes, containing
|
||||||
|
* information about which frame types can be registered for RX.
|
||||||
*
|
*
|
||||||
* @NL80211_ATTR_ACK: Flag attribute indicating that the frame was
|
* @NL80211_ATTR_ACK: Flag attribute indicating that the frame was
|
||||||
* acknowledged by the recipient.
|
* acknowledged by the recipient.
|
||||||
|
@ -709,6 +789,15 @@ enum nl80211_commands {
|
||||||
* NL80211_CMD_AUTHENTICATE, NL80211_CMD_DEAUTHENTICATE,
|
* NL80211_CMD_AUTHENTICATE, NL80211_CMD_DEAUTHENTICATE,
|
||||||
* NL80211_CMD_DISASSOCIATE.
|
* NL80211_CMD_DISASSOCIATE.
|
||||||
*
|
*
|
||||||
|
* @NL80211_ATTR_AP_ISOLATE: (AP mode) Do not forward traffic between stations
|
||||||
|
* connected to this BSS.
|
||||||
|
*
|
||||||
|
* @NL80211_ATTR_WIPHY_TX_POWER_SETTING: Transmit power setting type. See
|
||||||
|
* &enum nl80211_tx_power_setting for possible values.
|
||||||
|
* @NL80211_ATTR_WIPHY_TX_POWER_LEVEL: Transmit power level in signed mBm units.
|
||||||
|
* This is used in association with @NL80211_ATTR_WIPHY_TX_POWER_SETTING
|
||||||
|
* for non-automatic settings.
|
||||||
|
*
|
||||||
* @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
|
||||||
*/
|
*/
|
||||||
|
@ -864,6 +953,18 @@ enum nl80211_attrs {
|
||||||
|
|
||||||
NL80211_ATTR_LOCAL_STATE_CHANGE,
|
NL80211_ATTR_LOCAL_STATE_CHANGE,
|
||||||
|
|
||||||
|
NL80211_ATTR_AP_ISOLATE,
|
||||||
|
|
||||||
|
NL80211_ATTR_WIPHY_TX_POWER_SETTING,
|
||||||
|
NL80211_ATTR_WIPHY_TX_POWER_LEVEL,
|
||||||
|
|
||||||
|
NL80211_ATTR_TX_FRAME_TYPES,
|
||||||
|
NL80211_ATTR_RX_FRAME_TYPES,
|
||||||
|
NL80211_ATTR_FRAME_TYPE,
|
||||||
|
|
||||||
|
NL80211_ATTR_CONTROL_PORT_ETHERTYPE,
|
||||||
|
NL80211_ATTR_CONTROL_PORT_NO_ENCRYPT,
|
||||||
|
|
||||||
/* 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,
|
||||||
|
@ -919,8 +1020,10 @@ enum nl80211_attrs {
|
||||||
* @NL80211_IFTYPE_WDS: wireless distribution interface
|
* @NL80211_IFTYPE_WDS: wireless distribution interface
|
||||||
* @NL80211_IFTYPE_MONITOR: monitor interface receiving all frames
|
* @NL80211_IFTYPE_MONITOR: monitor interface receiving all frames
|
||||||
* @NL80211_IFTYPE_MESH_POINT: mesh point
|
* @NL80211_IFTYPE_MESH_POINT: mesh point
|
||||||
|
* @NL80211_IFTYPE_P2P_CLIENT: P2P client
|
||||||
|
* @NL80211_IFTYPE_P2P_GO: P2P group owner
|
||||||
* @NL80211_IFTYPE_MAX: highest interface type number currently defined
|
* @NL80211_IFTYPE_MAX: highest interface type number currently defined
|
||||||
* @__NL80211_IFTYPE_AFTER_LAST: internal use
|
* @NUM_NL80211_IFTYPES: number of defined interface types
|
||||||
*
|
*
|
||||||
* These values are used with the %NL80211_ATTR_IFTYPE
|
* These values are used with the %NL80211_ATTR_IFTYPE
|
||||||
* to set the type of an interface.
|
* to set the type of an interface.
|
||||||
|
@ -935,10 +1038,12 @@ enum nl80211_iftype {
|
||||||
NL80211_IFTYPE_WDS,
|
NL80211_IFTYPE_WDS,
|
||||||
NL80211_IFTYPE_MONITOR,
|
NL80211_IFTYPE_MONITOR,
|
||||||
NL80211_IFTYPE_MESH_POINT,
|
NL80211_IFTYPE_MESH_POINT,
|
||||||
|
NL80211_IFTYPE_P2P_CLIENT,
|
||||||
|
NL80211_IFTYPE_P2P_GO,
|
||||||
|
|
||||||
/* keep last */
|
/* keep last */
|
||||||
__NL80211_IFTYPE_AFTER_LAST,
|
NUM_NL80211_IFTYPES,
|
||||||
NL80211_IFTYPE_MAX = __NL80211_IFTYPE_AFTER_LAST - 1
|
NL80211_IFTYPE_MAX = NUM_NL80211_IFTYPES - 1
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -947,11 +1052,14 @@ enum nl80211_iftype {
|
||||||
* Station flags. When a station is added to an AP interface, it is
|
* Station flags. When a station is added to an AP interface, it is
|
||||||
* assumed to be already associated (and hence authenticated.)
|
* assumed to be already associated (and hence authenticated.)
|
||||||
*
|
*
|
||||||
|
* @__NL80211_STA_FLAG_INVALID: attribute number 0 is reserved
|
||||||
* @NL80211_STA_FLAG_AUTHORIZED: station is authorized (802.1X)
|
* @NL80211_STA_FLAG_AUTHORIZED: station is authorized (802.1X)
|
||||||
* @NL80211_STA_FLAG_SHORT_PREAMBLE: station is capable of receiving frames
|
* @NL80211_STA_FLAG_SHORT_PREAMBLE: station is capable of receiving frames
|
||||||
* with short barker preamble
|
* with short barker preamble
|
||||||
* @NL80211_STA_FLAG_WME: station is WME/QoS capable
|
* @NL80211_STA_FLAG_WME: station is WME/QoS capable
|
||||||
* @NL80211_STA_FLAG_MFP: station uses management frame protection
|
* @NL80211_STA_FLAG_MFP: station uses management frame protection
|
||||||
|
* @NL80211_STA_FLAG_MAX: highest station flag number currently defined
|
||||||
|
* @__NL80211_STA_FLAG_AFTER_LAST: internal use
|
||||||
*/
|
*/
|
||||||
enum nl80211_sta_flags {
|
enum nl80211_sta_flags {
|
||||||
__NL80211_STA_FLAG_INVALID,
|
__NL80211_STA_FLAG_INVALID,
|
||||||
|
@ -1064,14 +1172,17 @@ enum nl80211_mpath_flags {
|
||||||
* information about a mesh path.
|
* information about a mesh path.
|
||||||
*
|
*
|
||||||
* @__NL80211_MPATH_INFO_INVALID: attribute number 0 is reserved
|
* @__NL80211_MPATH_INFO_INVALID: attribute number 0 is reserved
|
||||||
* @NL80211_ATTR_MPATH_FRAME_QLEN: number of queued frames for this destination
|
* @NL80211_MPATH_INFO_FRAME_QLEN: number of queued frames for this destination
|
||||||
* @NL80211_ATTR_MPATH_SN: destination sequence number
|
* @NL80211_MPATH_INFO_SN: destination sequence number
|
||||||
* @NL80211_ATTR_MPATH_METRIC: metric (cost) of this mesh path
|
* @NL80211_MPATH_INFO_METRIC: metric (cost) of this mesh path
|
||||||
* @NL80211_ATTR_MPATH_EXPTIME: expiration time for the path, in msec from now
|
* @NL80211_MPATH_INFO_EXPTIME: expiration time for the path, in msec from now
|
||||||
* @NL80211_ATTR_MPATH_FLAGS: mesh path flags, enumerated in
|
* @NL80211_MPATH_INFO_FLAGS: mesh path flags, enumerated in
|
||||||
* &enum nl80211_mpath_flags;
|
* &enum nl80211_mpath_flags;
|
||||||
* @NL80211_ATTR_MPATH_DISCOVERY_TIMEOUT: total path discovery timeout, in msec
|
* @NL80211_MPATH_INFO_DISCOVERY_TIMEOUT: total path discovery timeout, in msec
|
||||||
* @NL80211_ATTR_MPATH_DISCOVERY_RETRIES: mesh path discovery retries
|
* @NL80211_MPATH_INFO_DISCOVERY_RETRIES: mesh path discovery retries
|
||||||
|
* @NL80211_MPATH_INFO_MAX: highest mesh path information attribute number
|
||||||
|
* currently defind
|
||||||
|
* @__NL80211_MPATH_INFO_AFTER_LAST: internal use
|
||||||
*/
|
*/
|
||||||
enum nl80211_mpath_info {
|
enum nl80211_mpath_info {
|
||||||
__NL80211_MPATH_INFO_INVALID,
|
__NL80211_MPATH_INFO_INVALID,
|
||||||
|
@ -1100,6 +1211,8 @@ enum nl80211_mpath_info {
|
||||||
* @NL80211_BAND_ATTR_HT_CAPA: HT capabilities, as in the HT information IE
|
* @NL80211_BAND_ATTR_HT_CAPA: HT capabilities, as in the HT information IE
|
||||||
* @NL80211_BAND_ATTR_HT_AMPDU_FACTOR: A-MPDU factor, as in 11n
|
* @NL80211_BAND_ATTR_HT_AMPDU_FACTOR: A-MPDU factor, as in 11n
|
||||||
* @NL80211_BAND_ATTR_HT_AMPDU_DENSITY: A-MPDU density, as in 11n
|
* @NL80211_BAND_ATTR_HT_AMPDU_DENSITY: A-MPDU density, as in 11n
|
||||||
|
* @NL80211_BAND_ATTR_MAX: highest band attribute currently defined
|
||||||
|
* @__NL80211_BAND_ATTR_AFTER_LAST: internal use
|
||||||
*/
|
*/
|
||||||
enum nl80211_band_attr {
|
enum nl80211_band_attr {
|
||||||
__NL80211_BAND_ATTR_INVALID,
|
__NL80211_BAND_ATTR_INVALID,
|
||||||
|
@ -1120,6 +1233,7 @@ enum nl80211_band_attr {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* enum nl80211_frequency_attr - frequency attributes
|
* enum nl80211_frequency_attr - frequency attributes
|
||||||
|
* @__NL80211_FREQUENCY_ATTR_INVALID: attribute number 0 is reserved
|
||||||
* @NL80211_FREQUENCY_ATTR_FREQ: Frequency in MHz
|
* @NL80211_FREQUENCY_ATTR_FREQ: Frequency in MHz
|
||||||
* @NL80211_FREQUENCY_ATTR_DISABLED: Channel is disabled in current
|
* @NL80211_FREQUENCY_ATTR_DISABLED: Channel is disabled in current
|
||||||
* regulatory domain.
|
* regulatory domain.
|
||||||
|
@ -1131,6 +1245,9 @@ enum nl80211_band_attr {
|
||||||
* on this channel in current regulatory domain.
|
* on this channel in current regulatory domain.
|
||||||
* @NL80211_FREQUENCY_ATTR_MAX_TX_POWER: Maximum transmission power in mBm
|
* @NL80211_FREQUENCY_ATTR_MAX_TX_POWER: Maximum transmission power in mBm
|
||||||
* (100 * dBm).
|
* (100 * dBm).
|
||||||
|
* @NL80211_FREQUENCY_ATTR_MAX: highest frequency attribute number
|
||||||
|
* currently defined
|
||||||
|
* @__NL80211_FREQUENCY_ATTR_AFTER_LAST: internal use
|
||||||
*/
|
*/
|
||||||
enum nl80211_frequency_attr {
|
enum nl80211_frequency_attr {
|
||||||
__NL80211_FREQUENCY_ATTR_INVALID,
|
__NL80211_FREQUENCY_ATTR_INVALID,
|
||||||
|
@ -1150,9 +1267,13 @@ enum nl80211_frequency_attr {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* enum nl80211_bitrate_attr - bitrate attributes
|
* enum nl80211_bitrate_attr - bitrate attributes
|
||||||
|
* @__NL80211_BITRATE_ATTR_INVALID: attribute number 0 is reserved
|
||||||
* @NL80211_BITRATE_ATTR_RATE: Bitrate in units of 100 kbps
|
* @NL80211_BITRATE_ATTR_RATE: Bitrate in units of 100 kbps
|
||||||
* @NL80211_BITRATE_ATTR_2GHZ_SHORTPREAMBLE: Short preamble supported
|
* @NL80211_BITRATE_ATTR_2GHZ_SHORTPREAMBLE: Short preamble supported
|
||||||
* in 2.4 GHz band.
|
* in 2.4 GHz band.
|
||||||
|
* @NL80211_BITRATE_ATTR_MAX: highest bitrate attribute number
|
||||||
|
* currently defined
|
||||||
|
* @__NL80211_BITRATE_ATTR_AFTER_LAST: internal use
|
||||||
*/
|
*/
|
||||||
enum nl80211_bitrate_attr {
|
enum nl80211_bitrate_attr {
|
||||||
__NL80211_BITRATE_ATTR_INVALID,
|
__NL80211_BITRATE_ATTR_INVALID,
|
||||||
|
@ -1208,6 +1329,7 @@ enum nl80211_reg_type {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* enum nl80211_reg_rule_attr - regulatory rule attributes
|
* enum nl80211_reg_rule_attr - regulatory rule attributes
|
||||||
|
* @__NL80211_REG_RULE_ATTR_INVALID: attribute number 0 is reserved
|
||||||
* @NL80211_ATTR_REG_RULE_FLAGS: a set of flags which specify additional
|
* @NL80211_ATTR_REG_RULE_FLAGS: a set of flags which specify additional
|
||||||
* considerations for a given frequency range. These are the
|
* considerations for a given frequency range. These are the
|
||||||
* &enum nl80211_reg_rule_flags.
|
* &enum nl80211_reg_rule_flags.
|
||||||
|
@ -1224,6 +1346,9 @@ enum nl80211_reg_type {
|
||||||
* If you don't have one then don't send this.
|
* If you don't have one then don't send this.
|
||||||
* @NL80211_ATTR_POWER_RULE_MAX_EIRP: the maximum allowed EIRP for
|
* @NL80211_ATTR_POWER_RULE_MAX_EIRP: the maximum allowed EIRP for
|
||||||
* a given frequency range. The value is in mBm (100 * dBm).
|
* a given frequency range. The value is in mBm (100 * dBm).
|
||||||
|
* @NL80211_REG_RULE_ATTR_MAX: highest regulatory rule attribute number
|
||||||
|
* currently defined
|
||||||
|
* @__NL80211_REG_RULE_ATTR_AFTER_LAST: internal use
|
||||||
*/
|
*/
|
||||||
enum nl80211_reg_rule_attr {
|
enum nl80211_reg_rule_attr {
|
||||||
__NL80211_REG_RULE_ATTR_INVALID,
|
__NL80211_REG_RULE_ATTR_INVALID,
|
||||||
|
@ -1275,6 +1400,9 @@ enum nl80211_reg_rule_flags {
|
||||||
* @__NL80211_SURVEY_INFO_INVALID: attribute number 0 is reserved
|
* @__NL80211_SURVEY_INFO_INVALID: attribute number 0 is reserved
|
||||||
* @NL80211_SURVEY_INFO_FREQUENCY: center frequency of channel
|
* @NL80211_SURVEY_INFO_FREQUENCY: center frequency of channel
|
||||||
* @NL80211_SURVEY_INFO_NOISE: noise level of channel (u8, dBm)
|
* @NL80211_SURVEY_INFO_NOISE: noise level of channel (u8, dBm)
|
||||||
|
* @NL80211_SURVEY_INFO_MAX: highest survey info attribute number
|
||||||
|
* currently defined
|
||||||
|
* @__NL80211_SURVEY_INFO_AFTER_LAST: internal use
|
||||||
*/
|
*/
|
||||||
enum nl80211_survey_info {
|
enum nl80211_survey_info {
|
||||||
__NL80211_SURVEY_INFO_INVALID,
|
__NL80211_SURVEY_INFO_INVALID,
|
||||||
|
@ -1439,6 +1567,7 @@ enum nl80211_channel_type {
|
||||||
* enum nl80211_bss - netlink attributes for a BSS
|
* enum nl80211_bss - netlink attributes for a BSS
|
||||||
*
|
*
|
||||||
* @__NL80211_BSS_INVALID: invalid
|
* @__NL80211_BSS_INVALID: invalid
|
||||||
|
* @NL80211_BSS_BSSID: BSSID of the BSS (6 octets)
|
||||||
* @NL80211_BSS_FREQUENCY: frequency in MHz (u32)
|
* @NL80211_BSS_FREQUENCY: frequency in MHz (u32)
|
||||||
* @NL80211_BSS_TSF: TSF of the received probe response/beacon (u64)
|
* @NL80211_BSS_TSF: TSF of the received probe response/beacon (u64)
|
||||||
* @NL80211_BSS_BEACON_INTERVAL: beacon interval of the (I)BSS (u16)
|
* @NL80211_BSS_BEACON_INTERVAL: beacon interval of the (I)BSS (u16)
|
||||||
|
@ -1482,6 +1611,12 @@ enum nl80211_bss {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* enum nl80211_bss_status - BSS "status"
|
* enum nl80211_bss_status - BSS "status"
|
||||||
|
* @NL80211_BSS_STATUS_AUTHENTICATED: Authenticated with this BSS.
|
||||||
|
* @NL80211_BSS_STATUS_ASSOCIATED: Associated with this BSS.
|
||||||
|
* @NL80211_BSS_STATUS_IBSS_JOINED: Joined to this IBSS.
|
||||||
|
*
|
||||||
|
* The BSS status is a BSS attribute in scan dumps, which
|
||||||
|
* indicates the status the interface has wrt. this BSS.
|
||||||
*/
|
*/
|
||||||
enum nl80211_bss_status {
|
enum nl80211_bss_status {
|
||||||
NL80211_BSS_STATUS_AUTHENTICATED,
|
NL80211_BSS_STATUS_AUTHENTICATED,
|
||||||
|
@ -1592,8 +1727,8 @@ enum nl80211_tx_rate_attributes {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* enum nl80211_band - Frequency band
|
* enum nl80211_band - Frequency band
|
||||||
* @NL80211_BAND_2GHZ - 2.4 GHz ISM band
|
* @NL80211_BAND_2GHZ: 2.4 GHz ISM band
|
||||||
* @NL80211_BAND_5GHZ - around 5 GHz band (4.9 - 5.7 GHz)
|
* @NL80211_BAND_5GHZ: around 5 GHz band (4.9 - 5.7 GHz)
|
||||||
*/
|
*/
|
||||||
enum nl80211_band {
|
enum nl80211_band {
|
||||||
NL80211_BAND_2GHZ,
|
NL80211_BAND_2GHZ,
|
||||||
|
@ -1631,9 +1766,9 @@ enum nl80211_attr_cqm {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* enum nl80211_cqm_rssi_threshold_event - RSSI threshold event
|
* enum nl80211_cqm_rssi_threshold_event - RSSI threshold event
|
||||||
* @NL80211_CQM_RSSI_THRESHOLD_EVENT_LOW - The RSSI level is lower than the
|
* @NL80211_CQM_RSSI_THRESHOLD_EVENT_LOW: The RSSI level is lower than the
|
||||||
* configured threshold
|
* configured threshold
|
||||||
* @NL80211_CQM_RSSI_THRESHOLD_EVENT_HIGH - The RSSI is higher than the
|
* @NL80211_CQM_RSSI_THRESHOLD_EVENT_HIGH: The RSSI is higher than the
|
||||||
* configured threshold
|
* configured threshold
|
||||||
*/
|
*/
|
||||||
enum nl80211_cqm_rssi_threshold_event {
|
enum nl80211_cqm_rssi_threshold_event {
|
||||||
|
@ -1641,4 +1776,17 @@ enum nl80211_cqm_rssi_threshold_event {
|
||||||
NL80211_CQM_RSSI_THRESHOLD_EVENT_HIGH,
|
NL80211_CQM_RSSI_THRESHOLD_EVENT_HIGH,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* enum nl80211_tx_power_setting - TX power adjustment
|
||||||
|
* @NL80211_TX_POWER_AUTOMATIC: automatically determine transmit power
|
||||||
|
* @NL80211_TX_POWER_LIMITED: limit TX power by the mBm parameter
|
||||||
|
* @NL80211_TX_POWER_FIXED: fix TX power to the mBm parameter
|
||||||
|
*/
|
||||||
|
enum nl80211_tx_power_setting {
|
||||||
|
NL80211_TX_POWER_AUTOMATIC,
|
||||||
|
NL80211_TX_POWER_LIMITED,
|
||||||
|
NL80211_TX_POWER_FIXED,
|
||||||
|
};
|
||||||
|
|
||||||
#endif /* __LINUX_NL80211_H */
|
#endif /* __LINUX_NL80211_H */
|
||||||
|
|
Loading…
Reference in a new issue