sta_info.h 25.1 KB
Newer Older
1 2
/*
 * Copyright 2002-2005, Devicescape Software, Inc.
3
 * Copyright 2013-2014  Intel Mobile Communications GmbH
4
 * Copyright(c) 2015-2016 Intel Deutschland GmbH
5 6 7 8 9 10 11 12 13 14 15 16
 *
 * 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>
17
#include <linux/workqueue.h>
18
#include <linux/average.h>
19
#include <linux/etherdevice.h>
20
#include <linux/rhashtable.h>
21
#include <linux/u64_stats_sync.h>
J
Johannes Berg 已提交
22
#include "key.h"
23

24 25 26
/**
 * enum ieee80211_sta_info_flags - Stations flags
 *
J
Johannes Berg 已提交
27 28
 * These flags are used with &struct sta_info's @flags member, but
 * only indirectly with set_sta_flag() and friends.
29 30 31
 *
 * @WLAN_STA_AUTH: Station is authenticated.
 * @WLAN_STA_ASSOC: Station is associated.
32
 * @WLAN_STA_PS_STA: Station is in power-save mode
33 34 35 36 37 38
 * @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.
39
 * @WLAN_STA_CLEAR_PS_FILT: Clear PS filter in hardware (using the
40
 *	IEEE80211_TX_CTL_CLEAR_PS_FILT control flag) when the next
41
 *	frame to this station is transmitted.
42
 * @WLAN_STA_MFP: Management frame protection is used with this STA.
43
 * @WLAN_STA_BLOCK_BA: Used to deny ADDBA requests (both TX and RX)
44
 *	during suspend/resume and station removal.
45 46 47 48 49
 * @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.
50 51 52
 * @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.
53 54
 * @WLAN_STA_TDLS_INITIATOR: We are the initiator of the TDLS link with this
 *	station.
55
 * @WLAN_STA_TDLS_CHAN_SWITCH: This TDLS peer supports TDLS channel-switching
56 57
 * @WLAN_STA_TDLS_OFF_CHANNEL: The local STA is currently off-channel with this
 *	TDLS peer
58 59
 * @WLAN_STA_TDLS_WIDER_BW: This TDLS peer supports working on a wider bw on
 *	the BSS base channel.
J
Johannes Berg 已提交
60 61 62 63
 * @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
64
 *	reply to other uAPSD trigger frames or PS-Poll.
65
 * @WLAN_STA_4ADDR_EVENT: 4-addr event was already sent for this frame.
66
 * @WLAN_STA_INSERTED: This station is inserted into the hash table.
67
 * @WLAN_STA_RATE_CONTROL: rate control was initialized for this station.
68
 * @WLAN_STA_TOFFSET_KNOWN: toffset calculated for this station is valid.
M
Marco Porsch 已提交
69 70
 * @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.
71 72
 * @WLAN_STA_PS_DELIVER: station woke up, but we're still blocking TX
 *	until pending frames are delivered
73 74
 *
 * @NUM_WLAN_STA_FLAGS: number of defined flags
75 76
 */
enum ieee80211_sta_info_flags {
J
Johannes Berg 已提交
77 78 79 80 81 82 83 84 85 86 87 88 89
	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,
90
	WLAN_STA_TDLS_INITIATOR,
91
	WLAN_STA_TDLS_CHAN_SWITCH,
92
	WLAN_STA_TDLS_OFF_CHANNEL,
93
	WLAN_STA_TDLS_WIDER_BW,
J
Johannes Berg 已提交
94 95
	WLAN_STA_UAPSD,
	WLAN_STA_SP,
96
	WLAN_STA_4ADDR_EVENT,
97
	WLAN_STA_INSERTED,
98
	WLAN_STA_RATE_CONTROL,
99
	WLAN_STA_TOFFSET_KNOWN,
M
Marco Porsch 已提交
100 101
	WLAN_STA_MPSP_OWNER,
	WLAN_STA_MPSP_RECIPIENT,
102
	WLAN_STA_PS_DELIVER,
103 104

