main.c 49.9 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
/*
 * Copyright 2002-2005, Instant802 Networks, Inc.
 * Copyright 2005-2006, Devicescape Software, Inc.
 * Copyright 2006-2007	Jiri Benc <jbenc@suse.cz>
 *
 * 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.
 */

#include <net/mac80211.h>
#include <net/ieee80211_radiotap.h>
#include <linux/module.h>
#include <linux/init.h>
#include <linux/netdevice.h>
#include <linux/types.h>
#include <linux/slab.h>
#include <linux/skbuff.h>
#include <linux/etherdevice.h>
#include <linux/if_arp.h>
#include <linux/wireless.h>
#include <linux/rtnetlink.h>
#include <linux/bitmap.h>
24
#include <net/net_namespace.h>
25 26 27
#include <net/cfg80211.h>

#include "ieee80211_i.h"
Johannes Berg's avatar
Johannes Berg committed
28
#include "rate.h"
29
#include "mesh.h"
30 31 32
#include "wep.h"
#include "wme.h"
#include "aes_ccm.h"
Johannes Berg's avatar
Johannes Berg committed
33
#include "led.h"
34
#include "cfg.h"
35 36
#include "debugfs.h"
#include "debugfs_netdev.h"
37

38 39 40 41 42 43 44 45 46 47
/*
 * For seeing transmitted packets on monitor interfaces
 * we have a radiotap header too.
 */
struct ieee80211_tx_status_rtap_hdr {
	struct ieee80211_radiotap_header hdr;
	__le16 tx_flags;
	u8 data_retries;
} __attribute__ ((packed));

48
/* common interface routines */
49

50
static int header_parse_80211(const struct sk_buff *skb, unsigned char *haddr)
51 52 53 54
{
	memcpy(haddr, skb_mac_header(skb) + 10, ETH_ALEN); /* addr2 */
	return ETH_ALEN;
}
55

56 57 58 59 60 61
/* must be called under mdev tx lock */
static void ieee80211_configure_filter(struct ieee80211_local *local)
{
	unsigned int changed_flags;
	unsigned int new_flags = 0;

62
	if (atomic_read(&local->iff_promiscs))
63 64
		new_flags |= FIF_PROMISC_IN_BSS;

65
	if (atomic_read(&local->iff_allmultis))
66 67 68
		new_flags |= FIF_ALLMULTI;

	if (local->monitors)
69 70 71 72 73 74 75 76 77 78 79 80 81
		new_flags |= FIF_BCN_PRBRESP_PROMISC;

	if (local->fif_fcsfail)
		new_flags |= FIF_FCSFAIL;

	if (local->fif_plcpfail)
		new_flags |= FIF_PLCPFAIL;

	if (local->fif_control)
		new_flags |= FIF_CONTROL;

	if (local->fif_other_bss)
		new_flags |= FIF_OTHER_BSS;
82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97

	changed_flags = local->filter_flags ^ new_flags;

	/* be a bit nasty */
	new_flags |= (1<<31);

	local->ops->configure_filter(local_to_hw(local),
				     changed_flags, &new_flags,
				     local->mdev->mc_count,
				     local->mdev->mc_list);

	WARN_ON(new_flags & (1<<31));

	local->filter_flags = new_flags & ~(1<<31);
}

98
/* master interface */
99

100 101 102 103 104
static int ieee80211_master_open(struct net_device *dev)
{
	struct ieee80211_local *local = wdev_priv(dev->ieee80211_ptr);
	struct ieee80211_sub_if_data *sdata;
	int res = -EOPNOTSUPP;
105

106 107
	/* we hold the RTNL here so can safely walk the list */
	list_for_each_entry(sdata, &local->interfaces, list) {
108
		if (netif_running(sdata->dev)) {
109 110 111 112
			res = 0;
			break;
		}
	}
113 114 115 116

	if (res)
		return res;

117
	netif_tx_start_all_queues(local->mdev);
118 119

	return 0;
120
}
121

122
static int ieee80211_master_stop(struct net_device *dev)
123
{
124 125
	struct ieee80211_local *local = wdev_priv(dev->ieee80211_ptr);
	struct ieee80211_sub_if_data *sdata;
126

127 128
	/* we hold the RTNL here so can safely walk the list */
	list_for_each_entry(sdata, &local->interfaces, list)
129
		if (netif_running(sdata->dev))
130
			dev_close(sdata->dev);
131

132 133
	return 0;
}
134

135 136 137 138 139 140 141
static void ieee80211_master_set_multicast_list(struct net_device *dev)
{
	struct ieee80211_local *local = wdev_priv(dev->ieee80211_ptr);

	ieee80211_configure_filter(local);
}

142
/* regular interfaces */
143

