sta_info.h 23.5 KB
Newer Older
1 2
/*
 * Copyright 2002-2005, Devicescape Software, Inc.
3
 * Copyright 2013-2014  Intel Mobile Communications GmbH
4 5 6 7 8 9 10 11 12 13 14 15
 *
 * 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.
 */

#ifndef STA_INFO_H
#define STA_INFO_H

#include <linux/list.h>
#include <linux/types.h>
#include <linux/if_ether.h>
16
#include <linux/workqueue.h>
17
#include <linux/average.h>
18
#include <linux/etherdevice.h>
19
#include <linux/rhashtable.h>
J
Johannes Berg 已提交
20
#include "key.h"
21

22 23 24
/**
 * enum ieee80211_sta_info_flags - Stations flags
 *
J
Johannes Berg 已提交
25 26
 * These flags are used with &struct sta_info's @flags member, but
 * only indirectly with set_sta_flag() and friends.
27 28 29
 *
 * @WLAN_STA_AUTH: Station is authenticated.
 * @WLAN_STA_ASSOC: Station is associated.
30
 * @WLAN_STA_PS_STA: Station is in power-save mode
31 32 33 34 35 36
 * @WLAN_STA_AUTHORIZED: Station is authorized to send/receive traffic.
 *	This bit is always checked so needs to be enabled for all stations
 *	when virtual port control is not in use.
 * @WLAN_STA_SHORT_PREAMBLE: Station is capable of receiving short-preamble
 *	frames.
 * @WLAN_STA_WDS: Station is one of our WDS peers.
37
 * @WLAN_STA_CLEAR_PS_FILT: Clear PS filter in hardware (using the
38
 *	IEEE80211_TX_CTL_CLEAR_PS_FILT control flag) when the next
39
 *	frame to this station is transmitted.
40
 * @WLAN_STA_MFP: Management frame protection is used with this STA.
41
 * @WLAN_STA_BLOCK_BA: Used to deny ADDBA requests (both TX and RX)
42
 *	during suspend/resume and station removal.
43 44 45 46 47
 * @WLAN_STA_PS_DRIVER: driver requires keeping this station in
 *	power-save mode logically to flush frames that might still
 *	be in the queues
 * @WLAN_STA_PSPOLL: Station sent PS-poll while driver was keeping
 *	station in power-save mode, reply when the driver unblocks.
48 49 50
 * @WLAN_STA_TDLS_PEER: Station is a TDLS peer.
 * @WLAN_STA_TDLS_PEER_AUTH: This TDLS peer is authorized to send direct
 *	packets. This means the link is enabled.
51 52
 * @WLAN_STA_TDLS_INITIATOR: We are the initiator of the TDLS link with this
 *	station.
53
 * @WLAN_STA_TDLS_CHAN_SWITCH: This TDLS peer supports TDLS channel-switching
54 55
 * @WLAN_STA_TDLS_OFF_CHANNEL: The local STA is currently off-channel with this
 *	TDLS peer
56 57
 * @WLAN_STA_TDLS_WIDER_BW: This TDLS peer supports working on a wider bw on
 *	the BSS base channel.
J
Johannes Berg 已提交
58 59 60 61
 * @WLAN_STA_UAPSD: Station requested unscheduled SP while driver was
 *	keeping station in power-save mode, reply when the driver
 *	unblocks the station.
 * @WLAN_STA_SP: Station is in a service period, so don't try to
62
 *	reply to other uAPSD trigger frames or PS-Poll.
63
 * @WLAN_STA_4ADDR_EVENT: 4-addr event was already sent for this frame.
64
 * @WLAN_STA_INSERTED: This station is inserted into the hash table.
65
 * @WLAN_STA_RATE_CONTROL: rate control was initialized for this station.
66
 * @WLAN_STA_TOFFSET_KNOWN: toffset calculated for this station is valid.
M
Marco Porsch 已提交
67 68
 * @WLAN_STA_MPSP_OWNER: local STA is owner of a mesh Peer Service Period.
 * @WLAN_STA_MPSP_RECIPIENT: local STA is recipient of a MPSP.
69 70
 * @WLAN_STA_PS_DELIVER: station woke up, but we're still blocking TX
 *	until pending frames are delivered
71 72
 */