	NUM_WLAN_STA_FLAGS,
105
};
106

107
#define ADDBA_RESP_INTERVAL HZ
108 109 110
#define HT_AGG_MAX_RETRIES		15
#define HT_AGG_BURST_RETRIES		3
#define HT_AGG_RETRIES_PERIOD		(15 * HZ)
111

112 113 114 115
#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
116 117
#define HT_AGG_STATE_WANT_START		4
#define HT_AGG_STATE_WANT_STOP		5
118

119 120 121 122 123 124 125
enum ieee80211_agg_stop_reason {
	AGG_STOP_DECLINED,
	AGG_STOP_LOCAL_REQUEST,
	AGG_STOP_PEER_REQUEST,
	AGG_STOP_DESTROY_STA,
};

126 127 128
/**
 * struct tid_ampdu_tx - TID aggregation information (Tx).
 *
129
 * @rcu_head: rcu head for freeing structure
130
 * @session_timer: check if we keep Tx-ing on the TID (by timeout value)
131
 * @addba_resp_timer: timer for peer's response to addba request
132
 * @pending: pending frames queue -- use sta's spinlock to protect
133
 * @dialog_token: dialog token for aggregation session
134
 * @timeout: session timeout value to be filled in ADDBA requests
135
 * @state: session state (see above)
136
 * @last_tx: jiffies of last tx activity
137
 * @stop_initiator: initiator of a session stop
138
 * @tx_stop: TX DelBA frame when stopping
139
 * @buf_size: reorder buffer size at receiver
140 141
 * @failed_bar_ssn: ssn of the last failed BAR tx attempt
 * @bar_pending: BAR needs to be re-sent
142
 * @amsdu: support A-MSDU withing A-MDPU
143
 *
144 145 146 147 148 149 150 151
 * 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.
152 153
 */
struct tid_ampdu_tx {
154
	struct rcu_head rcu_head;
155
	struct timer_list session_timer;
156
	struct timer_list addba_resp_timer;
157
	struct sk_buff_head pending;
158
	unsigned long state;
159
	unsigned long last_tx;
160
	u16 timeout;
161
	u8 dialog_token;
162
	u8 stop_initiator;
163
	bool tx_stop;
164
	u8 buf_size;
165 166 167

	u16 failed_bar_ssn;
	bool bar_pending;
168
	bool amsdu;
169
};
170 171 172 173

/**
 * struct tid_ampdu_rx - TID aggregation information (Rx).
 *
174 175
 * @reorder_buf: buffer to reorder incoming aggregated MPDUs. An MPDU may be an
 *	A-MSDU with individually reported subframes.
176 177
 * @reorder_buf_filtered: bitmap indicating where there are filtered frames in
 *	the reorder buffer that should be ignored when releasing frames
178
 * @reorder_time: jiffies when skb was added
179
 * @session_timer: check if peer keeps Tx-ing on the TID (by timeout value)
180
 * @reorder_timer: releases expired frames from the reorder buffer.
181
 * @last_rx: jiffies of last rx activity
182 183
 * @head_seq_num: head sequence number in reordering buffer.
 * @stored_mpdu_num: number of MPDUs in reordering buffer
184 185
 * @ssn: Starting Sequence Number expected to be aggregated.
 * @buf_size: buffer size for incoming A-MPDUs
186
 * @timeout: reset timer value (in TUs).
187
 * @rcu_head: RCU head used for freeing this struct
188
 * @reorder_lock: serializes access to reorder buffer, see below.
189 190
 * @auto_seq: used for offloaded BA sessions to automatically pick head_seq_and
 *	and ssn.
191
 * @removed: this session is removed (but might have been found due to RCU)
192
 * @started: this session has started (head ssn or higher was received)
193
 *
194 195
 * This structure's lifetime is managed by RCU, assignments to
 * the array holding it must hold the aggregation mutex.
196
 *
197 198 199 200
 * 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).
201 202
 */