144
static int ieee80211_change_mtu(struct net_device *dev, int new_mtu)
145
{
146 147 148 149 150
	int meshhdrlen;
	struct ieee80211_sub_if_data *sdata = IEEE80211_DEV_TO_SUB_IF(dev);

	meshhdrlen = (sdata->vif.type == IEEE80211_IF_TYPE_MESH_POINT) ? 5 : 0;

151 152
	/* FIX: what would be proper limits for MTU?
	 * This interface uses 802.3 frames. */
153
	if (new_mtu < 256 ||
154
	    new_mtu > IEEE80211_MAX_DATA_LEN - 24 - 6 - meshhdrlen) {
155 156
		return -EINVAL;
	}
157

158 159 160 161
#ifdef CONFIG_MAC80211_VERBOSE_DEBUG
	printk(KERN_DEBUG "%s: setting MTU %d\n", dev->name, new_mtu);
#endif /* CONFIG_MAC80211_VERBOSE_DEBUG */
	dev->mtu = new_mtu;
162 163 164
	return 0;
}

165 166 167 168 169 170 171 172 173 174 175 176 177 178 179
static inline int identical_mac_addr_allowed(int type1, int type2)
{
	return (type1 == IEEE80211_IF_TYPE_MNTR ||
		type2 == IEEE80211_IF_TYPE_MNTR ||
		(type1 == IEEE80211_IF_TYPE_AP &&
		 type2 == IEEE80211_IF_TYPE_WDS) ||
		(type1 == IEEE80211_IF_TYPE_WDS &&
		 (type2 == IEEE80211_IF_TYPE_WDS ||
		  type2 == IEEE80211_IF_TYPE_AP)) ||
		(type1 == IEEE80211_IF_TYPE_AP &&
		 type2 == IEEE80211_IF_TYPE_VLAN) ||
		(type1 == IEEE80211_IF_TYPE_VLAN &&
		 (type2 == IEEE80211_IF_TYPE_AP ||
		  type2 == IEEE80211_IF_TYPE_VLAN)));
}
180