enum ieee80211_sta_info_flags {
J
Johannes Berg 已提交
73 74 75 76 77 78 79 80 81 82 83 84 85
	WLAN_STA_AUTH,
	WLAN_STA_ASSOC,
	WLAN_STA_PS_STA,
	WLAN_STA_AUTHORIZED,
	WLAN_STA_SHORT_PREAMBLE,
	WLAN_STA_WDS,
	WLAN_STA_CLEAR_PS_FILT,
	WLAN_STA_MFP,
	WLAN_STA_BLOCK_BA,
	WLAN_STA_PS_DRIVER,
	WLAN_STA_PSPOLL,
	WLAN_STA_TDLS_PEER,
	WLAN_STA_TDLS_PEER_AUTH,
86
	WLAN_STA_TDLS_INITIATOR,
87
	WLAN_STA_TDLS_CHAN_SWITCH,
88
	WLAN_STA_TDLS_OFF_CHANNEL,
89
	WLAN_STA_TDLS_WIDER_BW,
J
Johannes Berg 已提交
90 91
	WLAN_STA_UAPSD,
	WLAN_STA_SP,
92
	WLAN_STA_4ADDR_EVENT,
93
	WLAN_STA_INSERTED,
94
	WLAN_STA_RATE_CONTROL,
95
	WLAN_STA_TOFFSET_KNOWN,
M
Marco Porsch 已提交
96 97
	WLAN_STA_MPSP_OWNER,
	WLAN_STA_MPSP_RECIPIENT,
98
	WLAN_STA_PS_DELIVER,
99
};
100

101
#define ADDBA_RESP_INTERVAL HZ
102 103 104
#define HT_AGG_MAX_RETRIES		15
#define HT_AGG_BURST_RETRIES		3
#define HT_AGG_RETRIES_PERIOD		(15 * HZ)
105

106 107 108 109
#define HT_AGG_STATE_DRV_READY		0
#define HT_AGG_STATE_RESPONSE_RECEIVED	1
#define HT_AGG_STATE_OPERATIONAL	2
#define HT_AGG_STATE_STOPPING		3
110 111
#define HT_AGG_STATE_WANT_START		4
#define HT_AGG_STATE_WANT_STOP		5
112

113 114 115 116 117 118 119
enum ieee80211_agg_stop_reason {
	AGG_STOP_DECLINED,
	AGG_STOP_LOCAL_REQUEST,
	AGG_STOP_PEER_REQUEST,
	AGG_STOP_DESTROY_STA,
};

120 121 122
/**
 * struct tid_ampdu_tx - TID aggregation information (Tx).
 *
123
 * @rcu_head: rcu head for freeing structure
124
 * @session_timer: check if we keep Tx-ing on the TID (by timeout value)
125
 * @addba_resp_timer: timer for peer's response to addba request
126
 * @pending: pending frames queue -- use sta's spinlock to protect
127
 * @dialog_token: dialog token for aggregation session
128
 * @timeout: session timeout value to be filled in ADDBA requests
129
 * @state: session state (see above)
130
 * @last_tx: jiffies of last tx activity
131
 * @stop_initiator: initiator of a session stop
132
 * @tx_stop: TX DelBA frame when stopping
133
 * @buf_size: reorder buffer size at receiver
134 135
 * @failed_bar_ssn: ssn of the last failed BAR tx attempt
 * @bar_pending: BAR needs to be re-sent
136
 *
137 138 139 140 141 142 143 144
 * This structure's lifetime is managed by RCU, assignments to
 * the array holding it must hold the aggregation mutex.
 *
 * The TX path can access it under RCU lock-free if, and
 * only if, the state has the flag %HT_AGG_STATE_OPERATIONAL
 * set. Otherwise, the TX path must also acquire the spinlock
 * and re-check the state, see comments in the tx code
 * touching it.
145 146
 */
struct tid_ampdu_tx {
147
	struct rcu_head rcu_head;
148
	struct timer_list session_timer;
149
	struct timer_list addba_resp_timer;
150
	struct sk_buff_head pending;
151
	unsigned long state;
152
	unsigned long last_tx;
153
	u16 timeout;
154
	u8 dialog_token;
155
	u8 stop_initiator;
156
	bool tx_stop;
157
	u8 buf_size;
158 159 160

	u16 failed_bar_ssn;
	bool bar_pending;
161
};
162 163 164 165