struct tid_ampdu_rx {
203
	struct rcu_head rcu_head;
204
	spinlock_t reorder_lock;
205
	u64 reorder_buf_filtered;
206
	struct sk_buff_head *reorder_buf;
207
	unsigned long *reorder_time;
208
	struct timer_list session_timer;
209
	struct timer_list reorder_timer;
210
	unsigned long last_rx;
211 212
	u16 head_seq_num;
	u16 stored_mpdu_num;
213 214 215
	u16 ssn;
	u16 buf_size;
	u16 timeout;
216 217 218
	u8 auto_seq:1,
	   removed:1,
	   started:1;
219 220
};

J
Johannes Berg 已提交
221 222 223
/**
 * struct sta_ampdu_mlme - STA aggregation information.
 *
224 225 226
 * @mtx: mutex to protect all TX data (except non-NULL assignments
 *	to tid_tx[idx], which are protected by the sta spinlock)
 *	tid_start_tx is also protected by sta->lock.
227
 * @tid_rx: aggregation info for Rx per TID -- RCU protected
228
 * @tid_rx_token: dialog tokens for valid aggregation sessions
229 230
 * @tid_rx_timer_expired: bitmap indicating on which TIDs the
 *	RX timer expired until the work for it runs
231 232
 * @tid_rx_stop_requested:  bitmap indicating which BA sessions per TID the
 *	driver requested to close until the work for it runs
233
 * @agg_session_valid: bitmap indicating which TID has a rx BA session open on
234 235
 * @unexpected_agg: bitmap indicating which TID already sent a delBA due to
 *	unexpected aggregation related frames outside a session
236 237 238 239 240 241
 * @work: work struct for starting/stopping aggregation
 * @tid_tx: aggregation info for Tx per TID
 * @tid_start_tx: sessions where start was requested
 * @last_addba_req_time: timestamp of the last addBA request.
 * @addba_req_num: number of times addBA request has been sent.
 * @dialog_token_allocator: dialog token enumerator for each new session;
J
Johannes Berg 已提交
242 243
 */
struct sta_ampdu_mlme {
244
	struct mutex mtx;
J
Johannes Berg 已提交
245
	/* rx */
246
	struct tid_ampdu_rx __rcu *tid_rx[IEEE80211_NUM_TIDS];
247
	u8 tid_rx_token[IEEE80211_NUM_TIDS];
248 249
	unsigned long tid_rx_timer_expired[BITS_TO_LONGS(IEEE80211_NUM_TIDS)];
	unsigned long tid_rx_stop_requested[BITS_TO_LONGS(IEEE80211_NUM_TIDS)];
250
	unsigned long agg_session_valid[BITS_TO_LONGS(IEEE80211_NUM_TIDS)];
251
	unsigned long unexpected_agg[BITS_TO_LONGS(IEEE80211_NUM_TIDS)];
J
Johannes Berg 已提交
252
	/* tx */
253
	struct work_struct work;
254 255 256 257
	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 已提交
258 259 260 261
	u8 dialog_token_allocator;
};


262 263 264
/* Value to indicate no TID reservation */
#define IEEE80211_TID_UNRESERVED	0xff

265 266
#define IEEE80211_FAST_XMIT_MAX_IV	18

J
Johannes Berg 已提交
267 268 269 270 271 272 273 274 275 276 277
/**
 * 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
 *
278 279 280
 * 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 已提交
281 282 283 284 285 286
 */
struct ieee80211_fast_tx {
	struct ieee80211_key *key;
	u8 hdr_len;
	u8 sa_offs, da_offs, pn_offs;
	u8 band;
287
	u8 hdr[30 + 2 + IEEE80211_FAST_XMIT_MAX_IV +
288
	       sizeof(rfc1042_header)] __aligned(2);
J
Johannes Berg 已提交
289 290 291 292