181
static int ieee80211_open(struct net_device *dev)
182
{
183 184
	struct ieee80211_sub_if_data *sdata, *nsdata;
	struct ieee80211_local *local = wdev_priv(dev->ieee80211_ptr);
185
	struct sta_info *sta;
186
	struct ieee80211_if_init_conf conf;
187
	u32 changed = 0;
188
	int res;
189
	bool need_hw_reconfig = 0;
190

191
	sdata = IEEE80211_DEV_TO_SUB_IF(dev);
192

193 194
	/* we hold the RTNL here so can safely walk the list */
	list_for_each_entry(nsdata, &local->interfaces, list) {
195
		struct net_device *ndev = nsdata->dev;
196

197
		if (ndev != dev && netif_running(ndev)) {
198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218
			/*
			 * Allow only a single IBSS interface to be up at any
			 * time. This is restricted because beacon distribution
			 * cannot work properly if both are in the same IBSS.
			 *
			 * To remove this restriction we'd have to disallow them
			 * from setting the same SSID on different IBSS interfaces
			 * belonging to the same hardware. Then, however, we're
			 * faced with having to adopt two different TSF timers...
			 */
			if (sdata->vif.type == IEEE80211_IF_TYPE_IBSS &&
			    nsdata->vif.type == IEEE80211_IF_TYPE_IBSS)
				return -EBUSY;

			/*
			 * The remaining checks are only performed for interfaces
			 * with the same MAC address.
			 */
			if (compare_ether_addr(dev->dev_addr, ndev->dev_addr))
				continue;

219 220 221
			/*
			 * check whether it may have the same address
			 */
222 223
			if (!identical_mac_addr_allowed(sdata->vif.type,
							nsdata->vif.type))
224 225 226 227 228
				return -ENOTUNIQ;

			/*
			 * can only add VLANs to enabled APs
			 */
229
			if (sdata->vif.type == IEEE80211_IF_TYPE_VLAN &&
230
			    nsdata->vif.type == IEEE80211_IF_TYPE_AP)
231
				sdata->bss = &nsdata->u.ap;
232 233
		}
	}
234

235
	switch (sdata->vif.type) {
236
	case IEEE80211_IF_TYPE_WDS:
237
		if (!is_valid_ether_addr(sdata->u.wds.remote_addr))
238 239 240
			return -ENOLINK;
		break;
	case IEEE80211_IF_TYPE_VLAN:
241
		if (!sdata->bss)
242
			return -ENOLINK;
243
		list_add(&sdata->u.vlan.list, &sdata->bss->vlans);
244
		break;
Johannes Berg's avatar
Johannes Berg committed
245
	case IEEE80211_IF_TYPE_AP:
246 247
		sdata->bss = &sdata->u.ap;
		break;
248 249 250 251
	case IEEE80211_IF_TYPE_MESH_POINT:
		/* mesh ifaces must set allmulti to forward mcast traffic */
		atomic_inc(&local->iff_allmultis);
		break;
Johannes Berg's avatar
Johannes Berg committed
252 253 254 255 256
	case IEEE80211_IF_TYPE_STA:
	case IEEE80211_IF_TYPE_MNTR:
	case IEEE80211_IF_TYPE_IBSS:
		/* no special treatment */
		break;
257 258 259 260
	case IEEE80211_IF_TYPE_INVALID:
		/* cannot happen */
		WARN_ON(1);
		break;
261
	}
262

263 264
	if (local->open_count == 0) {
		res = 0;
265 266 267
		if (local->ops->start)
			res = local->ops->start(local_to_hw(local));
		if (res)
268
			goto err_del_bss;
269
		need_hw_reconfig = 1;
270
		ieee80211_led_radio(local, local->hw.conf.radio_enabled);
271
	}
272

273
	switch (sdata->vif.type) {
274 275 276
	case IEEE80211_IF_TYPE_VLAN:
		/* no need to tell driver */
		break;
277
	case IEEE80211_IF_TYPE_MNTR:
278 279 280 281 282
		if (sdata->u.mntr_flags & MONITOR_FLAG_COOK_FRAMES) {
			local->cooked_mntrs++;
			break;
		}

283
		/* must be before the call to ieee80211_configure_filter */
284
		local->monitors++;
285
		if (local->monitors == 1)
286
			local->hw.conf.flags |= IEEE80211_CONF_RADIOTAP;
287 288 289 290 291 292 293 294 295 296

		if (sdata->u.mntr_flags & MONITOR_FLAG_FCSFAIL)
			local->fif_fcsfail++;
		if (sdata->u.mntr_flags & MONITOR_FLAG_PLCPFAIL)
			local->fif_plcpfail++;
		if (sdata->u.mntr_flags & MONITOR_FLAG_CONTROL)
			local->fif_control++;
		if (sdata->u.mntr_flags & MONITOR_FLAG_OTHER_BSS)
			local->fif_other_bss++;

297
		netif_addr_lock_bh(local->mdev);
298
		ieee80211_configure_filter(local);
299
		netif_addr_unlock_bh(local->mdev);
300 301 302 303 304 305
		break;
	case IEEE80211_IF_TYPE_STA:
	case IEEE80211_IF_TYPE_IBSS:
		sdata->u.sta.flags &= ~IEEE80211_STA_PREV_BSSID_SET;
		/* fall through */
	default:
306
		conf.vif = &sdata->vif;
307
		conf.type = sdata->vif.type;
308 309 310
		conf.mac_addr = dev->dev_addr;
		res = local->ops->add_interface(local_to_hw(local), &conf);
		if (res)
311
			goto err_stop;
312

313 314
		if (ieee80211_vif_is_mesh(&sdata->vif))
			ieee80211_start_mesh(sdata->dev);
315 316
		changed |= ieee80211_reset_erp_info(dev);
		ieee80211_bss_info_change_notify(sdata, changed);
317
		ieee80211_enable_keys(sdata);
318

319
		if (sdata->vif.type == IEEE80211_IF_TYPE_STA &&
320
		    !(sdata->flags & IEEE80211_SDATA_USERSPACE_MLME))
321 322 323
			netif_carrier_off(dev);
		else
			netif_carrier_on(dev);
324
	}
325

326 327 328 329 330 331 332 333 334
	if (sdata->vif.type == IEEE80211_IF_TYPE_WDS) {
		/* Create STA entry for the WDS peer */
		sta = sta_info_alloc(sdata, sdata->u.wds.remote_addr,
				     GFP_KERNEL);
		if (!sta) {
			res = -ENOMEM;
			goto err_del_interface;
		}

335
		/* no locking required since STA is not live yet */
336 337 338 339 340 341 342 343 344
		sta->flags |= WLAN_STA_AUTHORIZED;

		res = sta_info_insert(sta);
		if (res) {
			/* STA has been freed */
			goto err_del_interface;
		}
	}

345 346 347
	if (local->open_count == 0) {
		res = dev_open(local->mdev);
		WARN_ON(res);
348 349
		if (res)
			goto err_del_interface;
350 351 352 353
		tasklet_enable(&local->tx_pending_tasklet);
		tasklet_enable(&local->tasklet);
	}

354 355 356 357 358 359 360 361 362 363 364
	/*
	 * set_multicast_list will be invoked by the networking core
	 * which will check whether any increments here were done in
	 * error and sync them down to the hardware as filter flags.
	 */
	if (sdata->flags & IEEE80211_SDATA_ALLMULTI)
		atomic_inc(&local->iff_allmultis);

	if (sdata->flags & IEEE80211_SDATA_PROMISC)
		atomic_inc(&local->iff_promiscs);

365
	local->open_count++;
366 367
	if (need_hw_reconfig)
		ieee80211_hw_config(local);
368

369 370 371 372 373 374
	/*
	 * ieee80211_sta_work is disabled while network interface
	 * is down. Therefore, some configuration changes may not
	 * yet be effective. Trigger execution of ieee80211_sta_work
	 * to fix this.
	 */
Johannes Berg's avatar
Johannes Berg committed
375 376
	if (sdata->vif.type == IEEE80211_IF_TYPE_STA ||
	    sdata->vif.type == IEEE80211_IF_TYPE_IBSS) {
377 378 379 380
		struct ieee80211_if_sta *ifsta = &sdata->u.sta;
		queue_work(local->hw.workqueue, &ifsta->work);
	}

381
	netif_tx_start_all_queues(dev);
382

383
	return 0;
384 385 386 387 388
 err_del_interface:
	local->ops->remove_interface(local_to_hw(local), &conf);
 err_stop:
	if (!local->open_count && local->ops->stop)
		local->ops->stop(local_to_hw(local));
389 390 391 392
 err_del_bss:
	sdata->bss = NULL;
	if (sdata->vif.type == IEEE80211_IF_TYPE_VLAN)
		list_del(&sdata->u.vlan.list);
393
	return res;
394 395
}