/**
 * struct tid_ampdu_rx - TID aggregation information (Rx).
 *
166 167
 * @reorder_buf: buffer to reorder incoming aggregated MPDUs. An MPDU may be an
 *	A-MSDU with individually reported subframes.
168
 * @reorder_time: jiffies when skb was added
169
 * @session_timer: check if peer keeps Tx-ing on the TID (by timeout value)
170
 * @reorder_timer: releases expired frames from the reorder buffer.
171
 * @last_rx: jiffies of last rx activity
172 173
 * @head_seq_num: head sequence number in reordering buffer.
 * @stored_mpdu_num: number of MPDUs in reordering buffer
174 175
 * @ssn: Starting Sequence Number expected to be aggregated.
 * @buf_size: buffer size for incoming A-MPDUs
176
 * @timeout: reset timer value (in TUs).
177
 * @dialog_token: dialog token for aggregation session
178
 * @rcu_head: RCU head used for freeing this struct
179
 * @reorder_lock: serializes access to reorder buffer, see below.
180 181
 * @auto_seq: used for offloaded BA sessions to automatically pick head_seq_and
 *	and ssn.
182
 * @removed: this session is removed (but might have been found due to RCU)
183
 *
184 185
 * This structure's lifetime is managed by RCU, assignments to
 * the array holding it must hold the aggregation mutex.
186
 *
187 188 189 190
 * The @reorder_lock is used to protect the members of this
 * struct, except for @timeout, @buf_size and @dialog_token,
 * which are constant across the lifetime of the struct (the
 * dialog token being used only for debugging).
191 192
 */
struct tid_ampdu_rx {
193
	struct rcu_head rcu_head;
194
	spinlock_t reorder_lock;
195
	struct sk_buff_head *reorder_buf;
196
	unsigned long *reorder_time;
197
	struct timer_list session_timer;
198
	struct timer_list reorder_timer;
199
	unsigned long last_rx;
200 201
	u16 head_seq_num;
	u16 stored_mpdu_num;
202 203 204 205
	u16 ssn;
	u16 buf_size;
	u16 timeout;
	u8 dialog_token;
206
	bool auto_seq;
207
	bool removed;
208 209
};

J
Johannes Berg 已提交
210 211 212
/**
 * struct sta_ampdu_mlme - STA aggregation information.
 *
213
 * @tid_rx: aggregation info for Rx per TID -- RCU protected
J
Johannes Berg 已提交
214
 * @tid_tx: aggregation info for Tx per TID
J
Johannes Berg 已提交
215
 * @tid_start_tx: sessions where start was requested
J
Johannes Berg 已提交
216
 * @addba_req_num: number of times addBA request has been sent.
217
 * @last_addba_req_time: timestamp of the last addBA request.
J
Johannes Berg 已提交
218
 * @dialog_token_allocator: dialog token enumerator for each new session;
219
 * @work: work struct for starting/stopping aggregation
220 221
 * @tid_rx_timer_expired: bitmap indicating on which TIDs the
 *	RX timer expired until the work for it runs
222 223
 * @tid_rx_stop_requested:  bitmap indicating which BA sessions per TID the
 *	driver requested to close until the work for it runs
224 225
 * @mtx: mutex to protect all TX data (except non-NULL assignments
 *	to tid_tx[idx], which are protected by the sta spinlock)
226
 *	tid_start_tx is also protected by sta->lock.
J
Johannes Berg 已提交
227 228
 */
struct sta_ampdu_mlme {
229
	struct mutex mtx;
J
Johannes Berg 已提交
230
	/* rx */
231 232 233
	struct tid_ampdu_rx __rcu *tid_rx[IEEE80211_NUM_TIDS];
	unsigned long tid_rx_timer_expired[BITS_TO_LONGS(IEEE80211_NUM_TIDS)];
	unsigned long tid_rx_stop_requested[BITS_TO_LONGS(IEEE80211_NUM_TIDS)];
J
Johannes Berg 已提交
234
	/* tx */
235
	struct work_struct work;
236 237 238 239
	struct tid_ampdu_tx __rcu *tid_tx[IEEE80211_NUM_TIDS];
	struct tid_ampdu_tx *tid_start_tx[IEEE80211_NUM_TIDS];
	unsigned long last_addba_req_time[IEEE80211_NUM_TIDS];
	u8 addba_req_num[IEEE80211_NUM_TIDS];
J
Johannes Berg 已提交
240 241 242 243
	u8 dialog_token_allocator;
};