	struct rcu_head rcu_head;
};

J
Johannes Berg 已提交
293 294 295 296 297 298 299 300 301 302 303 304
/**
 * struct ieee80211_fast_rx - RX fastpath information
 * @dev: netdevice for reporting the SKB
 * @vif_type: (P2P-less) interface type of the original sdata (sdata->vif.type)
 * @vif_addr: interface address
 * @rfc1042_hdr: copy of the RFC 1042 SNAP header (to have in cache)
 * @control_port_protocol: control port protocol copied from sdata
 * @expected_ds_bits: from/to DS bits expected
 * @icv_len: length of the MIC if present
 * @key: bool indicating encryption is expected (key is set)
 * @sta_notify: notify the MLME code (once)
 * @internal_forward: forward froms internally on AP/VLAN type interfaces
305
 * @uses_rss: copy of USES_RSS hw flag
J
Johannes Berg 已提交
306 307 308 309 310 311 312 313 314 315 316 317 318 319
 * @da_offs: offset of the DA in the header (for header conversion)
 * @sa_offs: offset of the SA in the header (for header conversion)
 * @rcu_head: RCU head for freeing this structure
 */
struct ieee80211_fast_rx {
	struct net_device *dev;
	enum nl80211_iftype vif_type;
	u8 vif_addr[ETH_ALEN] __aligned(2);
	u8 rfc1042_hdr[6] __aligned(2);
	__be16 control_port_protocol;
	__le16 expected_ds_bits;
	u8 icv_len;
	u8 key:1,
	   sta_notify:1,
320 321
	   internal_forward:1,
	   uses_rss:1;
J
Johannes Berg 已提交
322 323 324 325 326
	u8 da_offs, sa_offs;

	struct rcu_head rcu_head;
};

327 328 329
/* we use only values in the range 0-100, so pick a large precision */
DECLARE_EWMA(mesh_fail_avg, 20, 8)

330 331 332 333 334
/**
 * struct mesh_sta - mesh STA information
 * @plink_lock: serialize access to plink fields
 * @llid: Local link ID
 * @plid: Peer link ID
335
 * @aid: local aid supplied by peer
336 337 338 339 340 341 342 343 344 345 346 347 348
 * @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
349
 * @fail_avg: moving percentage of failed MSDUs
350 351 352 353 354 355 356 357 358 359
 */
struct mesh_sta {
	struct timer_list plink_timer;

	s64 t_offset;
	s64 t_offset_setpoint;

	spinlock_t plink_lock;
	u16 llid;
	u16 plid;
360
	u16 aid;
361 362 363 364 365 366 367 368 369 370 371 372
	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;
373 374

	/* moving percentage of failed MSDUs */
375
	struct ewma_mesh_fail_avg fail_avg;
376 377
};

378
DECLARE_EWMA(signal, 10, 8)
J
Johannes Berg 已提交
379

380 381 382 383 384 385 386 387 388 389 390 391 392 393 394
struct ieee80211_sta_rx_stats {
	unsigned long packets;
	unsigned long last_rx;
	unsigned long num_duplicates;
	unsigned long fragments;
	unsigned long dropped;
	int last_signal;
	u8 chains;
	s8 chain_signal_last[IEEE80211_MAX_CHAINS];
	u16 last_rate;
	struct u64_stats_sync syncp;
	u64 bytes;
	u64 msdu[IEEE80211_NUM_TIDS + 1];
};