396
static int ieee80211_stop(struct net_device *dev)
397
{
398 399
	struct ieee80211_sub_if_data *sdata = IEEE80211_DEV_TO_SUB_IF(dev);
	struct ieee80211_local *local = sdata->local;
400
	struct ieee80211_if_init_conf conf;
401
	struct sta_info *sta;
402

403 404 405
	/*
	 * Stop TX on this interface first.
	 */
406
	netif_tx_stop_all_queues(dev);
407

408 409 410
	/*
	 * Now delete all active aggregation sessions.
	 */
411 412 413 414
	rcu_read_lock();

	list_for_each_entry_rcu(sta, &local->sta_list, list) {
		if (sta->sdata == sdata)
415
			ieee80211_sta_tear_down_BA_sessions(dev, sta->addr);
416 417
	}

418 419
	rcu_read_unlock();

420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437
	/*
	 * Remove all stations associated with this interface.
	 *
	 * This must be done before calling ops->remove_interface()
	 * because otherwise we can later invoke ops->sta_notify()
	 * whenever the STAs are removed, and that invalidates driver
	 * assumptions about always getting a vif pointer that is valid
	 * (because if we remove a STA after ops->remove_interface()
	 * the driver will have removed the vif info already!)
	 *
	 * We could relax this and only unlink the stations from the
	 * hash table and list but keep them on a per-sdata list that
	 * will be inserted back again when the interface is brought
	 * up again, but I don't currently see a use case for that,
	 * except with WDS which gets a STA entry created when it is
	 * brought up.
	 */
	sta_info_flush(local, sdata);
438

439 440 441 442 443 444 445 446 447 448 449 450
	/*
	 * Don't count this interface for promisc/allmulti while it
	 * is down. dev_mc_unsync() will invoke set_multicast_list
	 * on the master interface which will sync these down to the
	 * hardware as filter flags.
	 */
	if (sdata->flags & IEEE80211_SDATA_ALLMULTI)
		atomic_dec(&local->iff_allmultis);

	if (sdata->flags & IEEE80211_SDATA_PROMISC)
		atomic_dec(&local->iff_promiscs);

451 452
	dev_mc_unsync(local->mdev, dev);

453
	/* APs need special treatment */
454
	if (sdata->vif.type == IEEE80211_IF_TYPE_AP) {
455
		struct ieee80211_sub_if_data *vlan, *tmp;
456
		struct beacon_data *old_beacon = sdata->u.ap.beacon;
457

458 459 460 461 462 463
		/* remove beacon */
		rcu_assign_pointer(sdata->u.ap.beacon, NULL);
		synchronize_rcu();
		kfree(old_beacon);

		/* down all dependent devices, that is VLANs */
464 465 466 467 468 469
		list_for_each_entry_safe(vlan, tmp, &sdata->u.ap.vlans,
					 u.vlan.list)
			dev_close(vlan->dev);
		WARN_ON(!list_empty(&sdata->u.ap.vlans));
	}

470
	local->open_count--;
471

472
	switch (sdata->vif.type) {
473 474 475 476
	case IEEE80211_IF_TYPE_VLAN:
		list_del(&sdata->u.vlan.list);
		/* no need to tell driver */
		break;
477
	case IEEE80211_IF_TYPE_MNTR:
478 479 480 481 482
		if (sdata->u.mntr_flags & MONITOR_FLAG_COOK_FRAMES) {
			local->cooked_mntrs--;
			break;
		}

483
		local->monitors--;
484
		if (local->monitors == 0)
485
			local->hw.conf.flags &= ~IEEE80211_CONF_RADIOTAP;
486 487 488 489 490 491 492 493 494 495

		if (sdata->u.mntr_flags & MONITOR_FLAG_FCSFAIL)
			local->fif_fcsfail--;
		if (sdata->u.mntr_flags & MONITOR_FLAG_PLCPFAIL)
			local->fif_plcpfail--;
		if (sdata->u.mntr_flags & MONITOR_FLAG_CONTROL)
			local->fif_control--;
		if (sdata->u.mntr_flags & MONITOR_FLAG_OTHER_BSS)
			local->fif_other_bss--;

496
		netif_addr_lock_bh(local->mdev);
497
		ieee80211_configure_filter(local);
498
		netif_addr_unlock_bh(local->mdev);
499
		break;
500
	case IEEE80211_IF_TYPE_MESH_POINT:
501 502 503
		/* allmulti is always set on mesh ifaces */
		atomic_dec(&local->iff_allmultis);
		/* fall through */
504 505 506
	case IEEE80211_IF_TYPE_STA:
	case IEEE80211_IF_TYPE_IBSS:
		sdata->u.sta.state = IEEE80211_DISABLED;
507
		memset(sdata->u.sta.bssid, 0, ETH_ALEN);
508
		del_timer_sync(&sdata->u.sta.timer);
509
		/*
510 511 512 513
		 * When we get here, the interface is marked down.
		 * Call synchronize_rcu() to wait for the RX path
		 * should it be using the interface and enqueuing
		 * frames at this very time on another CPU.
514
		 */
515
		synchronize_rcu();
516
		skb_queue_purge(&sdata->u.sta.skb_queue);
517

Zhu Yi's avatar
Zhu Yi committed
518 519 520 521 522 523
		if (local->scan_dev == sdata->dev) {
			if (!local->ops->hw_scan) {
				local->sta_sw_scanning = 0;
				cancel_delayed_work(&local->scan_work);
			} else
				local->sta_hw_scanning = 0;
524
		}
Zhu Yi's avatar
Zhu Yi committed
525

526 527 528 529
		sdata->u.sta.flags &= ~IEEE80211_STA_PRIVACY_INVOKED;
		kfree(sdata->u.sta.extra_ie);
		sdata->u.sta.extra_ie = NULL;
		sdata->u.sta.extra_ie_len = 0;
530 531
		/* fall through */
	default:
532
		conf.vif = &sdata->vif;
533
		conf.type = sdata->vif.type;
534
		conf.mac_addr = dev->dev_addr;
535 536
		/* disable all keys for as long as this netdev is down */
		ieee80211_disable_keys(sdata);
537
		local->ops->remove_interface(local_to_hw(local), &conf);
538 539
	}

540 541
	sdata->bss = NULL;

542 543 544
	if (local->open_count == 0) {
		if (netif_running(local->mdev))
			dev_close(local->mdev);
545

546 547
		if (local->ops->stop)
			local->ops->stop(local_to_hw(local));
548

549 550
		ieee80211_led_radio(local, 0);

551 552
		flush_workqueue(local->hw.workqueue);

553 554 555 556
		tasklet_disable(&local->tx_pending_tasklet);
		tasklet_disable(&local->tasklet);
	}

557 558 559
	return 0;
}

