2 * Copyright 2002-2005, Instant802 Networks, Inc.
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation.
9 #include <linux/module.h>
10 #include <linux/init.h>
11 #include <linux/kobject.h>
12 #include <linux/netdevice.h>
13 #include <linux/types.h>
14 #include <linux/slab.h>
15 #include <linux/skbuff.h>
16 #include <linux/if_arp.h>
18 #include <net/d80211.h>
19 #include "ieee80211_i.h"
20 #include "ieee80211_rate.h"
24 /* Caller must hold local->sta_lock */
25 static void sta_info_hash_add(struct ieee80211_local
*local
,
28 sta
->hnext
= local
->sta_hash
[STA_HASH(sta
->addr
)];
29 local
->sta_hash
[STA_HASH(sta
->addr
)] = sta
;
33 /* Caller must hold local->sta_lock */
34 static void sta_info_hash_del(struct ieee80211_local
*local
,
39 s
= local
->sta_hash
[STA_HASH(sta
->addr
)];
42 if (memcmp(s
->addr
, sta
->addr
, ETH_ALEN
) == 0) {
43 local
->sta_hash
[STA_HASH(sta
->addr
)] = s
->hnext
;
47 while (s
->hnext
&& memcmp(s
->hnext
->addr
, sta
->addr
, ETH_ALEN
) != 0)
50 s
->hnext
= s
->hnext
->hnext
;
52 printk(KERN_ERR
"%s: could not remove STA " MAC_FMT
" from "
53 "hash table\n", local
->mdev
->name
, MAC_ARG(sta
->addr
));
56 static inline struct sta_info
*__sta_info_get(struct sta_info
*sta
)
58 return kobject_get(&sta
->kobj
) ? sta
: NULL
;
61 struct sta_info
* sta_info_get(struct ieee80211_local
*local
, u8
*addr
)
65 spin_lock_bh(&local
->sta_lock
);
66 sta
= local
->sta_hash
[STA_HASH(addr
)];
68 if (memcmp(sta
->addr
, addr
, ETH_ALEN
) == 0) {
74 spin_unlock_bh(&local
->sta_lock
);
78 EXPORT_SYMBOL(sta_info_get
);
80 int sta_info_min_txrate_get(struct ieee80211_local
*local
)
83 int min_txrate
= 9999999;
86 spin_lock_bh(&local
->sta_lock
);
87 for (i
= 0; i
< STA_HASH_SIZE
; i
++) {
88 sta
= local
->sta_hash
[i
];
90 if (sta
->txrate
< min_txrate
)
91 min_txrate
= sta
->txrate
;
95 spin_unlock_bh(&local
->sta_lock
);
96 if (min_txrate
== 9999999)
103 void sta_info_put(struct sta_info
*sta
)
105 kobject_put(&sta
->kobj
);
107 EXPORT_SYMBOL(sta_info_put
);
109 void sta_info_release(struct kobject
*kobj
)
111 struct sta_info
*sta
= container_of(kobj
, struct sta_info
, kobj
);
112 struct ieee80211_local
*local
= sta
->local
;
115 /* free sta structure; it has already been removed from
116 * hash table etc. external structures. Make sure that all
117 * buffered frames are release (one might have been added
118 * after sta_info_free() was called). */
119 while ((skb
= skb_dequeue(&sta
->ps_tx_buf
)) != NULL
) {
120 local
->total_ps_buffered
--;
121 dev_kfree_skb_any(skb
);
123 while ((skb
= skb_dequeue(&sta
->tx_filtered
)) != NULL
) {
124 dev_kfree_skb_any(skb
);
126 rate_control_free_sta(sta
->rate_ctrl
, sta
->rate_ctrl_priv
);
127 rate_control_put(sta
->rate_ctrl
);
132 struct sta_info
* sta_info_add(struct ieee80211_local
*local
,
133 struct net_device
*dev
, u8
*addr
, gfp_t gfp
)
135 struct sta_info
*sta
;
137 sta
= kzalloc(sizeof(*sta
), gfp
);
141 if (kobject_set_name(&sta
->kobj
, MAC_FMT
, MAC_ARG(addr
))) {
145 sta
->kobj
.kset
= &local
->sta_kset
;
146 kobject_init(&sta
->kobj
);
148 sta
->rate_ctrl
= rate_control_get(local
->rate_ctrl
);
149 sta
->rate_ctrl_priv
= rate_control_alloc_sta(sta
->rate_ctrl
, gfp
);
150 if (!sta
->rate_ctrl_priv
) {
151 rate_control_put(sta
->rate_ctrl
);
152 kobject_put(&sta
->kobj
);
157 memcpy(sta
->addr
, addr
, ETH_ALEN
);
160 skb_queue_head_init(&sta
->ps_tx_buf
);
161 skb_queue_head_init(&sta
->tx_filtered
);
162 __sta_info_get(sta
); /* sta used by caller, decremented by
164 spin_lock_bh(&local
->sta_lock
);
165 list_add(&sta
->list
, &local
->sta_list
);
167 sta_info_hash_add(local
, sta
);
168 spin_unlock_bh(&local
->sta_lock
);
169 if (local
->ops
->sta_table_notification
)
170 local
->ops
->sta_table_notification(local_to_hw(local
),
172 sta
->key_idx_compression
= HW_KEY_IDX_INVALID
;
174 #ifdef CONFIG_D80211_VERBOSE_DEBUG
175 printk(KERN_DEBUG
"%s: Added STA " MAC_FMT
"\n",
176 local
->mdev
->name
, MAC_ARG(addr
));
177 #endif /* CONFIG_D80211_VERBOSE_DEBUG */
179 if (!in_interrupt()) {
180 sta
->sysfs_registered
= 1;
181 ieee80211_sta_sysfs_add(sta
);
182 rate_control_add_sta_attrs(sta
, &sta
->kobj
);
184 /* procfs entry adding might sleep, so schedule process context
185 * task for adding proc entry for STAs that do not yet have
187 schedule_work(&local
->sta_proc_add
);
193 static void finish_sta_info_free(struct ieee80211_local
*local
,
194 struct sta_info
*sta
)
196 #ifdef CONFIG_D80211_VERBOSE_DEBUG
197 printk(KERN_DEBUG
"%s: Removed STA " MAC_FMT
"\n",
198 local
->mdev
->name
, MAC_ARG(sta
->addr
));
199 #endif /* CONFIG_D80211_VERBOSE_DEBUG */
202 ieee80211_key_sysfs_remove(sta
->key
);
203 ieee80211_key_free(sta
->key
);
207 rate_control_remove_sta_attrs(sta
, &sta
->kobj
);
208 ieee80211_sta_sysfs_remove(sta
);
213 void sta_info_free(struct sta_info
*sta
, int locked
)
216 struct ieee80211_local
*local
= sta
->local
;
217 struct ieee80211_sub_if_data
*sdata
;
220 spin_lock_bh(&local
->sta_lock
);
221 sta_info_hash_del(local
, sta
);
222 list_del(&sta
->list
);
223 sdata
= IEEE80211_DEV_TO_SUB_IF(sta
->dev
);
224 if (sta
->flags
& WLAN_STA_PS
) {
225 sta
->flags
&= ~WLAN_STA_PS
;
227 atomic_dec(&sdata
->bss
->num_sta_ps
);
230 sta_info_remove_aid_ptr(sta
);
232 spin_unlock_bh(&local
->sta_lock
);
233 if (local
->ops
->sta_table_notification
)
234 local
->ops
->sta_table_notification(local_to_hw(local
),
237 while ((skb
= skb_dequeue(&sta
->ps_tx_buf
)) != NULL
) {
238 local
->total_ps_buffered
--;
239 dev_kfree_skb_any(skb
);
241 while ((skb
= skb_dequeue(&sta
->tx_filtered
)) != NULL
) {
242 dev_kfree_skb_any(skb
);
246 if (local
->ops
->set_key
) {
247 struct ieee80211_key_conf
*key
;
248 key
= ieee80211_key_data2conf(local
, sta
->key
);
250 local
->ops
->set_key(local_to_hw(local
),
252 sta
->addr
, key
, sta
->aid
);
256 } else if (sta
->key_idx_compression
!= HW_KEY_IDX_INVALID
) {
257 struct ieee80211_key_conf conf
;
258 memset(&conf
, 0, sizeof(conf
));
259 conf
.hw_key_idx
= sta
->key_idx_compression
;
261 conf
.flags
|= IEEE80211_KEY_FORCE_SW_ENCRYPT
;
262 local
->ops
->set_key(local_to_hw(local
), DISABLE_KEY
,
263 sta
->addr
, &conf
, sta
->aid
);
264 sta
->key_idx_compression
= HW_KEY_IDX_INVALID
;
268 list_add(&sta
->list
, &local
->deleted_sta_list
);
269 schedule_work(&local
->sta_proc_add
);
271 finish_sta_info_free(local
, sta
);
275 static inline int sta_info_buffer_expired(struct ieee80211_local
*local
,
276 struct sta_info
*sta
,
279 struct ieee80211_tx_packet_data
*pkt_data
;
285 pkt_data
= (struct ieee80211_tx_packet_data
*) skb
->cb
;
287 /* Timeout: (2 * listen_interval * beacon_int * 1024 / 1000000) sec */
288 timeout
= (sta
->listen_interval
* local
->hw
.conf
.beacon_int
* 32 /
290 if (timeout
< STA_TX_BUFFER_EXPIRE
)
291 timeout
= STA_TX_BUFFER_EXPIRE
;
292 return time_after(jiffies
, pkt_data
->jiffies
+ timeout
);
296 static void sta_info_cleanup_expire_buffered(struct ieee80211_local
*local
,
297 struct sta_info
*sta
)
302 if (skb_queue_empty(&sta
->ps_tx_buf
))
306 spin_lock_irqsave(&sta
->ps_tx_buf
.lock
, flags
);
307 skb
= skb_peek(&sta
->ps_tx_buf
);
308 if (sta_info_buffer_expired(local
, sta
, skb
)) {
309 skb
= __skb_dequeue(&sta
->ps_tx_buf
);
310 if (skb_queue_empty(&sta
->ps_tx_buf
))
311 sta
->flags
&= ~WLAN_STA_TIM
;
314 spin_unlock_irqrestore(&sta
->ps_tx_buf
.lock
, flags
);
317 local
->total_ps_buffered
--;
318 printk(KERN_DEBUG
"Buffered frame expired (STA "
319 MAC_FMT
")\n", MAC_ARG(sta
->addr
));
327 static void sta_info_cleanup(unsigned long data
)
329 struct ieee80211_local
*local
= (struct ieee80211_local
*) data
;
330 struct sta_info
*sta
;
332 spin_lock_bh(&local
->sta_lock
);
333 list_for_each_entry(sta
, &local
->sta_list
, list
) {
335 sta_info_cleanup_expire_buffered(local
, sta
);
338 spin_unlock_bh(&local
->sta_lock
);
340 local
->sta_cleanup
.expires
= jiffies
+ STA_INFO_CLEANUP_INTERVAL
;
341 add_timer(&local
->sta_cleanup
);
345 static void sta_info_proc_add_task(void *data
)
347 struct ieee80211_local
*local
= data
;
348 struct sta_info
*sta
, *tmp
;
351 spin_lock_bh(&local
->sta_lock
);
352 if (!list_empty(&local
->deleted_sta_list
)) {
353 sta
= list_entry(local
->deleted_sta_list
.next
,
354 struct sta_info
, list
);
355 list_del(local
->deleted_sta_list
.next
);
358 spin_unlock_bh(&local
->sta_lock
);
361 finish_sta_info_free(local
, sta
);
366 spin_lock_bh(&local
->sta_lock
);
367 list_for_each_entry(tmp
, &local
->sta_list
, list
) {
368 if (!tmp
->sysfs_registered
) {
374 spin_unlock_bh(&local
->sta_lock
);
379 sta
->sysfs_registered
= 1;
380 ieee80211_sta_sysfs_add(sta
);
381 rate_control_add_sta_attrs(sta
, &sta
->kobj
);
387 void sta_info_init(struct ieee80211_local
*local
)
389 spin_lock_init(&local
->sta_lock
);
390 INIT_LIST_HEAD(&local
->sta_list
);
391 INIT_LIST_HEAD(&local
->deleted_sta_list
);
393 init_timer(&local
->sta_cleanup
);
394 local
->sta_cleanup
.expires
= jiffies
+ STA_INFO_CLEANUP_INTERVAL
;
395 local
->sta_cleanup
.data
= (unsigned long) local
;
396 local
->sta_cleanup
.function
= sta_info_cleanup
;
398 INIT_WORK(&local
->sta_proc_add
, sta_info_proc_add_task
, local
);
401 int sta_info_start(struct ieee80211_local
*local
)
405 res
= ieee80211_sta_kset_sysfs_register(local
);
408 add_timer(&local
->sta_cleanup
);
412 void sta_info_stop(struct ieee80211_local
*local
)
414 struct sta_info
*sta
, *tmp
;
416 del_timer(&local
->sta_cleanup
);
418 list_for_each_entry_safe(sta
, tmp
, &local
->sta_list
, list
) {
419 /* sta_info_free must be called with 0 as the last
420 * parameter to ensure all sysfs sta entries are
421 * unregistered. We don't need locking at this
423 sta_info_free(sta
, 0);
425 ieee80211_sta_kset_sysfs_unregister(local
);
429 void sta_info_remove_aid_ptr(struct sta_info
*sta
)
431 struct ieee80211_sub_if_data
*sdata
;
436 sdata
= IEEE80211_DEV_TO_SUB_IF(sta
->dev
);
438 if (sdata
->local
->ops
->set_tim
)
439 sdata
->local
->ops
->set_tim(local_to_hw(sdata
->local
),
442 bss_tim_clear(sdata
->local
, sdata
->bss
, sta
->aid
);
447 * sta_info_flush - flush matching STA entries from the STA table
448 * @local: local interface data
449 * @dev: matching rule for the net device (sta->dev) or %NULL to match all STAs
451 void sta_info_flush(struct ieee80211_local
*local
, struct net_device
*dev
)
453 struct sta_info
*sta
, *tmp
;
455 spin_lock_bh(&local
->sta_lock
);
456 list_for_each_entry_safe(sta
, tmp
, &local
->sta_list
, list
)
457 if (!dev
|| dev
== sta
->dev
)
458 sta_info_free(sta
, 1);
459 spin_unlock_bh(&local
->sta_lock
);