395 396 397 398 399 400 401
/**
 * struct sta_info - STA information
 *
 * This structure collects information about a station that
 * mac80211 is communicating with.
 *
 * @list: global linked list entry
402
 * @free_list: list entry for keeping track of stations to free
403
 * @hash_node: hash node for rhashtable
404 405
 * @addr: station's MAC address - duplicated from public part to
 *	let the hash table work with just a single cacheline
406
 * @local: pointer to the global information
407
 * @sdata: virtual interface this station belongs to
408 409
 * @ptk: peer keys negotiated with this station, if any
 * @ptk_idx: last installed peer key index
410
 * @gtk: group keys negotiated with this station, if any
411
 * @rate_ctrl: rate control algorithm reference
412 413
 * @rate_ctrl_lock: spinlock used to protect rate control data
 *	(data inside the algorithm, so serializes calls there)
414
 * @rate_ctrl_priv: rate control private per-STA pointer
R
Randy Dunlap 已提交
415 416
 * @lock: used for locking all fields that require locking, see comments
 *	in the header file.
417
 * @drv_deliver_wk: used for delivering frames after driver PS unblocking
418
 * @listen_interval: listen interval of this station, when we're acting as AP
J
Johannes Berg 已提交
419
 * @_flags: STA flags, see &enum ieee80211_sta_info_flags, do not use directly
420
 * @ps_lock: used for powersave (when mac80211 is the AP) related locking
421 422 423 424 425 426 427
 * @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
428
 * @txq_buffered_tids: bitmap of TIDs that mac80211 has txq data buffered on
429
 * @last_connected: time (in seconds) when a station got connected
430 431
 * @last_seq_ctrl: last received seq/frag number from this STA (per TID
 *	plus one for non-QoS frames)
432 433
 * @tid_seq: per-TID sequence numbers for sending to this STA
 * @ampdu_mlme: A-MPDU state machine state
R
Randy Dunlap 已提交
434
 * @timer_to_tid: identity mapping to ID timers
435
 * @mesh: mesh STA information
436
 * @debugfs_dir: debug filesystem directory dentry
437
 * @dead: set to true when sta is unlinked
438
 * @removed: set to true when sta is being removed from sta_list
439
 * @uploaded: set to true when sta is uploaded to the driver
440
 * @sta: station information we share with the driver
441
 * @sta_state: duplicates information about station state (for debug)
J
Johannes Berg 已提交
442
 * @rcu_head: RCU head used for freeing this station struct
443 444
 * @cur_max_bandwidth: maximum bandwidth to use for TX to the station,
 *	taken from HT/VHT capabilities or VHT operating mode notification
445 446
 * @known_smps_mode: the smps_mode the client thinks we are in. Relevant for
 *	AP only.
447
 * @cipher_scheme: optional cipher scheme for this station
448
 * @reserved_tid: reserved TID (if any, otherwise IEEE80211_TID_UNRESERVED)
J
Johannes Berg 已提交
449
 * @fast_tx: TX fastpath information
J
Johannes Berg 已提交
450
 * @fast_rx: RX fastpath information
451 452
 * @tdls_chandef: a TDLS peer can have a wider chandef that is compatible to
 *	the BSS one.
453 454
 * @tx_stats: TX statistics
 * @rx_stats: RX statistics
455 456
 * @pcpu_rx_stats: per-CPU RX statistics, assigned only if the driver needs
 *	this (by advertising the USES_RSS hw flag)
457
 * @status_stats: TX status statistics
458
 */