560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577
int ieee80211_start_tx_ba_session(struct ieee80211_hw *hw, u8 *ra, u16 tid)
{
	struct ieee80211_local *local = hw_to_local(hw);
	struct sta_info *sta;
	struct ieee80211_sub_if_data *sdata;
	u16 start_seq_num = 0;
	u8 *state;
	int ret;
	DECLARE_MAC_BUF(mac);

	if (tid >= STA_TID_NUM)
		return -EINVAL;

#ifdef CONFIG_MAC80211_HT_DEBUG
	printk(KERN_DEBUG "Open BA session requested for %s tid %u\n",
				print_mac(mac, ra), tid);
#endif /* CONFIG_MAC80211_HT_DEBUG */

578 579
	rcu_read_lock();

580 581
	sta = sta_info_get(local, ra);
	if (!sta) {
582
#ifdef CONFIG_MAC80211_HT_DEBUG
583
		printk(KERN_DEBUG "Could not find the station\n");
584
#endif
585 586
		ret = -ENOENT;
		goto exit;
587 588
	}

589
	spin_lock_bh(&sta->lock);
590 591

	/* we have tried too many times, receiver does not want A-MPDU */
592
	if (sta->ampdu_mlme.addba_req_num[tid] > HT_AGG_MAX_RETRIES) {
593
		ret = -EBUSY;
594
		goto err_unlock_sta;
595 596
	}

597
	state = &sta->ampdu_mlme.tid_state_tx[tid];
598 599 600 601 602 603 604
	/* check if the TID is not in aggregation flow already */
	if (*state != HT_AGG_STATE_IDLE) {
#ifdef CONFIG_MAC80211_HT_DEBUG
		printk(KERN_DEBUG "BA request denied - session is not "
				 "idle on tid %u\n", tid);
#endif /* CONFIG_MAC80211_HT_DEBUG */
		ret = -EAGAIN;
605
		goto err_unlock_sta;
606 607
	}

608 609 610 611
	/* prepare A-MPDU MLME for Tx aggregation */
	sta->ampdu_mlme.tid_tx[tid] =
			kmalloc(sizeof(struct tid_ampdu_tx), GFP_ATOMIC);
	if (!sta->ampdu_mlme.tid_tx[tid]) {
612
#ifdef CONFIG_MAC80211_HT_DEBUG
613 614 615
		if (net_ratelimit())
			printk(KERN_ERR "allocate tx mlme to tid %d failed\n",
					tid);
616
#endif
617
		ret = -ENOMEM;
618
		goto err_unlock_sta;
619 620 621 622 623 624 625 626
	}
	/* Tx timer */
	sta->ampdu_mlme.tid_tx[tid]->addba_resp_timer.function =
			sta_addba_resp_timer_expired;
	sta->ampdu_mlme.tid_tx[tid]->addba_resp_timer.data =
			(unsigned long)&sta->timer_to_tid[tid];
	init_timer(&sta->ampdu_mlme.tid_tx[tid]->addba_resp_timer);

627
	/* create a new queue for this aggregation */
628
	ret = ieee80211_ht_agg_queue_add(local, sta, tid);
629 630 631 632 633

	/* case no queue is available to aggregation
	 * don't switch to aggregation */
	if (ret) {
#ifdef CONFIG_MAC80211_HT_DEBUG
634
		printk(KERN_DEBUG "BA request denied - queue unavailable for"
635 636
					" tid %d\n", tid);
#endif /* CONFIG_MAC80211_HT_DEBUG */
637
		goto err_unlock_queue;
638
	}
639
	sdata = sta->sdata;
640 641 642 643 644 645 646 647 648 649 650 651 652

	/* Ok, the Addba frame hasn't been sent yet, but if the driver calls the
	 * call back right away, it must see that the flow has begun */
	*state |= HT_ADDBA_REQUESTED_MSK;

	if (local->ops->ampdu_action)
		ret = local->ops->ampdu_action(hw, IEEE80211_AMPDU_TX_START,
						ra, tid, &start_seq_num);

	if (ret) {
		/* No need to requeue the packets in the agg queue, since we
		 * held the tx lock: no packet could be enqueued to the newly
		 * allocated queue */
653
		ieee80211_ht_agg_queue_remove(local, sta, tid, 0);
654
#ifdef CONFIG_MAC80211_HT_DEBUG
655 656
		printk(KERN_DEBUG "BA request denied - HW unavailable for"
					" tid %d\n", tid);
657 658
#endif /* CONFIG_MAC80211_HT_DEBUG */
		*state = HT_AGG_STATE_IDLE;
659
		goto err_unlock_queue;
660 661 662
	}

	/* Will put all the packets in the new SW queue */
663
	ieee80211_requeue(local, ieee802_1d_to_ac[tid]);
664
	spin_unlock_bh(&sta->lock);
665 666 667

	/* send an addBA request */
	sta->ampdu_mlme.dialog_token_allocator++;
668
	sta->ampdu_mlme.tid_tx[tid]->dialog_token =
669
			sta->ampdu_mlme.dialog_token_allocator;
670
	sta->ampdu_mlme.tid_tx[tid]->ssn = start_seq_num;
671

672

673
	ieee80211_send_addba_request(sta->sdata->dev, ra, tid,
674 675
			 sta->ampdu_mlme.tid_tx[tid]->dialog_token,
			 sta->ampdu_mlme.tid_tx[tid]->ssn,
676 677
			 0x40, 5000);
	/* activate the timer for the recipient's addBA response */
678
	sta->ampdu_mlme.tid_tx[tid]->addba_resp_timer.expires =
679
				jiffies + ADDBA_RESP_INTERVAL;
680
	add_timer(&sta->ampdu_mlme.tid_tx[tid]->addba_resp_timer);
681
#ifdef CONFIG_MAC80211_HT_DEBUG
682
	printk(KERN_DEBUG "activated addBA response timer on tid %d\n", tid);
683
#endif
684
	goto exit;
685

686
err_unlock_queue:
687 688 689
	kfree(sta->ampdu_mlme.tid_tx[tid]);
	sta->ampdu_mlme.tid_tx[tid] = NULL;
	ret = -EBUSY;
690
err_unlock_sta:
691
	spin_unlock_bh(&sta->lock);
692
exit:
693
	rcu_read_unlock();
694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710
	return ret;
}
EXPORT_SYMBOL(ieee80211_start_tx_ba_session);