244 245 246
/* Value to indicate no TID reservation */
#define IEEE80211_TID_UNRESERVED	0xff

247 248
#define IEEE80211_FAST_XMIT_MAX_IV	18

J
Johannes Berg 已提交
249 250 251 252 253 254 255 256 257 258 259
/**
 * struct ieee80211_fast_tx - TX fastpath information
 * @key: key to use for hw crypto
 * @hdr: the 802.11 header to put with the frame
 * @hdr_len: actual 802.11 header length
 * @sa_offs: offset of the SA
 * @da_offs: offset of the DA
 * @pn_offs: offset where to put PN for crypto (or 0 if not needed)
 * @band: band this will be transmitted on, for tx_info
 * @rcu_head: RCU head to free this struct
 *
260 261 262
 * This struct is small enough so that the common case (maximum crypto
 * header length of 8 like for CCMP/GCMP) fits into a single 64-byte
 * cache line.
J
Johannes Berg 已提交
263 264 265 266 267 268
 */
struct ieee80211_fast_tx {
	struct ieee80211_key *key;
	u8 hdr_len;
	u8 sa_offs, da_offs, pn_offs;
	u8 band;
269 270
	u8 hdr[30 + 2 + IEEE80211_FAST_XMIT_MAX_IV +
	       sizeof(rfc1042_header)];
J
Johannes Berg 已提交
271 272 273 274

	struct rcu_head rcu_head;
};

275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316
/**
 * struct mesh_sta - mesh STA information
 * @plink_lock: serialize access to plink fields
 * @llid: Local link ID
 * @plid: Peer link ID
 * @reason: Cancel reason on PLINK_HOLDING state
 * @plink_retries: Retries in establishment
 * @plink_state: peer link state
 * @plink_timeout: timeout of peer link
 * @plink_timer: peer link watch timer
 * @t_offset: timing offset relative to this host
 * @t_offset_setpoint: reference timing offset of this sta to be used when
 * 	calculating clockdrift
 * @local_pm: local link-specific power save mode
 * @peer_pm: peer-specific power save mode towards local STA
 * @nonpeer_pm: STA power save mode towards non-peer neighbors
 * @processed_beacon: set to true after peer rates and capabilities are
 *	processed
 */
struct mesh_sta {
	struct timer_list plink_timer;

	s64 t_offset;
	s64 t_offset_setpoint;

	spinlock_t plink_lock;
	u16 llid;
	u16 plid;
	u16 reason;
	u8 plink_retries;

	bool processed_beacon;

	enum nl80211_plink_state plink_state;
	u32 plink_timeout;

	/* mesh power save */
	enum nl80211_mesh_power_mode local_pm;
	enum nl80211_mesh_power_mode peer_pm;
	enum nl80211_mesh_power_mode nonpeer_pm;
};