459
struct sta_info {
460
	/* General information, mostly static */
461
	struct list_head list, free_list;
462
	struct rcu_head rcu_head;
463
	struct rhlist_head hash_node;
464
	u8 addr[ETH_ALEN];
465
	struct ieee80211_local *local;
466
	struct ieee80211_sub_if_data *sdata;
J
Johannes Berg 已提交
467
	struct ieee80211_key __rcu *gtk[NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS];
468 469
	struct ieee80211_key __rcu *ptk[NUM_DEFAULT_KEYS];
	u8 ptk_idx;
470 471
	struct rate_control_ref *rate_ctrl;
	void *rate_ctrl_priv;
J
Johannes Berg 已提交
472
	spinlock_t rate_ctrl_lock;
473
	spinlock_t lock;
474

J
Johannes Berg 已提交
475
	struct ieee80211_fast_tx __rcu *fast_tx;
J
Johannes Berg 已提交
476
	struct ieee80211_fast_rx __rcu *fast_rx;
477
	struct ieee80211_sta_rx_stats __percpu *pcpu_rx_stats;
J
Johannes Berg 已提交
478

479 480 481 482
#ifdef CONFIG_MAC80211_MESH
	struct mesh_sta *mesh;
#endif

483
	struct work_struct drv_deliver_wk;
484

485
	u16 listen_interval;
486

487
	bool dead;
488
	bool removed;
489

490
	bool uploaded;
491

492 493
	enum ieee80211_sta_state sta_state;

J
Johannes Berg 已提交
494 495
	/* use the accessors defined below */
	unsigned long _flags;
496

497 498
	/* STA powersave lock and frame queues */
	spinlock_t ps_lock;
499 500 501
	struct sk_buff_head ps_tx_buf[IEEE80211_NUM_ACS];
	struct sk_buff_head tx_filtered[IEEE80211_NUM_ACS];
	unsigned long driver_buffered_tids;
502
	unsigned long txq_buffered_tids;
503

504
	long last_connected;
505

506
	/* Updated from RX path only, no locking requirements */
507
	struct ieee80211_sta_rx_stats rx_stats;
508 509 510 511
	struct {
		struct ewma_signal signal;
		struct ewma_signal chain_signal[IEEE80211_MAX_CHAINS];
	} rx_stats_avg;
512

513
	/* Plus 1 for non-QoS frames */
514
	__le16 last_seq_ctrl[IEEE80211_NUM_TIDS + 1];
515 516

	/* Updated from TX status path only, no locking requirements */
517 518 519 520 521 522 523
	struct {
		unsigned long filtered;
		unsigned long retry_failed, retry_count;
		unsigned int lost_packets;
		unsigned long last_tdls_pkt_time;
		u64 msdu_retries[IEEE80211_NUM_TIDS + 1];
		u64 msdu_failed[IEEE80211_NUM_TIDS + 1];
524
		unsigned long last_ack;
525
	} status_stats;
526 527

	/* Updated from TX path only, no locking requirements */
528 529 530 531 532 533
	struct {
		u64 packets[IEEE80211_NUM_ACS];
		u64 bytes[IEEE80211_NUM_ACS];
		struct ieee80211_tx_rate last_rate;
		u64 msdu[IEEE80211_NUM_TIDS + 1];
	} tx_stats;
534
	u16 tid_seq[IEEE80211_QOS_CTL_TID_MASK + 1];
535

536
	/*
537
	 * Aggregation information, locked with lock.
538
	 */
539
	struct sta_ampdu_mlme ampdu_mlme;
540
	u8 timer_to_tid[IEEE80211_NUM_TIDS];
541

J
Jiri Benc 已提交
542
#ifdef CONFIG_MAC80211_DEBUGFS
543
	struct dentry *debugfs_dir;
J
Jiri Benc 已提交
544
#endif
545

546 547
	enum ieee80211_sta_rx_bandwidth cur_max_bandwidth;

548
	enum ieee80211_smps_mode known_smps_mode;
549
	const struct ieee80211_cipher_scheme *cipher_scheme;
550

551 552
	u8 reserved_tid;

553 554
	struct cfg80211_chan_def tdls_chandef;

555 556
	/* keep last! */
	struct ieee80211_sta sta;
557 558
};

559
static inline enum nl80211_plink_state sta_plink_state(struct sta_info *sta)
560 561
{
#ifdef CONFIG_MAC80211_MESH
562
	return sta->mesh->plink_state;
563
#endif
564
	return NL80211_PLINK_LISTEN;
565 566
}

J
Johannes Berg 已提交
567 568
static inline void set_sta_flag(struct sta_info *sta,
				enum ieee80211_sta_info_flags flag)