int ieee80211_stop_tx_ba_session(struct ieee80211_hw *hw,
				 u8 *ra, u16 tid,
				 enum ieee80211_back_parties initiator)
{
	struct ieee80211_local *local = hw_to_local(hw);
	struct sta_info *sta;
	u8 *state;
	int ret = 0;
	DECLARE_MAC_BUF(mac);

	if (tid >= STA_TID_NUM)
		return -EINVAL;

711
	rcu_read_lock();
712
	sta = sta_info_get(local, ra);
713 714
	if (!sta) {
		rcu_read_unlock();
715
		return -ENOENT;
716
	}
717 718

	/* check if the TID is in aggregation */
719
	state = &sta->ampdu_mlme.tid_state_tx[tid];
720
	spin_lock_bh(&sta->lock);
721 722 723 724 725 726

	if (*state != HT_AGG_STATE_OPERATIONAL) {
		ret = -ENOENT;
		goto stop_BA_exit;
	}

727 728 729 730 731
#ifdef CONFIG_MAC80211_HT_DEBUG
	printk(KERN_DEBUG "Tx BA session stop requested for %s tid %u\n",
				print_mac(mac, ra), tid);
#endif /* CONFIG_MAC80211_HT_DEBUG */

732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749
	ieee80211_stop_queue(hw, sta->tid_to_tx_q[tid]);

	*state = HT_AGG_STATE_REQ_STOP_BA_MSK |
		(initiator << HT_AGG_STATE_INITIATOR_SHIFT);

	if (local->ops->ampdu_action)
		ret = local->ops->ampdu_action(hw, IEEE80211_AMPDU_TX_STOP,
						ra, tid, NULL);