317 318 319 320 321 322 323
/**
 * struct sta_info - STA information
 *
 * This structure collects information about a station that
 * mac80211 is communicating with.
 *
 * @list: global linked list entry
324
 * @free_list: list entry for keeping track of stations to free
325
 * @hash_node: hash node for rhashtable
326 327
 * @addr: station's MAC address - duplicated from public part to
 *	let the hash table work with just a single cacheline
328
 * @local: pointer to the global information
329
 * @sdata: virtual interface this station belongs to
330 331
 * @ptk: peer keys negotiated with this station, if any
 * @ptk_idx: last installed peer key index
332
 * @gtk: group keys negotiated with this station, if any
333
 * @rate_ctrl: rate control algorithm reference
334 335
 * @rate_ctrl_lock: spinlock used to protect rate control data
 *	(data inside the algorithm, so serializes calls there)
336 337 338
 * @rate_ctrl_priv: rate control private per-STA pointer
 * @last_tx_rate: rate used for last transmit, to report to userspace as
 *	"the" transmit rate
339 340
 * @last_rx_rate_idx: rx status rate index of the last data packet
 * @last_rx_rate_flag: rx status flag of the last data packet
341
 * @last_rx_rate_vht_flag: rx status vht flag of the last data packet
342
 * @last_rx_rate_vht_nss: rx status nss of last data packet
R
Randy Dunlap 已提交
343 344
 * @lock: used for locking all fields that require locking, see comments
 *	in the header file.
345
 * @drv_deliver_wk: used for delivering frames after driver PS unblocking
346
 * @listen_interval: listen interval of this station, when we're acting as AP
J
Johannes Berg 已提交
347
 * @_flags: STA flags, see &enum ieee80211_sta_info_flags, do not use directly
348
 * @ps_lock: used for powersave (when mac80211 is the AP) related locking
349 350 351 352 353 354 355
 * @ps_tx_buf: buffers (per AC) of frames to transmit to this station
 *	when it leaves power saving state or polls
 * @tx_filtered: buffers (per AC) of frames we already tried to
 *	transmit but were filtered by hardware due to STA having
 *	entered power saving state, these are also delivered to
 *	the station when it leaves powersave or polls for frames
 * @driver_buffered_tids: bitmap of TIDs the driver has data buffered on
356
 * @txq_buffered_tids: bitmap of TIDs that mac80211 has txq data buffered on
357 358
 * @rx_packets: Number of MSDUs received from this STA
 * @rx_bytes: Number of bytes received from this STA
359
 * @last_rx: time (in jiffies) when last frame was received from this STA
360
 * @last_connected: time (in seconds) when a station got connected
R
Randy Dunlap 已提交
361 362 363 364
 * @num_duplicates: number of duplicate frames received from this STA
 * @rx_fragments: number of received MPDUs
 * @rx_dropped: number of dropped MPDUs from this STA
 * @last_signal: signal of last received frame from this STA
365
 * @avg_signal: moving average of signal of received frames from this STA
366
 * @last_ack_signal: signal of last received Ack frame from this STA
367 368
 * @last_seq_ctrl: last received seq/frag number from this STA (per TID
 *	plus one for non-QoS frames)
369 370 371
 * @tx_filtered_count: number of frames the hardware filtered for this STA
 * @tx_retry_failed: number of frames that failed retry
 * @tx_retry_count: total number of retries for frames to this STA
R
Randy Dunlap 已提交
372 373
 * @fail_avg: moving percentage of failed MSDUs
 * @tx_packets: number of RX/TX MSDUs
374 375 376
 * @tx_bytes: number of bytes transmitted to this STA
 * @tid_seq: per-TID sequence numbers for sending to this STA
 * @ampdu_mlme: A-MPDU state machine state
R
Randy Dunlap 已提交
377
 * @timer_to_tid: identity mapping to ID timers
378
 * @mesh: mesh STA information
R
Randy Dunlap 已提交
379
 * @debugfs: debug filesystem info
380
 * @dead: set to true when sta is unlinked
381
 * @uploaded: set to true when sta is uploaded to the driver
382
 * @lost_packets: number of consecutive lost packets
383
 * @sta: station information we share with the driver
384
 * @sta_state: duplicates information about station state (for debug)
385
 * @beacon_loss_count: number of times beacon loss has triggered
J
Johannes Berg 已提交
386
 * @rcu_head: RCU head used for freeing this station struct
387 388
 * @cur_max_bandwidth: maximum bandwidth to use for TX to the station,
 *	taken from HT/VHT capabilities or VHT operating mode notification
J
Johannes Berg 已提交
389 390 391
 * @chains: chains ever used for RX from this station
 * @chain_signal_last: last signal (per chain)
 * @chain_signal_avg: signal average (per chain)
392 393
 * @known_smps_mode: the smps_mode the client thinks we are in. Relevant for
 *	AP only.
394
 * @cipher_scheme: optional cipher scheme for this station
395
 * @last_tdls_pkt_time: holds the time in jiffies of last TDLS pkt ACKed
396
 * @reserved_tid: reserved TID (if any, otherwise IEEE80211_TID_UNRESERVED)
397 398 399 400 401 402 403 404
 * @tx_msdu: MSDUs transmitted to this station, using IEEE80211_NUM_TID
 *	entry for non-QoS frames
 * @tx_msdu_retries: MSDU retries for transmissions to to this station,
 *	using IEEE80211_NUM_TID entry for non-QoS frames
 * @tx_msdu_failed: MSDU failures for transmissions to to this station,
 *	using IEEE80211_NUM_TID entry for non-QoS frames
 * @rx_msdu: MSDUs received from this station, using IEEE80211_NUM_TID
 *	entry for non-QoS frames
J
Johannes Berg 已提交
405
 * @fast_tx: TX fastpath information
406 407
 * @tdls_chandef: a TDLS peer can have a wider chandef that is compatible to
 *	the BSS one.
408
 */