569
{
570 571 572
	WARN_ON(flag == WLAN_STA_AUTH ||
		flag == WLAN_STA_ASSOC ||
		flag == WLAN_STA_AUTHORIZED);
J
Johannes Berg 已提交
573
	set_bit(flag, &sta->_flags);
574 575
}

J
Johannes Berg 已提交
576 577
static inline void clear_sta_flag(struct sta_info *sta,
				  enum ieee80211_sta_info_flags flag)
578
{
579 580 581
	WARN_ON(flag == WLAN_STA_AUTH ||
		flag == WLAN_STA_ASSOC ||
		flag == WLAN_STA_AUTHORIZED);
J
Johannes Berg 已提交
582
	clear_bit(flag, &sta->_flags);
583 584
}

J
Johannes Berg 已提交
585 586
static inline int test_sta_flag(struct sta_info *sta,
				enum ieee80211_sta_info_flags flag)
587
{
J
Johannes Berg 已提交
588
	return test_bit(flag, &sta->_flags);
589 590
}

J
Johannes Berg 已提交
591 592
static inline int test_and_clear_sta_flag(struct sta_info *sta,
					  enum ieee80211_sta_info_flags flag)
593
{
594 595 596
	WARN_ON(flag == WLAN_STA_AUTH ||
		flag == WLAN_STA_ASSOC ||
		flag == WLAN_STA_AUTHORIZED);
J
Johannes Berg 已提交
597
	return test_and_clear_bit(flag, &sta->_flags);
598 599
}

600 601 602
static inline int test_and_set_sta_flag(struct sta_info *sta,
					enum ieee80211_sta_info_flags flag)
{
603 604 605
	WARN_ON(flag == WLAN_STA_AUTH ||
		flag == WLAN_STA_ASSOC ||
		flag == WLAN_STA_AUTHORIZED);
606 607 608
	return test_and_set_bit(flag, &sta->_flags);
}

609 610
int sta_info_move_state(struct sta_info *sta,
			enum ieee80211_sta_state new_state);
611

612 613
static inline void sta_info_pre_move_state(struct sta_info *sta,
					   enum ieee80211_sta_state new_state)
614
{
615 616 617 618 619
	int ret;

	WARN_ON_ONCE(test_sta_flag(sta, WLAN_STA_INSERTED));

	ret = sta_info_move_state(sta, new_state);
620 621 622 623
	WARN_ON_ONCE(ret);
}


J
Johannes Berg 已提交
624 625
void ieee80211_assign_tid_tx(struct sta_info *sta, int tid,
			     struct tid_ampdu_tx *tid_tx);
626

J
Johannes Berg 已提交
627 628 629 630 631 632 633
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));
}
634

635 636
/* Maximum number of frames to buffer per power saving station per AC */
#define STA_MAX_TX_BUFFER	64
637 638 639 640 641 642 643 644 645

/* 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)

646 647 648
struct rhlist_head *sta_info_hash_lookup(struct ieee80211_local *local,
					 const u8 *addr);

649
/*
650
 * Get a STA info, must be under RCU read lock.
651
 */
652 653 654
struct sta_info *sta_info_get(struct ieee80211_sub_if_data *sdata,
			      const u8 *addr);

655 656 657
struct sta_info *sta_info_get_bss(struct ieee80211_sub_if_data *sdata,
				  const u8 *addr);

658 659 660
#define for_each_sta_info(local, _addr, _sta, _tmp)			\
	rhl_for_each_entry_rcu(_sta, _tmp,				\
			       sta_info_hash_lookup(local, _addr), hash_node)
661

662 663 664
/*
 * Get STA info by index, BROKEN!
 */
665 666
struct sta_info *sta_info_get_by_idx(struct ieee80211_sub_if_data *sdata,
				     int idx);
667
/*
J
Johannes Berg 已提交
668 669
 * Create a new STA info, caller owns returned structure
 * until sta_info_insert().
670
 */
J
Johannes Berg 已提交
671
struct sta_info *sta_info_alloc(struct ieee80211_sub_if_data *sdata,
672
				const u8 *addr, gfp_t gfp);