	/* case HW denied going back to legacy */
	if (ret) {
		WARN_ON(ret != -EBUSY);
		*state = HT_AGG_STATE_OPERATIONAL;
		ieee80211_wake_queue(hw, sta->tid_to_tx_q[tid]);
		goto stop_BA_exit;
	}

stop_BA_exit:
750
	spin_unlock_bh(&sta->lock);
751
	rcu_read_unlock();
752 753 754 755 756 757 758 759 760 761 762 763
	return ret;
}
EXPORT_SYMBOL(ieee80211_stop_tx_ba_session);

void ieee80211_start_tx_ba_cb(struct ieee80211_hw *hw, u8 *ra, u16 tid)
{
	struct ieee80211_local *local = hw_to_local(hw);
	struct sta_info *sta;
	u8 *state;
	DECLARE_MAC_BUF(mac);

	if (tid >= STA_TID_NUM) {
764
#ifdef CONFIG_MAC80211_HT_DEBUG
765 766
		printk(KERN_DEBUG "Bad TID value: tid = %d (>= %d)\n",
				tid, STA_TID_NUM);
767
#endif
768 769 770
		return;
	}

771
	rcu_read_lock();
772 773
	sta = sta_info_get(local, ra);
	if (!sta) {
774
		rcu_read_unlock();
775
#ifdef CONFIG_MAC80211_HT_DEBUG
776 777
		printk(KERN_DEBUG "Could not find station: %s\n",
				print_mac(mac, ra));
778
#endif
779 780 781
		return;
	}

782
	state = &sta->ampdu_mlme.tid_state_tx[tid];
783
	spin_lock_bh(&sta->lock);
784 785

	if (!(*state & HT_ADDBA_REQUESTED_MSK)) {
786
#ifdef CONFIG_MAC80211_HT_DEBUG
787 788
		printk(KERN_DEBUG "addBA was not requested yet, state is %d\n",
				*state);
789
#endif
790
		spin_unlock_bh(&sta->lock);
791
		rcu_read_unlock();
792 793 794 795 796 797 798 799
		return;
	}

	WARN_ON_ONCE(*state & HT_ADDBA_DRV_READY_MSK);

	*state |= HT_ADDBA_DRV_READY_MSK;

	if (*state == HT_AGG_STATE_OPERATIONAL) {
800
#ifdef CONFIG_MAC80211_HT_DEBUG
801
		printk(KERN_DEBUG "Aggregation is on for tid %d \n", tid);
802
#endif
803 804
		ieee80211_wake_queue(hw, sta->tid_to_tx_q[tid]);
	}
805
	spin_unlock_bh(&sta->lock);
806
	rcu_read_unlock();
807 808 809 810 811 812 813 814 815 816 817 818
}
EXPORT_SYMBOL(ieee80211_start_tx_ba_cb);

void ieee80211_stop_tx_ba_cb(struct ieee80211_hw *hw, u8 *ra, u8 tid)
{
	struct ieee80211_local *local = hw_to_local(hw);
	struct sta_info *sta;
	u8 *state;
	int agg_queue;
	DECLARE_MAC_BUF(mac);

	if (tid >= STA_TID_NUM) {
819
#ifdef CONFIG_MAC80211_HT_DEBUG
820 821
		printk(KERN_DEBUG "Bad TID value: tid = %d (>= %d)\n",
				tid, STA_TID_NUM);
822
#endif
823 824 825
		return;
	}

826 827
#ifdef CONFIG_MAC80211_HT_DEBUG
	printk(KERN_DEBUG "Stopping Tx BA session for %s tid %d\n",
828
				print_mac(mac, ra), tid);
829
#endif /* CONFIG_MAC80211_HT_DEBUG */
830

831
	rcu_read_lock();
832 833
	sta = sta_info_get(local, ra);
	if (!sta) {
834
#ifdef CONFIG_MAC80211_HT_DEBUG
835 836
		printk(KERN_DEBUG "Could not find station: %s\n",
				print_mac(mac, ra));
837
#endif
838
		rcu_read_unlock();
839 840
		return;
	}
841
	state = &sta->ampdu_mlme.tid_state_tx[tid];
842

843
	/* NOTE: no need to use sta->lock in this state check, as
844 845 846
	 * ieee80211_stop_tx_ba_session will let only one stop call to
	 * pass through per sta/tid
	 */
847
	if ((*state & HT_AGG_STATE_REQ_STOP_BA_MSK) == 0) {
848
#ifdef CONFIG_MAC80211_HT_DEBUG
849
		printk(KERN_DEBUG "unexpected callback to A-MPDU stop\n");
850
#endif
851
		rcu_read_unlock();
852 853 854 855
		return;
	}

	if (*state & HT_AGG_STATE_INITIATOR_MSK)
856
		ieee80211_send_delba(sta->sdata->dev, ra, tid,
857 858 859 860
			WLAN_BACK_INITIATOR, WLAN_REASON_QSTA_NOT_USE);

	agg_queue = sta->tid_to_tx_q[tid];

861
	ieee80211_ht_agg_queue_remove(local, sta, tid, 1);
862

863 864 865 866 867 868
	/* We just requeued the all the frames that were in the
	 * removed queue, and since we might miss a softirq we do
	 * netif_schedule_queue.  ieee80211_wake_queue is not used
	 * here as this queue is not necessarily stopped
	 */
	netif_schedule_queue(netdev_get_tx_queue(local->mdev, agg_queue));
869
	spin_lock_bh(&sta->lock);
870
	*state = HT_AGG_STATE_IDLE;
871 872 873
	sta->ampdu_mlme.addba_req_num[tid] = 0;
	kfree(sta->ampdu_mlme.tid_tx[tid]);
	sta->ampdu_mlme.tid_tx[tid] = NULL;
874
	spin_unlock_bh(&sta->lock);
875

876
	rcu_read_unlock();
877 878 879 880 881 882 883 884 885 886 887
}
EXPORT_SYMBOL(ieee80211_stop_tx_ba_cb);