409
struct sta_info {
410
	/* General information, mostly static */
411
	struct list_head list, free_list;
412
	struct rcu_head rcu_head;
413
	struct rhash_head hash_node;
414
	u8 addr[ETH_ALEN];
415
	struct ieee80211_local *local;
416
	struct ieee80211_sub_if_data *sdata;
J
Johannes Berg 已提交
417
	struct ieee80211_key __rcu *gtk[NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS];
418 419
	struct ieee80211_key __rcu *ptk[NUM_DEFAULT_KEYS];
	u8 ptk_idx;
420 421
	struct rate_control_ref *rate_ctrl;
	void *rate_ctrl_priv;
J
Johannes Berg 已提交
422
	spinlock_t rate_ctrl_lock;
423
	spinlock_t lock;
424

J
Johannes Berg 已提交
425 426
	struct ieee80211_fast_tx __rcu *fast_tx;

427 428 429 430
#ifdef CONFIG_MAC80211_MESH
	struct mesh_sta *mesh;
#endif

431
	struct work_struct drv_deliver_wk;
432

433
	u16 listen_interval;
434

435 436
	bool dead;

437
	bool uploaded;
438

439 440
	enum ieee80211_sta_state sta_state;

J
Johannes Berg 已提交
441 442
	/* use the accessors defined below */
	unsigned long _flags;
443

444 445
	/* STA powersave lock and frame queues */
	spinlock_t ps_lock;
446 447 448
	struct sk_buff_head ps_tx_buf[IEEE80211_NUM_ACS];
	struct sk_buff_head tx_filtered[IEEE80211_NUM_ACS];
	unsigned long driver_buffered_tids;
449
	unsigned long txq_buffered_tids;
450 451

	/* Updated from RX path only, no locking requirements */
452 453
	unsigned long rx_packets;
	u64 rx_bytes;
454
	unsigned long last_rx;
455
	long last_connected;
R
Randy Dunlap 已提交
456 457 458 459
	unsigned long num_duplicates;
	unsigned long rx_fragments;
	unsigned long rx_dropped;
	int last_signal;
460
	struct ewma avg_signal;
461
	int last_ack_signal;
462 463 464 465 466

	u8 chains;
	s8 chain_signal_last[IEEE80211_MAX_CHAINS];
	struct ewma chain_signal_avg[IEEE80211_MAX_CHAINS];

467
	/* Plus 1 for non-QoS frames */
468
	__le16 last_seq_ctrl[IEEE80211_NUM_TIDS + 1];
469 470 471 472 473 474 475 476

	/* Updated from TX status path only, no locking requirements */
	unsigned long tx_filtered_count;
	unsigned long tx_retry_failed, tx_retry_count;
	/* moving percentage of failed MSDUs */
	unsigned int fail_avg;

	/* Updated from TX path only, no locking requirements */
477 478
	u64 tx_packets[IEEE80211_NUM_ACS];
	u64 tx_bytes[IEEE80211_NUM_ACS];
479
	struct ieee80211_tx_rate last_tx_rate;
480
	int last_rx_rate_idx;
481
	u32 last_rx_rate_flag;
482
	u32 last_rx_rate_vht_flag;
483
	u8 last_rx_rate_vht_nss;
484
	u16 tid_seq[IEEE80211_QOS_CTL_TID_MASK + 1];
485 486 487 488
	u64 tx_msdu[IEEE80211_NUM_TIDS + 1];
	u64 tx_msdu_retries[IEEE80211_NUM_TIDS + 1];
	u64 tx_msdu_failed[IEEE80211_NUM_TIDS + 1];
	u64 rx_msdu[IEEE80211_NUM_TIDS + 1];
489

490
	/*
491
	 * Aggregation information, locked with lock.
492
	 */
493
	struct sta_ampdu_mlme ampdu_mlme;
494
	u8 timer_to_tid[IEEE80211_NUM_TIDS];
495

J
Jiri Benc 已提交
496 497 498
#ifdef CONFIG_MAC80211_DEBUGFS
	struct sta_info_debugfsdentries {
		struct dentry *dir;
J
Johannes Berg 已提交
499
		bool add_has_run;
J
Jiri Benc 已提交
500 501
	} debugfs;
#endif
502

503 504
	enum ieee80211_sta_rx_bandwidth cur_max_bandwidth;

505
	unsigned int lost_packets;
506
	unsigned int beacon_loss_count;
507

508
	enum ieee80211_smps_mode known_smps_mode;
509
	const struct ieee80211_cipher_scheme *cipher_scheme;
510

511 512 513
	/* TDLS timeout data */
	unsigned long last_tdls_pkt_time;

514 515
	u8 reserved_tid;

516 517
	struct cfg80211_chan_def tdls_chandef;

518 519
	/* keep last! */
	struct ieee80211_sta sta;
520 521
};

