diff options
| -rw-r--r-- | package/iw/patches/001-nl80211_h_sync.patch | 221 | 
1 files changed, 214 insertions, 7 deletions
| diff --git a/package/iw/patches/001-nl80211_h_sync.patch b/package/iw/patches/001-nl80211_h_sync.patch index 544df9dff..cccc14475 100644 --- a/package/iw/patches/001-nl80211_h_sync.patch +++ b/package/iw/patches/001-nl80211_h_sync.patch @@ -1,6 +1,121 @@  --- a/nl80211.h  +++ b/nl80211.h -@@ -1475,6 +1475,7 @@ enum nl80211_attrs { +@@ -156,21 +156,23 @@ +  * @NL80211_CMD_DEL_KEY: delete a key identified by %NL80211_ATTR_KEY_IDX +  *	or %NL80211_ATTR_MAC. +  * +- * @NL80211_CMD_GET_BEACON: retrieve beacon information (returned in a +- *	%NL80222_CMD_NEW_BEACON message) +- * @NL80211_CMD_SET_BEACON: set the beacon on an access point interface +- *	using the %NL80211_ATTR_BEACON_INTERVAL, %NL80211_ATTR_DTIM_PERIOD, +- *	%NL80211_ATTR_BEACON_HEAD and %NL80211_ATTR_BEACON_TAIL attributes. +- *	Following attributes are provided for drivers that generate full Beacon +- *	and Probe Response frames internally: %NL80211_ATTR_SSID, ++ * @NL80211_CMD_GET_BEACON: (not used) ++ * @NL80211_CMD_SET_BEACON: change the beacon on an access point interface ++ *	using the %NL80211_ATTR_BEACON_HEAD and %NL80211_ATTR_BEACON_TAIL ++ *	attributes. For drivers that generate the beacon and probe responses ++ *	internally, the following attributes must be provided: %NL80211_ATTR_IE, ++ *	%NL80211_ATTR_IE_PROBE_RESP and %NL80211_ATTR_IE_ASSOC_RESP. ++ * @NL80211_CMD_START_AP: Start AP operation on an AP interface, parameters ++ *	are like for %NL80211_CMD_SET_BEACON, and additionally parameters that ++ *	do not change are used, these include %NL80211_ATTR_BEACON_INTERVAL, ++ *	%NL80211_ATTR_DTIM_PERIOD, %NL80211_ATTR_SSID, +  *	%NL80211_ATTR_HIDDEN_SSID, %NL80211_ATTR_CIPHERS_PAIRWISE, +  *	%NL80211_ATTR_CIPHER_GROUP, %NL80211_ATTR_WPA_VERSIONS, +  *	%NL80211_ATTR_AKM_SUITES, %NL80211_ATTR_PRIVACY, +- *	%NL80211_ATTR_AUTH_TYPE, %NL80211_ATTR_IE, %NL80211_ATTR_IE_PROBE_RESP, +- *	%NL80211_ATTR_IE_ASSOC_RESP. +- * @NL80211_CMD_NEW_BEACON: add a new beacon to an access point interface, +- *	parameters are like for %NL80211_CMD_SET_BEACON. +- * @NL80211_CMD_DEL_BEACON: remove the beacon, stop sending it ++ *	%NL80211_ATTR_AUTH_TYPE and %NL80211_ATTR_INACTIVITY_TIMEOUT. ++ * @NL80211_CMD_NEW_BEACON: old alias for %NL80211_CMD_START_AP ++ * @NL80211_CMD_STOP_AP: Stop AP operation on the given interface ++ * @NL80211_CMD_DEL_BEACON: old alias for %NL80211_CMD_STOP_AP +  * +  * @NL80211_CMD_GET_STATION: Get station attributes for station identified by +  *	%NL80211_ATTR_MAC on the interface identified by %NL80211_ATTR_IFINDEX. +@@ -367,6 +369,11 @@ +  *	%NL80211_ATTR_WIPHY_FREQ, %NL80211_ATTR_CONTROL_PORT, +  *	%NL80211_ATTR_CONTROL_PORT_ETHERTYPE and +  *	%NL80211_ATTR_CONTROL_PORT_NO_ENCRYPT. ++ *	Background scan period can optionally be ++ *	specified in %NL80211_ATTR_BG_SCAN_PERIOD, ++ *	if not specified default background scan configuration ++ *	in driver is used and if period value is 0, bg scan will be disabled. ++ *	This attribute is ignored if driver does not support roam scan. +  *	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 +  *	determined by the STATUS_CODE attribute. +@@ -541,6 +548,11 @@ +  * @NL80211_CMD_SET_NOACK_MAP: sets a bitmap for the individual TIDs whether +  *      No Acknowledgement Policy should be applied. +  * ++ * @NL80211_CMD_CH_SWITCH_NOTIFY: An AP or GO may decide to switch channels ++ *	independently of the userspace SME, send this event indicating ++ *	%NL80211_ATTR_IFINDEX is now on %NL80211_ATTR_WIPHY_FREQ with ++ *	%NL80211_ATTR_WIPHY_CHANNEL_TYPE. ++ * +  * @NL80211_CMD_MAX: highest used command number +  * @__NL80211_CMD_AFTER_LAST: internal use +  */ +@@ -565,8 +577,10 @@ enum nl80211_commands { +  + 	NL80211_CMD_GET_BEACON, + 	NL80211_CMD_SET_BEACON, +-	NL80211_CMD_NEW_BEACON, +-	NL80211_CMD_DEL_BEACON, ++	NL80211_CMD_START_AP, ++	NL80211_CMD_NEW_BEACON = NL80211_CMD_START_AP, ++	NL80211_CMD_STOP_AP, ++	NL80211_CMD_DEL_BEACON = NL80211_CMD_STOP_AP, +  + 	NL80211_CMD_GET_STATION, + 	NL80211_CMD_SET_STATION, +@@ -680,6 +694,8 @@ enum nl80211_commands { +  + 	NL80211_CMD_SET_NOACK_MAP, +  ++	NL80211_CMD_CH_SWITCH_NOTIFY, ++ + 	/* add new commands above here */ +  + 	/* used to define NL80211_CMD_MAX below */ +@@ -1193,6 +1209,19 @@ enum nl80211_commands { +  * @NL80211_ATTR_NOACK_MAP: This u16 bitmap contains the No Ack Policy of +  *      up to 16 TIDs. +  * ++ * @NL80211_ATTR_INACTIVITY_TIMEOUT: timeout value in seconds, this can be ++ *	used by the drivers which has MLME in firmware and does not have support ++ *	to report per station tx/rx activity to free up the staion entry from ++ *	the list. This needs to be used when the driver advertises the ++ *	capability to timeout the stations. ++ * ++ * @NL80211_ATTR_RX_SIGNAL_DBM: signal strength in dBm (as a 32-bit int); ++ *	this attribute is (depending on the driver capabilities) added to ++ *	received frames indicated with %NL80211_CMD_FRAME. ++ * ++ * @NL80211_ATTR_BG_SCAN_PERIOD: Background scan period in seconds ++ *      or 0 to disable background scan. ++ * +  * @NL80211_ATTR_MAX: highest attribute number currently defined +  * @__NL80211_ATTR_AFTER_LAST: internal use +  */ +@@ -1438,6 +1467,12 @@ enum nl80211_attrs { +  + 	NL80211_ATTR_NOACK_MAP, +  ++	NL80211_ATTR_INACTIVITY_TIMEOUT, ++ ++	NL80211_ATTR_RX_SIGNAL_DBM, ++ ++	NL80211_ATTR_BG_SCAN_PERIOD, ++ + 	/* add attributes here, update the policy in nl80211.c */ +  + 	__NL80211_ATTR_AFTER_LAST, +@@ -1475,6 +1510,7 @@ enum nl80211_attrs {   #define NL80211_ATTR_FEATURE_FLAGS NL80211_ATTR_FEATURE_FLAGS   #define NL80211_MAX_SUPP_RATES			32 @@ -8,7 +123,7 @@   #define NL80211_MAX_SUPP_REG_RULES		32   #define NL80211_TKIP_DATA_OFFSET_ENCR_KEY	0   #define NL80211_TKIP_DATA_OFFSET_TX_MIC_KEY	16 -@@ -1536,7 +1537,11 @@ enum nl80211_iftype { +@@ -1536,7 +1572,11 @@ enum nl80211_iftype {    * @NL80211_STA_FLAG_WME: station is WME/QoS capable    * @NL80211_STA_FLAG_MFP: station uses management frame protection    * @NL80211_STA_FLAG_AUTHENTICATED: station is authenticated @@ -21,45 +136,123 @@    * @NL80211_STA_FLAG_MAX: highest station flag number currently defined    * @__NL80211_STA_FLAG_AFTER_LAST: internal use    */ -@@ -1651,6 +1656,9 @@ enum nl80211_sta_bss_param { +@@ -1651,6 +1691,10 @@ enum nl80211_sta_bss_param {    *     containing info as possible, see &enum nl80211_sta_bss_param    * @NL80211_STA_INFO_CONNECTED_TIME: time since the station is last connected    * @NL80211_STA_INFO_STA_FLAGS: Contains a struct nl80211_sta_flag_update.  + * @NL80211_STA_INFO_BEACON_LOSS: count of times beacon loss was detected (u32) ++ * @NL80211_STA_INFO_T_OFFSET: timing offset with respect to this STA (s64)  + * @NL80211_STA_INFO_CHAIN_SIGNAL: per-chain signal strength of last PPDU  + * @NL80211_STA_INFO_CHAIN_SIGNAL_AVG: per-chain signal strength average    * @__NL80211_STA_INFO_AFTER_LAST: internal    * @NL80211_STA_INFO_MAX: highest possible station info attribute    */ -@@ -1673,6 +1681,9 @@ enum nl80211_sta_info { +@@ -1673,6 +1717,10 @@ enum nl80211_sta_info {   	NL80211_STA_INFO_BSS_PARAM,   	NL80211_STA_INFO_CONNECTED_TIME,   	NL80211_STA_INFO_STA_FLAGS,  +	NL80211_STA_INFO_BEACON_LOSS, ++	NL80211_STA_INFO_T_OFFSET,  +	NL80211_STA_INFO_CHAIN_SIGNAL,  +	NL80211_STA_INFO_CHAIN_SIGNAL_AVG,   	/* keep last */   	__NL80211_STA_INFO_AFTER_LAST, -@@ -2098,6 +2109,9 @@ enum nl80211_mntr_flags { +@@ -2098,8 +2146,18 @@ enum nl80211_mntr_flags {    * TUs) during which a mesh STA can send only one Action frame containing a    * PERR element.    *  + * @NL80211_MESHCONF_FORWARDING: set Mesh STA as forwarding or non-forwarding  + * or forwarding entity (default is TRUE - forwarding entity)  + * ++ * @NL80211_MESHCONF_RSSI_THRESHOLD: RSSI threshold in dBm. This specifies the ++ * threshold for average signal strength of candidate station to establish ++ * a peer link. ++ *    * @NL80211_MESHCONF_ATTR_MAX: highest possible mesh configuration attribute    * ++ * @NL80211_MESHCONF_SYNC_OFFSET_MAX_NEIGHBOR: maximum number of neighbors ++ * to synchronize to for 11s default synchronization method (see 11C.12.2.2) ++ *    * @__NL80211_MESHCONF_ATTR_AFTER_LAST: internal use -@@ -2122,6 +2136,7 @@ enum nl80211_meshconf_params { +  */ + enum nl80211_meshconf_params { +@@ -2122,6 +2180,9 @@ enum nl80211_meshconf_params {   	NL80211_MESHCONF_HWMP_RANN_INTERVAL,   	NL80211_MESHCONF_GATE_ANNOUNCEMENTS,   	NL80211_MESHCONF_HWMP_PERR_MIN_INTERVAL,  +	NL80211_MESHCONF_FORWARDING, ++	NL80211_MESHCONF_RSSI_THRESHOLD, ++	NL80211_MESHCONF_SYNC_OFFSET_MAX_NEIGHBOR,   	/* keep last */   	__NL80211_MESHCONF_ATTR_AFTER_LAST, -@@ -2395,12 +2410,15 @@ enum nl80211_key_attributes { +@@ -2161,6 +2222,11 @@ enum nl80211_meshconf_params { +  * complete (unsecured) mesh peering without the need of a userspace daemon. +  * +  * @NL80211_MESH_SETUP_ATTR_MAX: highest possible mesh setup attribute number ++ * ++ * @NL80211_MESH_SETUP_ENABLE_VENDOR_SYNC: Enable this option to use a ++ * vendor specific synchronization method or disable it to use the default ++ * neighbor offset synchronization ++ * +  * @__NL80211_MESH_SETUP_ATTR_AFTER_LAST: Internal use +  */ + enum nl80211_mesh_setup_params { +@@ -2170,6 +2236,7 @@ enum nl80211_mesh_setup_params { + 	NL80211_MESH_SETUP_IE, + 	NL80211_MESH_SETUP_USERSPACE_AUTH, + 	NL80211_MESH_SETUP_USERSPACE_AMPE, ++	NL80211_MESH_SETUP_ENABLE_VENDOR_SYNC, +  + 	/* keep last */ + 	__NL80211_MESH_SETUP_ATTR_AFTER_LAST, +@@ -2179,7 +2246,7 @@ enum nl80211_mesh_setup_params { + /** +  * enum nl80211_txq_attr - TX queue parameter attributes +  * @__NL80211_TXQ_ATTR_INVALID: Attribute number 0 is reserved +- * @NL80211_TXQ_ATTR_QUEUE: TX queue identifier (NL80211_TXQ_Q_*) ++ * @NL80211_TXQ_ATTR_AC: AC identifier (NL80211_AC_*) +  * @NL80211_TXQ_ATTR_TXOP: Maximum burst time in units of 32 usecs, 0 meaning +  *	disabled +  * @NL80211_TXQ_ATTR_CWMIN: Minimum contention window [a value of the form +@@ -2192,7 +2259,7 @@ enum nl80211_mesh_setup_params { +  */ + enum nl80211_txq_attr { + 	__NL80211_TXQ_ATTR_INVALID, +-	NL80211_TXQ_ATTR_QUEUE, ++	NL80211_TXQ_ATTR_AC, + 	NL80211_TXQ_ATTR_TXOP, + 	NL80211_TXQ_ATTR_CWMIN, + 	NL80211_TXQ_ATTR_CWMAX, +@@ -2203,13 +2270,21 @@ enum nl80211_txq_attr { + 	NL80211_TXQ_ATTR_MAX = __NL80211_TXQ_ATTR_AFTER_LAST - 1 + }; +  +-enum nl80211_txq_q { +-	NL80211_TXQ_Q_VO, +-	NL80211_TXQ_Q_VI, +-	NL80211_TXQ_Q_BE, +-	NL80211_TXQ_Q_BK ++enum nl80211_ac { ++	NL80211_AC_VO, ++	NL80211_AC_VI, ++	NL80211_AC_BE, ++	NL80211_AC_BK, ++	NL80211_NUM_ACS + }; +  ++/* backward compat */ ++#define NL80211_TXQ_ATTR_QUEUE	NL80211_TXQ_ATTR_AC ++#define NL80211_TXQ_Q_VO	NL80211_AC_VO ++#define NL80211_TXQ_Q_VI	NL80211_AC_VI ++#define NL80211_TXQ_Q_BE	NL80211_AC_BE ++#define NL80211_TXQ_Q_BK	NL80211_AC_BK ++ + enum nl80211_channel_type { + 	NL80211_CHAN_NO_HT, + 	NL80211_CHAN_HT20, +@@ -2395,12 +2470,15 @@ enum nl80211_key_attributes {    *	in an array of rates as defined in IEEE 802.11 7.3.2.2 (u8 values with    *	1 = 500 kbps) but without the IE length restriction (at most    *	%NL80211_MAX_SUPP_RATES in a single array). @@ -75,3 +268,17 @@   	/* keep last */   	__NL80211_TXRATE_AFTER_LAST, +@@ -2786,10 +2864,13 @@ enum nl80211_ap_sme_features { +  *	TX status to the socket error queue when requested with the +  *	socket option. +  * @NL80211_FEATURE_HT_IBSS: This driver supports IBSS with HT datarates. ++ * @NL80211_FEATURE_INACTIVITY_TIMER: This driver takes care of freeing up ++ *	the connected inactive stations in AP mode. +  */ + enum nl80211_feature_flags { + 	NL80211_FEATURE_SK_TX_STATUS	= 1 << 0, + 	NL80211_FEATURE_HT_IBSS		= 1 << 1, ++	NL80211_FEATURE_INACTIVITY_TIMER = 1 << 2, + }; +  + /** | 