void ieee80211_start_tx_ba_cb_irqsafe(struct ieee80211_hw *hw,
				      const u8 *ra, u16 tid)
{
	struct ieee80211_local *local = hw_to_local(hw);
	struct ieee80211_ra_tid *ra_tid;
	struct sk_buff *skb = dev_alloc_skb(0);

	if (unlikely(!skb)) {
888
#ifdef CONFIG_MAC80211_HT_DEBUG
889 890 891
		if (net_ratelimit())
			printk(KERN_WARNING "%s: Not enough memory, "
			       "dropping start BA session", skb->dev->name);
892
#endif
893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912
		return;
	}
	ra_tid = (struct ieee80211_ra_tid *) &skb->cb;
	memcpy(&ra_tid->ra, ra, ETH_ALEN);
	ra_tid->tid = tid;

	skb->pkt_type = IEEE80211_ADDBA_MSG;
	skb_queue_tail(&local->skb_queue, skb);
	tasklet_schedule(&local->tasklet);
}
EXPORT_SYMBOL(ieee80211_start_tx_ba_cb_irqsafe);

void ieee80211_stop_tx_ba_cb_irqsafe(struct ieee80211_hw *hw,
				     const u8 *ra, u16 tid)
{
	struct ieee80211_local *local = hw_to_local(hw);
	struct ieee80211_ra_tid *ra_tid;
	struct sk_buff *skb = dev_alloc_skb(0);

	if (unlikely(!skb)) {
913
#ifdef CONFIG_MAC80211_HT_DEBUG
914 915 916
		if (net_ratelimit())
			printk(KERN_WARNING "%s: Not enough memory, "
			       "dropping stop BA session", skb->dev->name);
917
#endif
918 919 920 921 922 923 924 925 926 927 928 929
		return;
	}
	ra_tid = (struct ieee80211_ra_tid *) &skb->cb;
	memcpy(&ra_tid->ra, ra, ETH_ALEN);
	ra_tid->tid = tid;

	skb->pkt_type = IEEE80211_DELBA_MSG;
	skb_queue_tail(&local->skb_queue, skb);
	tasklet_schedule(&local->tasklet);
}
EXPORT_SYMBOL(ieee80211_stop_tx_ba_cb_irqsafe);

930 931 932 933
static void ieee80211_set_multicast_list(struct net_device *dev)
{
	struct ieee80211_local *local = wdev_priv(dev->ieee80211_ptr);
	struct ieee80211_sub_if_data *sdata = IEEE80211_DEV_TO_SUB_IF(dev);
934
	int allmulti, promisc, sdata_allmulti, sdata_promisc;
935

936 937
	allmulti = !!(dev->flags & IFF_ALLMULTI);
	promisc = !!(dev->flags & IFF_PROMISC);
938 939
	sdata_allmulti = !!(sdata->flags & IEEE80211_SDATA_ALLMULTI);
	sdata_promisc = !!(sdata->flags & IEEE80211_SDATA_PROMISC);
940 941 942

	if (allmulti != sdata_allmulti) {
		if (dev->flags & IFF_ALLMULTI)
943
			atomic_inc(&local->iff_allmultis);
944
		else
945
			atomic_dec(&local->iff_allmultis);
946
		sdata->flags ^= IEEE80211_SDATA_ALLMULTI;
947
	}
948 949 950

	if (promisc != sdata_promisc) {
		if (dev->flags & IFF_PROMISC)
951
			atomic_inc(&local->iff_promiscs);
952
		else
953
			atomic_dec(&local->iff_promiscs);
954
		sdata->flags ^= IEEE80211_SDATA_PROMISC;
955
	}
956 957

	dev_mc_sync(local->mdev, dev);
958 959
}

960 961 962 963 964 965 966 967
static const struct header_ops ieee80211_header_ops = {
	.create		= eth_header,
	.parse		= header_parse_80211,
	.rebuild	= eth_rebuild_header,
	.cache		= eth_header_cache,
	.cache_update	= eth_header_cache_update,
};

968
void ieee80211_if_setup(struct net_device *dev)
969
{
970 971 972 973 974 975 976
	ether_setup(dev);
	dev->hard_start_xmit = ieee80211_subif_start_xmit;
	dev->wireless_handlers = &ieee80211_iw_handler_def;
	dev->set_multicast_list = ieee80211_set_multicast_list;
	dev->change_mtu = ieee80211_change_mtu;
	dev->open = ieee80211_open;
	dev->stop = ieee80211_stop;
977
	dev->destructor = free_netdev;
978
}
979