522
static inline enum nl80211_plink_state sta_plink_state(struct sta_info *sta)
523 524
{
#ifdef CONFIG_MAC80211_MESH
525
	return sta->mesh->plink_state;
526
#endif
527
	return NL80211_PLINK_LISTEN;
528 529
}

J
Johannes Berg 已提交
530 531
static inline void set_sta_flag(struct sta_info *sta,
				enum ieee80211_sta_info_flags flag)
532
{
533 534 535
	WARN_ON(flag == WLAN_STA_AUTH ||
		flag == WLAN_STA_ASSOC ||
		flag == WLAN_STA_AUTHORIZED);
J
Johannes Berg 已提交
536
	set_bit(flag, &sta->_flags);
537 538
}

J
Johannes Berg 已提交
539 540
static inline void clear_sta_flag(struct sta_info *sta,
				  enum ieee80211_sta_info_flags flag)
541
{
542 543 544
	WARN_ON(flag == WLAN_STA_AUTH ||
		flag == WLAN_STA_ASSOC ||
		flag == WLAN_STA_AUTHORIZED);
J
Johannes Berg 已提交
545
	clear_bit(flag, &sta->_flags);
546 547
}

J
Johannes Berg 已提交
548 549
static inline int test_sta_flag(struct sta_info *sta,
				enum ieee80211_sta_info_flags flag)
550
{
J
Johannes Berg 已提交
551
	return test_bit(flag, &sta->_flags);
552 553
}

J
Johannes Berg 已提交
554 555
static inline int test_and_clear_sta_flag(struct sta_info *sta,
					  enum ieee80211_sta_info_flags flag)
556
{
557 558 559
	WARN_ON(flag == WLAN_STA_AUTH ||
		flag == WLAN_STA_ASSOC ||
		flag == WLAN_STA_AUTHORIZED);
J
Johannes Berg 已提交
560
	return test_and_clear_bit(flag, &sta->_flags);
561 562
}

563 564 565
static inline int test_and_set_sta_flag(struct sta_info *sta,
					enum ieee80211_sta_info_flags flag)
{
566 567 568
	WARN_ON(flag == WLAN_STA_AUTH ||
		flag == WLAN_STA_ASSOC ||
		flag == WLAN_STA_AUTHORIZED);
569 570 571
	return test_and_set_bit(flag, &sta->_flags);
}

572 573
int sta_info_move_state(struct sta_info *sta,
			enum ieee80211_sta_state new_state);
574

575 576
static inline void sta_info_pre_move_state(struct sta_info *sta,
					   enum ieee80211_sta_state new_state)
577
{
578 579 580 581 582
	int ret;

	WARN_ON_ONCE(test_sta_flag(sta, WLAN_STA_INSERTED));

	ret = sta_info_move_state(sta, new_state);
583 584 585 586
	WARN_ON_ONCE(ret);
}


J
Johannes Berg 已提交
587 588
void ieee80211_assign_tid_tx(struct sta_info *sta, int tid,
			     struct tid_ampdu_tx *tid_tx);
589

J
Johannes Berg 已提交
590 591 592 593 594 595 596
static inline struct tid_ampdu_tx *
rcu_dereference_protected_tid_tx(struct sta_info *sta, int tid)
{
	return rcu_dereference_protected(sta->ampdu_mlme.tid_tx[tid],
					 lockdep_is_held(&sta->lock) ||
					 lockdep_is_held(&sta->ampdu_mlme.mtx));
}
597

598 599
/* Maximum number of frames to buffer per power saving station per AC */
#define STA_MAX_TX_BUFFER	64
600 601 602 603 604 605 606 607 608

/* Minimum buffered frame expiry time. If STA uses listen interval that is
 * smaller than this value, the minimum value here is used instead. */
#define STA_TX_BUFFER_EXPIRE (10 * HZ)