673 674 675

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

J
Johannes Berg 已提交
676 677 678 679
/*
 * Insert STA info into hash table/list, returns zero or a
 * -EEXIST if (if the same MAC address is already present).
 *
680 681 682
 * 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 已提交
683 684
 */
int sta_info_insert(struct sta_info *sta);
685 686
int sta_info_insert_rcu(struct sta_info *sta) __acquires(RCU);

687
int __must_check __sta_info_destroy(struct sta_info *sta);
688 689 690 691
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);
692

J
Johannes Berg 已提交
693
void sta_info_recalc_tim(struct sta_info *sta);
694

695
int sta_info_init(struct ieee80211_local *local);
696
void sta_info_stop(struct ieee80211_local *local);
697 698 699 700 701 702 703

/**
 * 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
704
 * @vlans: if the given interface is an AP interface, also flush VLANs
705
 */
706 707 708 709 710 711
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);
}
712

713 714 715
void sta_set_rate_info_tx(struct sta_info *sta,
			  const struct ieee80211_tx_rate *rate,
			  struct rate_info *rinfo);
716 717
void sta_set_sinfo(struct sta_info *sta, struct station_info *sinfo);

718 719
u32 sta_get_expected_throughput(struct sta_info *sta);

720 721
void ieee80211_sta_expire(struct ieee80211_sub_if_data *sdata,
			  unsigned long exp_time);
722
u8 sta_info_tx_streams(struct sta_info *sta);
723

724 725
void ieee80211_sta_ps_deliver_wakeup(struct sta_info *sta);
void ieee80211_sta_ps_deliver_poll_response(struct sta_info *sta);
J
Johannes Berg 已提交
726
void ieee80211_sta_ps_deliver_uapsd(struct sta_info *sta);
727

728 729
unsigned long ieee80211_sta_last_active(struct sta_info *sta);

730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767
#define STA_STATS_RATE_INVALID		0
#define STA_STATS_RATE_VHT		0x8000
#define STA_STATS_RATE_HT		0x4000
#define STA_STATS_RATE_LEGACY		0x2000
#define STA_STATS_RATE_SGI		0x1000
#define STA_STATS_RATE_BW_SHIFT		9
#define STA_STATS_RATE_BW_MASK		(0x7 << STA_STATS_RATE_BW_SHIFT)

static inline u16 sta_stats_encode_rate(struct ieee80211_rx_status *s)
{
	u16 r = s->rate_idx;

	if (s->vht_flag & RX_VHT_FLAG_80MHZ)
		r |= RATE_INFO_BW_80 << STA_STATS_RATE_BW_SHIFT;
	else if (s->vht_flag & RX_VHT_FLAG_160MHZ)
		r |= RATE_INFO_BW_160 << STA_STATS_RATE_BW_SHIFT;
	else if (s->flag & RX_FLAG_40MHZ)
		r |= RATE_INFO_BW_40 << STA_STATS_RATE_BW_SHIFT;
	else if (s->flag & RX_FLAG_10MHZ)
		r |= RATE_INFO_BW_10 << STA_STATS_RATE_BW_SHIFT;
	else if (s->flag & RX_FLAG_5MHZ)
		r |= RATE_INFO_BW_5 << STA_STATS_RATE_BW_SHIFT;
	else
		r |= RATE_INFO_BW_20 << STA_STATS_RATE_BW_SHIFT;

	if (s->flag & RX_FLAG_SHORT_GI)
		r |= STA_STATS_RATE_SGI;

	if (s->flag & RX_FLAG_VHT)
		r |= STA_STATS_RATE_VHT | (s->vht_nss << 4);
	else if (s->flag & RX_FLAG_HT)
		r |= STA_STATS_RATE_HT;
	else
		r |= STA_STATS_RATE_LEGACY | (s->band << 4);

	return r;
}

768
#endif /* STA_INFO_H */