/* How often station data is cleaned up (e.g., expiration of buffered frames)
 */
#define STA_INFO_CLEANUP_INTERVAL (10 * HZ)

609
/*
610
 * Get a STA info, must be under RCU read lock.
611
 */
612 613 614
struct sta_info *sta_info_get(struct ieee80211_sub_if_data *sdata,
			      const u8 *addr);

615 616 617
struct sta_info *sta_info_get_bss(struct ieee80211_sub_if_data *sdata,
				  const u8 *addr);

618 619 620 621
u32 sta_addr_hash(const void *key, u32 length, u32 seed);

#define _sta_bucket_idx(_tbl, _a)					\
	rht_bucket_index(_tbl, sta_addr_hash(_a, ETH_ALEN, (_tbl)->hash_rnd))
622

623 624 625 626
#define for_each_sta_info(local, tbl, _addr, _sta, _tmp)		\
	rht_for_each_entry_rcu(_sta, _tmp, tbl, 			\
			       _sta_bucket_idx(tbl, _addr),		\
			       hash_node)				\
627
	/* compare address and run code only if it matches */		\
628
	if (ether_addr_equal(_sta->addr, (_addr)))
629

630 631 632
/*
 * Get STA info by index, BROKEN!
 */
633 634
struct sta_info *sta_info_get_by_idx(struct ieee80211_sub_if_data *sdata,
				     int idx);
635
/*
J
Johannes Berg 已提交
636 637
 * Create a new STA info, caller owns returned structure
 * until sta_info_insert().
638
 */
J
Johannes Berg 已提交
639
struct sta_info *sta_info_alloc(struct ieee80211_sub_if_data *sdata,
640
				const u8 *addr, gfp_t gfp);
641 642 643

void sta_info_free(struct ieee80211_local *local, struct sta_info *sta);

J
Johannes Berg 已提交
644 645 646 647
/*
 * Insert STA info into hash table/list, returns zero or a
 * -EEXIST if (if the same MAC address is already present).
 *
648 649 650
 * Calling the non-rcu version makes the caller relinquish,
 * the _rcu version calls read_lock_rcu() and must be called
 * without it held.
J
Johannes Berg 已提交
651 652
 */
int sta_info_insert(struct sta_info *sta);
653 654
int sta_info_insert_rcu(struct sta_info *sta) __acquires(RCU);

655
int __must_check __sta_info_destroy(struct sta_info *sta);
656 657 658 659
int sta_info_destroy_addr(struct ieee80211_sub_if_data *sdata,
			  const u8 *addr);
int sta_info_destroy_addr_bss(struct ieee80211_sub_if_data *sdata,
			      const u8 *addr);
660

J
Johannes Berg 已提交
661
void sta_info_recalc_tim(struct sta_info *sta);
662

663
int sta_info_init(struct ieee80211_local *local);
664
void sta_info_stop(struct ieee80211_local *local);
665 666 667 668 669 670 671

/**
 * sta_info_flush - flush matching STA entries from the STA table
 *
 * Returns the number of removed STA entries.
 *
 * @sdata: sdata to remove all stations from
672
 * @vlans: if the given interface is an AP interface, also flush VLANs
673
 */
674 675 676 677 678 679
int __sta_info_flush(struct ieee80211_sub_if_data *sdata, bool vlans);

static inline int sta_info_flush(struct ieee80211_sub_if_data *sdata)
{
	return __sta_info_flush(sdata, false);
}
680

681 682 683
void sta_set_rate_info_tx(struct sta_info *sta,
			  const struct ieee80211_tx_rate *rate,
			  struct rate_info *rinfo);
684 685
void sta_set_rate_info_rx(struct sta_info *sta,
			  struct rate_info *rinfo);
686 687
void sta_set_sinfo(struct sta_info *sta, struct station_info *sinfo);

688 689
void ieee80211_sta_expire(struct ieee80211_sub_if_data *sdata,
			  unsigned long exp_time);
690
u8 sta_info_tx_streams(struct sta_info *sta);
691

692 693
void ieee80211_sta_ps_deliver_wakeup(struct sta_info *sta);
void ieee80211_sta_ps_deliver_poll_response(struct sta_info *sta);
J
Johannes Berg 已提交
694
void ieee80211_sta_ps_deliver_uapsd(struct sta_info *sta);
695

696
#endif /* STA_INFO_H */