rt2x00dev.c 26.4 KB
Newer Older
1
/*
2
	Copyright (C) 2004 - 2009 Ivo van Doorn <IvDoorn@gmail.com>
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
	<http://rt2x00.serialmonkey.com>

	This program is free software; you can redistribute it and/or modify
	it under the terms of the GNU General Public License as published by
	the Free Software Foundation; either version 2 of the License, or
	(at your option) any later version.

	This program is distributed in the hope that it will be useful,
	but WITHOUT ANY WARRANTY; without even the implied warranty of
	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
	GNU General Public License for more details.

	You should have received a copy of the GNU General Public License
	along with this program; if not, write to the
	Free Software Foundation, Inc.,
	59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 */

/*
	Module: rt2x00lib
	Abstract: rt2x00 generic device routines.
 */

#include <linux/kernel.h>
#include <linux/module.h>
28
#include <linux/slab.h>
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43

#include "rt2x00.h"
#include "rt2x00lib.h"

/*
 * Radio control handlers.
 */
int rt2x00lib_enable_radio(struct rt2x00_dev *rt2x00dev)
{
	int status;

	/*
	 * Don't enable the radio twice.
	 * And check if the hardware button has been disabled.
	 */
44
	if (test_bit(DEVICE_STATE_ENABLED_RADIO, &rt2x00dev->flags))
45 46
		return 0;

47
	/*
I
Ivo van Doorn 已提交
48
	 * Initialize all data queues.
49
	 */
50
	rt2x00queue_init_queues(rt2x00dev);
51

52 53 54
	/*
	 * Enable radio.
	 */
55 56
	status =
	    rt2x00dev->ops->lib->set_device_state(rt2x00dev, STATE_RADIO_ON);
57 58 59
	if (status)
		return status;

60 61
	rt2x00dev->ops->lib->set_device_state(rt2x00dev, STATE_RADIO_IRQ_ON);

62
	rt2x00leds_led_radio(rt2x00dev, true);
63
	rt2x00led_led_activity(rt2x00dev, true);
64

65
	set_bit(DEVICE_STATE_ENABLED_RADIO, &rt2x00dev->flags);
66 67 68 69

	/*
	 * Enable RX.
	 */
70
	rt2x00lib_toggle_rx(rt2x00dev, STATE_RADIO_RX_ON);
71

72 73 74 75 76
	/*
	 * Start watchdog monitoring.
	 */
	rt2x00link_start_watchdog(rt2x00dev);

77 78 79
	/*
	 * Start the TX queues.
	 */
80
	ieee80211_wake_queues(rt2x00dev->hw);
81 82 83 84 85 86

	return 0;
}

void rt2x00lib_disable_radio(struct rt2x00_dev *rt2x00dev)
{
87
	if (!test_and_clear_bit(DEVICE_STATE_ENABLED_RADIO, &rt2x00dev->flags))
88 89 90
		return;

	/*
91
	 * Stop the TX queues in mac80211.
92 93
	 */
	ieee80211_stop_queues(rt2x00dev->hw);
94
	rt2x00queue_stop_queues(rt2x00dev);
95

96 97 98 99 100
	/*
	 * Stop watchdog monitoring.
	 */
	rt2x00link_stop_watchdog(rt2x00dev);

101 102 103
	/*
	 * Disable RX.
	 */
104
	rt2x00lib_toggle_rx(rt2x00dev, STATE_RADIO_RX_OFF);
105 106 107 108 109

	/*
	 * Disable radio.
	 */
	rt2x00dev->ops->lib->set_device_state(rt2x00dev, STATE_RADIO_OFF);
110
	rt2x00dev->ops->lib->set_device_state(rt2x00dev, STATE_RADIO_IRQ_OFF);
111
	rt2x00led_led_activity(rt2x00dev, false);
112
	rt2x00leds_led_radio(rt2x00dev, false);
113 114
}

115
void rt2x00lib_toggle_rx(struct rt2x00_dev *rt2x00dev, enum dev_state state)
116 117 118 119
{
	/*
	 * When we are disabling the RX, we should also stop the link tuner.
	 */
120
	if (state == STATE_RADIO_RX_OFF)
121
		rt2x00link_stop_tuner(rt2x00dev);
122 123 124 125 126 127

	rt2x00dev->ops->lib->set_device_state(rt2x00dev, state);

	/*
	 * When we are enabling the RX, we should also start the link tuner.
	 */
128 129
	if (state == STATE_RADIO_RX_ON)
		rt2x00link_start_tuner(rt2x00dev);
130 131
}

132 133
static void rt2x00lib_intf_scheduled_iter(void *data, u8 *mac,
					  struct ieee80211_vif *vif)
134
{
135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150
	struct rt2x00_dev *rt2x00dev = data;
	struct rt2x00_intf *intf = vif_to_intf(vif);
	int delayed_flags;

	/*
	 * Copy all data we need during this action under the protection
	 * of a spinlock. Otherwise race conditions might occur which results
	 * into an invalid configuration.
	 */
	spin_lock(&intf->lock);

	delayed_flags = intf->delayed_flags;
	intf->delayed_flags = 0;

	spin_unlock(&intf->lock);

151 152 153 154 155 156
	/*
	 * It is possible the radio was disabled while the work had been
	 * scheduled. If that happens we should return here immediately,
	 * note that in the spinlock protected area above the delayed_flags
	 * have been cleared correctly.
	 */
157
	if (!test_bit(DEVICE_STATE_ENABLED_RADIO, &rt2x00dev->flags))
158 159
		return;

160
	if (delayed_flags & DELAYED_UPDATE_BEACON)
161
		rt2x00queue_update_beacon(rt2x00dev, vif, true);
162
}
163

164 165 166 167
static void rt2x00lib_intf_scheduled(struct work_struct *work)
{
	struct rt2x00_dev *rt2x00dev =
	    container_of(work, struct rt2x00_dev, intf_work);
168 169

	/*
170 171
	 * Iterate over each interface and perform the
	 * requested configurations.
172
	 */
173 174 175
	ieee80211_iterate_active_interfaces(rt2x00dev->hw,
					    rt2x00lib_intf_scheduled_iter,
					    rt2x00dev);
176 177
}

178 179 180
/*
 * Interrupt context handlers.
 */
181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202
static void rt2x00lib_bc_buffer_iter(void *data, u8 *mac,
				     struct ieee80211_vif *vif)
{
	struct rt2x00_dev *rt2x00dev = data;
	struct sk_buff *skb;

	/*
	 * Only AP mode interfaces do broad- and multicast buffering
	 */
	if (vif->type != NL80211_IFTYPE_AP)
		return;

	/*
	 * Send out buffered broad- and multicast frames
	 */
	skb = ieee80211_get_buffered_bc(rt2x00dev->hw, vif);
	while (skb) {
		rt2x00mac_tx(rt2x00dev->hw, skb);
		skb = ieee80211_get_buffered_bc(rt2x00dev->hw, vif);
	}
}

203 204
static void rt2x00lib_beacondone_iter(void *data, u8 *mac,
				      struct ieee80211_vif *vif)
205
{
206
	struct rt2x00_dev *rt2x00dev = data;
207

208
	if (vif->type != NL80211_IFTYPE_AP &&
A
Andrey Yurovsky 已提交
209
	    vif->type != NL80211_IFTYPE_ADHOC &&
I
Ivo van Doorn 已提交
210 211
	    vif->type != NL80211_IFTYPE_MESH_POINT &&
	    vif->type != NL80211_IFTYPE_WDS)
212 213
		return;

214
	rt2x00queue_update_beacon(rt2x00dev, vif, true);
215 216 217 218
}

void rt2x00lib_beacondone(struct rt2x00_dev *rt2x00dev)
{
219
	if (!test_bit(DEVICE_STATE_ENABLED_RADIO, &rt2x00dev->flags))
220 221
		return;

222
	/* send buffered bc/mc frames out for every bssid */
223
	ieee80211_iterate_active_interfaces(rt2x00dev->hw,
224 225 226 227 228 229 230
					    rt2x00lib_bc_buffer_iter,
					    rt2x00dev);

	/* fetch next beacon */
	ieee80211_iterate_active_interfaces(rt2x00dev->hw,
					    rt2x00lib_beacondone_iter,
					    rt2x00dev);
231

232 233 234
}
EXPORT_SYMBOL_GPL(rt2x00lib_beacondone);

I
Ivo van Doorn 已提交
235 236
void rt2x00lib_txdone(struct queue_entry *entry,
		      struct txdone_entry_desc *txdesc)
237
{
I
Ivo van Doorn 已提交
238
	struct rt2x00_dev *rt2x00dev = entry->queue->rt2x00dev;
239
	struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(entry->skb);
240
	struct skb_frame_desc *skbdesc = get_skb_frame_desc(entry->skb);
I
Ivo van Doorn 已提交
241
	enum data_queue_qid qid = skb_get_queue_mapping(entry->skb);
242
	unsigned int header_length = ieee80211_get_hdrlen_from_skb(entry->skb);
243
	u8 rate_idx, rate_flags, retry_rates;
244
	u8 skbdesc_flags = skbdesc->flags;
245
	unsigned int i;
I
Ivo van Doorn 已提交
246
	bool success;
I
Ivo van Doorn 已提交
247

248 249 250 251 252 253 254 255 256 257 258 259 260 261 262
	/*
	 * Unmap the skb.
	 */
	rt2x00queue_unmap_skb(rt2x00dev, entry->skb);

	/*
	 * Remove the extra tx headroom from the skb.
	 */
	skb_pull(entry->skb, rt2x00dev->ops->extra_tx_headroom);

	/*
	 * Signal that the TX descriptor is no longer in the skb.
	 */
	skbdesc->flags &= ~SKBDESC_DESC_IN_SKB;

263 264 265 266
	/*
	 * Remove L2 padding which was added during
	 */
	if (test_bit(DRIVER_REQUIRE_L2PAD, &rt2x00dev->flags))
267
		rt2x00queue_remove_l2pad(entry->skb, header_length);
268

I
Ivo van Doorn 已提交
269 270 271
	/*
	 * If the IV/EIV data was stripped from the frame before it was
	 * passed to the hardware, we should now reinsert it again because
272
	 * mac80211 will expect the same data to be present it the
I
Ivo van Doorn 已提交
273 274 275
	 * frame as it was passed to us.
	 */
	if (test_bit(CONFIG_SUPPORT_HW_CRYPTO, &rt2x00dev->flags))
276
		rt2x00crypto_tx_insert_iv(entry->skb, header_length);
I
Ivo van Doorn 已提交
277

278 279 280 281 282
	/*
	 * Send frame to debugfs immediately, after this call is completed
	 * we are going to overwrite the skb->cb array.
	 */
	rt2x00debug_dump_frame(rt2x00dev, DUMP_FRAME_TXDONE, entry->skb);
283 284

	/*
I
Ivo van Doorn 已提交
285
	 * Determine if the frame has been successfully transmitted.
286
	 */
I
Ivo van Doorn 已提交
287
	success =
288
	    test_bit(TXDONE_SUCCESS, &txdesc->flags) ||
289
	    test_bit(TXDONE_UNKNOWN, &txdesc->flags);
I
Ivo van Doorn 已提交
290 291 292 293 294 295

	/*
	 * Update TX statistics.
	 */
	rt2x00dev->link.qual.tx_success += success;
	rt2x00dev->link.qual.tx_failed += !success;
296

297 298
	rate_idx = skbdesc->tx_rate_idx;
	rate_flags = skbdesc->tx_rate_flags;
299 300
	retry_rates = test_bit(TXDONE_FALLBACK, &txdesc->flags) ?
	    (txdesc->retry + 1) : 1;
301

I
Ivo van Doorn 已提交
302 303 304
	/*
	 * Initialize TX status
	 */
305 306
	memset(&tx_info->status, 0, sizeof(tx_info->status));
	tx_info->status.ack_signal = 0;
307 308 309 310

	/*
	 * Frame was send with retries, hardware tried
	 * different rates to send out the frame, at each
311 312
	 * retry it lowered the rate 1 step except when the
	 * lowest rate was used.
313 314 315 316
	 */
	for (i = 0; i < retry_rates && i < IEEE80211_TX_MAX_RATES; i++) {
		tx_info->status.rates[i].idx = rate_idx - i;
		tx_info->status.rates[i].flags = rate_flags;
317 318 319 320 321 322 323 324 325 326

		if (rate_idx - i == 0) {
			/*
			 * The lowest rate (index 0) was used until the
			 * number of max retries was reached.
			 */
			tx_info->status.rates[i].count = retry_rates - i;
			i++;
			break;
		}
327 328
		tx_info->status.rates[i].count = 1;
	}
I
Ivo van Doorn 已提交
329
	if (i < (IEEE80211_TX_MAX_RATES - 1))
330
		tx_info->status.rates[i].idx = -1; /* terminate */
I
Ivo van Doorn 已提交
331

332
	if (!(tx_info->flags & IEEE80211_TX_CTL_NO_ACK)) {
I
Ivo van Doorn 已提交
333
		if (success)
334
			tx_info->flags |= IEEE80211_TX_STAT_ACK;
I
Ivo van Doorn 已提交
335
		else
I
Ivo van Doorn 已提交
336
			rt2x00dev->low_level_stats.dot11ACKFailureCount++;
337 338
	}

339 340 341 342 343 344 345 346 347 348 349 350 351 352 353
	/*
	 * Every single frame has it's own tx status, hence report
	 * every frame as ampdu of size 1.
	 *
	 * TODO: if we can find out how many frames were aggregated
	 * by the hw we could provide the real ampdu_len to mac80211
	 * which would allow the rc algorithm to better decide on
	 * which rates are suitable.
	 */
	if (tx_info->flags & IEEE80211_TX_CTL_AMPDU) {
		tx_info->flags |= IEEE80211_TX_STAT_AMPDU;
		tx_info->status.ampdu_len = 1;
		tx_info->status.ampdu_ack_len = success ? 1 : 0;
	}

354
	if (rate_flags & IEEE80211_TX_RC_USE_RTS_CTS) {
I
Ivo van Doorn 已提交
355
		if (success)
I
Ivo van Doorn 已提交
356
			rt2x00dev->low_level_stats.dot11RTSSuccessCount++;
I
Ivo van Doorn 已提交
357
		else
I
Ivo van Doorn 已提交
358
			rt2x00dev->low_level_stats.dot11RTSFailureCount++;
359 360 361
	}

	/*
362 363 364 365
	 * Only send the status report to mac80211 when it's a frame
	 * that originated in mac80211. If this was a extra frame coming
	 * through a mac80211 library call (RTS/CTS) then we should not
	 * send the status report back.
366
	 */
367
	if (!(skbdesc_flags & SKBDESC_NOT_MAC80211))
368 369 370 371 372 373 374 375 376
		/*
		 * Only PCI and SOC devices process the tx status in process
		 * context. Hence use ieee80211_tx_status for PCI and SOC
		 * devices and stick to ieee80211_tx_status_irqsafe for USB.
		 */
		if (rt2x00_is_usb(rt2x00dev))
			ieee80211_tx_status_irqsafe(rt2x00dev->hw, entry->skb);
		else
			ieee80211_tx_status(rt2x00dev->hw, entry->skb);
377
	else
378
		dev_kfree_skb_any(entry->skb);
I
Ivo van Doorn 已提交
379 380 381 382

	/*
	 * Make this entry available for reuse.
	 */
383
	entry->skb = NULL;
I
Ivo van Doorn 已提交
384 385
	entry->flags = 0;

386
	rt2x00dev->ops->lib->clear_entry(entry);
I
Ivo van Doorn 已提交
387

388
	clear_bit(ENTRY_OWNER_DEVICE_DATA, &entry->flags);
I
Ivo van Doorn 已提交
389 390 391 392 393 394 395 396 397
	rt2x00queue_index_inc(entry->queue, Q_INDEX_DONE);

	/*
	 * If the data queue was below the threshold before the txdone
	 * handler we must make sure the packet queue in the mac80211 stack
	 * is reenabled when the txdone handler has finished.
	 */
	if (!rt2x00queue_threshold(entry->queue))
		ieee80211_wake_queue(rt2x00dev->hw, qid);
398 399 400
}
EXPORT_SYMBOL_GPL(rt2x00lib_txdone);

401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439
static int rt2x00lib_rxdone_read_signal(struct rt2x00_dev *rt2x00dev,
					struct rxdone_entry_desc *rxdesc)
{
	struct ieee80211_supported_band *sband;
	const struct rt2x00_rate *rate;
	unsigned int i;
	int signal;
	int type;

	/*
	 * For non-HT rates the MCS value needs to contain the
	 * actually used rate modulation (CCK or OFDM).
	 */
	if (rxdesc->dev_flags & RXDONE_SIGNAL_MCS)
		signal = RATE_MCS(rxdesc->rate_mode, rxdesc->signal);
	else
		signal = rxdesc->signal;

	type = (rxdesc->dev_flags & RXDONE_SIGNAL_MASK);

	sband = &rt2x00dev->bands[rt2x00dev->curr_band];
	for (i = 0; i < sband->n_bitrates; i++) {
		rate = rt2x00_get_rate(sband->bitrates[i].hw_value);

		if (((type == RXDONE_SIGNAL_PLCP) &&
		     (rate->plcp == signal)) ||
		    ((type == RXDONE_SIGNAL_BITRATE) &&
		      (rate->bitrate == signal)) ||
		    ((type == RXDONE_SIGNAL_MCS) &&
		      (rate->mcs == signal))) {
			return i;
		}
	}

	WARNING(rt2x00dev, "Frame received with unrecognized signal, "
		"signal=0x%.4x, type=%d.\n", signal, type);
	return 0;
}

440 441
void rt2x00lib_rxdone(struct rt2x00_dev *rt2x00dev,
		      struct queue_entry *entry)
442
{
443 444
	struct rxdone_entry_desc rxdesc;
	struct sk_buff *skb;
445
	struct ieee80211_rx_status *rx_status = &rt2x00dev->rx_status;
I
Ivo van Doorn 已提交
446
	unsigned int header_length;
447
	int rate_idx;
448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465
	/*
	 * Allocate a new sk_buffer. If no new buffer available, drop the
	 * received frame and reuse the existing buffer.
	 */
	skb = rt2x00queue_alloc_rxskb(rt2x00dev, entry);
	if (!skb)
		return;

	/*
	 * Unmap the skb.
	 */
	rt2x00queue_unmap_skb(rt2x00dev, entry->skb);

	/*
	 * Extract the RXD details.
	 */
	memset(&rxdesc, 0, sizeof(rxdesc));
	rt2x00dev->ops->lib->fill_rxdone(entry, &rxdesc);
466

467 468
	/*
	 * The data behind the ieee80211 header must be
469
	 * aligned on a 4 byte boundary.
470
	 */
I
Ivo van Doorn 已提交
471
	header_length = ieee80211_get_hdrlen_from_skb(entry->skb);
472

I
Ivo van Doorn 已提交
473 474 475
	/*
	 * Hardware might have stripped the IV/EIV/ICV data,
	 * in that case it is possible that the data was
D
Daniel Mack 已提交
476
	 * provided separately (through hardware descriptor)
I
Ivo van Doorn 已提交
477 478
	 * in which case we should reinsert the data into the frame.
	 */
479
	if ((rxdesc.dev_flags & RXDONE_CRYPTO_IV) &&
480
	    (rxdesc.flags & RX_FLAG_IV_STRIPPED))
481
		rt2x00crypto_rx_insert_iv(entry->skb, header_length,
482
					  &rxdesc);
483 484 485
	else if (header_length &&
		 (rxdesc.size > header_length) &&
		 (rxdesc.dev_flags & RXDONE_L2PAD))
486
		rt2x00queue_remove_l2pad(entry->skb, header_length);
487
	else
488
		rt2x00queue_align_payload(entry->skb, header_length);
489

490 491 492
	/* Trim buffer to correct size */
	skb_trim(entry->skb, rxdesc.size);

493
	/*
494 495 496 497
	 * Check if the frame was received using HT. In that case,
	 * the rate is the MCS index and should be passed to mac80211
	 * directly. Otherwise we need to translate the signal to
	 * the correct bitrate index.
498
	 */
499 500 501 502 503 504
	if (rxdesc.rate_mode == RATE_MODE_CCK ||
	    rxdesc.rate_mode == RATE_MODE_OFDM) {
		rate_idx = rt2x00lib_rxdone_read_signal(rt2x00dev, &rxdesc);
	} else {
		rxdesc.flags |= RX_FLAG_HT;
		rate_idx = rxdesc.signal;
505 506
	}

507
	/*
508
	 * Update extra components
509
	 */
510 511
	rt2x00link_update_stats(rt2x00dev, entry->skb, &rxdesc);
	rt2x00debug_update_crypto(rt2x00dev, &rxdesc);
512

513
	rx_status->mactime = rxdesc.timestamp;
514
	rx_status->rate_idx = rate_idx;
515 516
	rx_status->signal = rxdesc.rssi;
	rx_status->flag = rxdesc.flags;
517
	rx_status->antenna = rt2x00dev->link.ant.active.rx;
518 519

	/*
I
Ivo van Doorn 已提交
520 521
	 * Send frame to mac80211 & debugfs.
	 * mac80211 will clean up the skb structure.
522
	 */
523
	rt2x00debug_dump_frame(rt2x00dev, DUMP_FRAME_RXDONE, entry->skb);
524
	memcpy(IEEE80211_SKB_RXCB(entry->skb), rx_status, sizeof(*rx_status));
525 526 527 528 529 530 531 532 533 534

	/*
	 * Currently only PCI and SOC devices handle rx interrupts in process
	 * context. Hence, use ieee80211_rx_irqsafe for USB and ieee80211_rx_ni
	 * for PCI and SOC devices.
	 */
	if (rt2x00_is_usb(rt2x00dev))
		ieee80211_rx_irqsafe(rt2x00dev->hw, entry->skb);
	else
		ieee80211_rx_ni(rt2x00dev->hw, entry->skb);
535 536 537 538 539

	/*
	 * Replace the skb with the freshly allocated one.
	 */
	entry->skb = skb;
I
Ivo van Doorn 已提交
540 541
	entry->flags = 0;

542
	rt2x00dev->ops->lib->clear_entry(entry);
I
Ivo van Doorn 已提交
543 544

	rt2x00queue_index_inc(entry->queue, Q_INDEX);
545 546 547 548 549 550
}
EXPORT_SYMBOL_GPL(rt2x00lib_rxdone);

/*
 * Driver initialization handlers.
 */
I
Ivo van Doorn 已提交
551 552
const struct rt2x00_rate rt2x00_supported_rates[12] = {
	{
I
Ivo van Doorn 已提交
553
		.flags = DEV_RATE_CCK,
I
Ivo van Doorn 已提交
554
		.bitrate = 10,
555
		.ratemask = BIT(0),
I
Ivo van Doorn 已提交
556
		.plcp = 0x00,
557
		.mcs = RATE_MCS(RATE_MODE_CCK, 0),
I
Ivo van Doorn 已提交
558 559
	},
	{
I
Ivo van Doorn 已提交
560
		.flags = DEV_RATE_CCK | DEV_RATE_SHORT_PREAMBLE,
I
Ivo van Doorn 已提交
561
		.bitrate = 20,
562
		.ratemask = BIT(1),
I
Ivo van Doorn 已提交
563
		.plcp = 0x01,
564
		.mcs = RATE_MCS(RATE_MODE_CCK, 1),
I
Ivo van Doorn 已提交
565 566
	},
	{
I
Ivo van Doorn 已提交
567
		.flags = DEV_RATE_CCK | DEV_RATE_SHORT_PREAMBLE,
I
Ivo van Doorn 已提交
568
		.bitrate = 55,
569
		.ratemask = BIT(2),
I
Ivo van Doorn 已提交
570
		.plcp = 0x02,
571
		.mcs = RATE_MCS(RATE_MODE_CCK, 2),
I
Ivo van Doorn 已提交
572 573
	},
	{
I
Ivo van Doorn 已提交
574
		.flags = DEV_RATE_CCK | DEV_RATE_SHORT_PREAMBLE,
I
Ivo van Doorn 已提交
575
		.bitrate = 110,
576
		.ratemask = BIT(3),
I
Ivo van Doorn 已提交
577
		.plcp = 0x03,
578
		.mcs = RATE_MCS(RATE_MODE_CCK, 3),
I
Ivo van Doorn 已提交
579 580
	},
	{
I
Ivo van Doorn 已提交
581
		.flags = DEV_RATE_OFDM,
I
Ivo van Doorn 已提交
582
		.bitrate = 60,
583
		.ratemask = BIT(4),
I
Ivo van Doorn 已提交
584
		.plcp = 0x0b,
585
		.mcs = RATE_MCS(RATE_MODE_OFDM, 0),
I
Ivo van Doorn 已提交
586 587 588 589
	},
	{
		.flags = DEV_RATE_OFDM,
		.bitrate = 90,
590
		.ratemask = BIT(5),
I
Ivo van Doorn 已提交
591
		.plcp = 0x0f,
592
		.mcs = RATE_MCS(RATE_MODE_OFDM, 1),
I
Ivo van Doorn 已提交
593 594
	},
	{
I
Ivo van Doorn 已提交
595
		.flags = DEV_RATE_OFDM,
I
Ivo van Doorn 已提交
596
		.bitrate = 120,
597
		.ratemask = BIT(6),
I
Ivo van Doorn 已提交
598
		.plcp = 0x0a,
599
		.mcs = RATE_MCS(RATE_MODE_OFDM, 2),
I
Ivo van Doorn 已提交
600 601 602 603
	},
	{
		.flags = DEV_RATE_OFDM,
		.bitrate = 180,
604
		.ratemask = BIT(7),
I
Ivo van Doorn 已提交
605
		.plcp = 0x0e,
606
		.mcs = RATE_MCS(RATE_MODE_OFDM, 3),
I
Ivo van Doorn 已提交
607 608
	},
	{
I
Ivo van Doorn 已提交
609
		.flags = DEV_RATE_OFDM,
I
Ivo van Doorn 已提交
610
		.bitrate = 240,
611
		.ratemask = BIT(8),
I
Ivo van Doorn 已提交
612
		.plcp = 0x09,
613
		.mcs = RATE_MCS(RATE_MODE_OFDM, 4),
I
Ivo van Doorn 已提交
614 615 616 617
	},
	{
		.flags = DEV_RATE_OFDM,
		.bitrate = 360,
618
		.ratemask = BIT(9),
I
Ivo van Doorn 已提交
619
		.plcp = 0x0d,
620
		.mcs = RATE_MCS(RATE_MODE_OFDM, 5),
I
Ivo van Doorn 已提交
621 622 623 624
	},
	{
		.flags = DEV_RATE_OFDM,
		.bitrate = 480,
625
		.ratemask = BIT(10),
I
Ivo van Doorn 已提交
626
		.plcp = 0x08,
627
		.mcs = RATE_MCS(RATE_MODE_OFDM, 6),
I
Ivo van Doorn 已提交
628 629 630 631
	},
	{
		.flags = DEV_RATE_OFDM,
		.bitrate = 540,
632
		.ratemask = BIT(11),
I
Ivo van Doorn 已提交
633
		.plcp = 0x0c,
634
		.mcs = RATE_MCS(RATE_MODE_OFDM, 7),
I
Ivo van Doorn 已提交
635 636 637
	},
};

638 639 640 641
static void rt2x00lib_channel(struct ieee80211_channel *entry,
			      const int channel, const int tx_power,
			      const int value)
{
642
	entry->center_freq = ieee80211_channel_to_frequency(channel);
643 644 645
	entry->hw_value = value;
	entry->max_power = tx_power;
	entry->max_antenna_gain = 0xff;
646 647 648
}

static void rt2x00lib_rate(struct ieee80211_rate *entry,
I
Ivo van Doorn 已提交
649
			   const u16 index, const struct rt2x00_rate *rate)
650
{
I
Ivo van Doorn 已提交
651 652
	entry->flags = 0;
	entry->bitrate = rate->bitrate;
653 654
	entry->hw_value =index;
	entry->hw_value_short = index;
I
Ivo van Doorn 已提交
655

656
	if (rate->flags & DEV_RATE_SHORT_PREAMBLE)
I
Ivo van Doorn 已提交
657
		entry->flags |= IEEE80211_RATE_SHORT_PREAMBLE;
658 659 660 661 662 663 664 665
}

static int rt2x00lib_probe_hw_modes(struct rt2x00_dev *rt2x00dev,
				    struct hw_mode_spec *spec)
{
	struct ieee80211_hw *hw = rt2x00dev->hw;
	struct ieee80211_channel *channels;
	struct ieee80211_rate *rates;
666
	unsigned int num_rates;
667 668
	unsigned int i;

669 670 671 672 673
	num_rates = 0;
	if (spec->supported_rates & SUPPORT_RATE_CCK)
		num_rates += 4;
	if (spec->supported_rates & SUPPORT_RATE_OFDM)
		num_rates += 8;
674 675 676

	channels = kzalloc(sizeof(*channels) * spec->num_channels, GFP_KERNEL);
	if (!channels)
677
		return -ENOMEM;
678

679
	rates = kzalloc(sizeof(*rates) * num_rates, GFP_KERNEL);
680 681 682 683 684 685
	if (!rates)
		goto exit_free_channels;

	/*
	 * Initialize Rate list.
	 */
686
	for (i = 0; i < num_rates; i++)
I
Ivo van Doorn 已提交
687
		rt2x00lib_rate(&rates[i], i, rt2x00_get_rate(i));
688 689 690 691 692 693

	/*
	 * Initialize Channel list.
	 */
	for (i = 0; i < spec->num_channels; i++) {
		rt2x00lib_channel(&channels[i],
694 695
				  spec->channels[i].channel,
				  spec->channels_info[i].tx_power1, i);
696 697 698
	}

	/*
699
	 * Intitialize 802.11b, 802.11g
700
	 * Rates: CCK, OFDM.
701
	 * Channels: 2.4 GHz
702
	 */
703
	if (spec->supported_bands & SUPPORT_BAND_2GHZ) {
704 705 706 707 708 709
		rt2x00dev->bands[IEEE80211_BAND_2GHZ].n_channels = 14;
		rt2x00dev->bands[IEEE80211_BAND_2GHZ].n_bitrates = num_rates;
		rt2x00dev->bands[IEEE80211_BAND_2GHZ].channels = channels;
		rt2x00dev->bands[IEEE80211_BAND_2GHZ].bitrates = rates;
		hw->wiphy->bands[IEEE80211_BAND_2GHZ] =
		    &rt2x00dev->bands[IEEE80211_BAND_2GHZ];
710 711
		memcpy(&rt2x00dev->bands[IEEE80211_BAND_2GHZ].ht_cap,
		       &spec->ht, sizeof(spec->ht));
712 713 714 715 716 717 718
	}

	/*
	 * Intitialize 802.11a
	 * Rates: OFDM.
	 * Channels: OFDM, UNII, HiperLAN2.
	 */
719
	if (spec->supported_bands & SUPPORT_BAND_5GHZ) {
720 721 722 723 724 725 726 727
		rt2x00dev->bands[IEEE80211_BAND_5GHZ].n_channels =
		    spec->num_channels - 14;
		rt2x00dev->bands[IEEE80211_BAND_5GHZ].n_bitrates =
		    num_rates - 4;
		rt2x00dev->bands[IEEE80211_BAND_5GHZ].channels = &channels[14];
		rt2x00dev->bands[IEEE80211_BAND_5GHZ].bitrates = &rates[4];
		hw->wiphy->bands[IEEE80211_BAND_5GHZ] =
		    &rt2x00dev->bands[IEEE80211_BAND_5GHZ];
728 729
		memcpy(&rt2x00dev->bands[IEEE80211_BAND_5GHZ].ht_cap,
		       &spec->ht, sizeof(spec->ht));
730 731 732 733
	}

	return 0;

734
 exit_free_channels:
735 736 737 738 739 740 741
	kfree(channels);
	ERROR(rt2x00dev, "Allocation ieee80211 modes failed.\n");
	return -ENOMEM;
}

static void rt2x00lib_remove_hw(struct rt2x00_dev *rt2x00dev)
{
742
	if (test_bit(DEVICE_STATE_REGISTERED_HW, &rt2x00dev->flags))
743 744
		ieee80211_unregister_hw(rt2x00dev->hw);

745 746 747 748 749
	if (likely(rt2x00dev->hw->wiphy->bands[IEEE80211_BAND_2GHZ])) {
		kfree(rt2x00dev->hw->wiphy->bands[IEEE80211_BAND_2GHZ]->channels);
		kfree(rt2x00dev->hw->wiphy->bands[IEEE80211_BAND_2GHZ]->bitrates);
		rt2x00dev->hw->wiphy->bands[IEEE80211_BAND_2GHZ] = NULL;
		rt2x00dev->hw->wiphy->bands[IEEE80211_BAND_5GHZ] = NULL;
750
	}
751 752

	kfree(rt2x00dev->spec.channels_info);
753 754 755 756 757 758 759
}

static int rt2x00lib_probe_hw(struct rt2x00_dev *rt2x00dev)
{
	struct hw_mode_spec *spec = &rt2x00dev->spec;
	int status;

760 761 762
	if (test_bit(DEVICE_STATE_REGISTERED_HW, &rt2x00dev->flags))
		return 0;

763 764 765 766 767 768 769
	/*
	 * Initialize HW modes.
	 */
	status = rt2x00lib_probe_hw_modes(rt2x00dev, spec);
	if (status)
		return status;

770 771 772 773 774
	/*
	 * Initialize HW fields.
	 */
	rt2x00dev->hw->queues = rt2x00dev->ops->tx_queues;

775 776 777
	/*
	 * Initialize extra TX headroom required.
	 */
778 779 780 781 782 783 784 785 786 787 788
	rt2x00dev->hw->extra_tx_headroom =
		max_t(unsigned int, IEEE80211_TX_STATUS_HEADROOM,
		      rt2x00dev->ops->extra_tx_headroom);

	/*
	 * Take TX headroom required for alignment into account.
	 */
	if (test_bit(DRIVER_REQUIRE_L2PAD, &rt2x00dev->flags))
		rt2x00dev->hw->extra_tx_headroom += RT2X00_L2PAD_SIZE;
	else if (test_bit(DRIVER_REQUIRE_DMA, &rt2x00dev->flags))
		rt2x00dev->hw->extra_tx_headroom += RT2X00_ALIGN_SIZE;
789

790 791 792 793
	/*
	 * Register HW.
	 */
	status = ieee80211_register_hw(rt2x00dev->hw);
794
	if (status)
795 796
		return status;

797
	set_bit(DEVICE_STATE_REGISTERED_HW, &rt2x00dev->flags);
798 799 800 801 802 803 804

	return 0;
}

/*
 * Initialization/uninitialization handlers.
 */
805
static void rt2x00lib_uninitialize(struct rt2x00_dev *rt2x00dev)
806
{
807
	if (!test_and_clear_bit(DEVICE_STATE_INITIALIZED, &rt2x00dev->flags))
808 809 810
		return;

	/*
811
	 * Unregister extra components.
812 813 814 815 816 817 818 819 820
	 */
	rt2x00rfkill_unregister(rt2x00dev);

	/*
	 * Allow the HW to uninitialize.
	 */
	rt2x00dev->ops->lib->uninitialize(rt2x00dev);

	/*
I
Ivo van Doorn 已提交
821
	 * Free allocated queue entries.
822
	 */
I
Ivo van Doorn 已提交
823
	rt2x00queue_uninitialize(rt2x00dev);
824 825
}

826
static int rt2x00lib_initialize(struct rt2x00_dev *rt2x00dev)
827 828 829
{
	int status;

830
	if (test_bit(DEVICE_STATE_INITIALIZED, &rt2x00dev->flags))
831 832 833
		return 0;

	/*
I
Ivo van Doorn 已提交
834
	 * Allocate all queue entries.
835
	 */
I
Ivo van Doorn 已提交
836 837
	status = rt2x00queue_initialize(rt2x00dev);
	if (status)
838 839 840 841 842 843
		return status;

	/*
	 * Initialize the device.
	 */
	status = rt2x00dev->ops->lib->initialize(rt2x00dev);
844 845 846 847
	if (status) {
		rt2x00queue_uninitialize(rt2x00dev);
		return status;
	}
848

849
	set_bit(DEVICE_STATE_INITIALIZED, &rt2x00dev->flags);
850 851

	/*
852
	 * Register the extra components.
853
	 */
854
	rt2x00rfkill_register(rt2x00dev);
855 856 857 858

	return 0;
}

859 860 861 862
int rt2x00lib_start(struct rt2x00_dev *rt2x00dev)
{
	int retval;

863
	if (test_bit(DEVICE_STATE_STARTED, &rt2x00dev->flags))
864 865 866 867 868 869
		return 0;

	/*
	 * If this is the first interface which is added,
	 * we should load the firmware now.
	 */
870 871 872
	retval = rt2x00lib_load_firmware(rt2x00dev);
	if (retval)
		return retval;
873 874 875 876 877 878 879 880

	/*
	 * Initialize the device.
	 */
	retval = rt2x00lib_initialize(rt2x00dev);
	if (retval)
		return retval;

881 882 883 884
	rt2x00dev->intf_ap_count = 0;
	rt2x00dev->intf_sta_count = 0;
	rt2x00dev->intf_associated = 0;

885 886 887 888 889 890 891
	/* Enable the radio */
	retval = rt2x00lib_enable_radio(rt2x00dev);
	if (retval) {
		rt2x00queue_uninitialize(rt2x00dev);
		return retval;
	}

892
	set_bit(DEVICE_STATE_STARTED, &rt2x00dev->flags);
893 894 895 896 897 898

	return 0;
}

void rt2x00lib_stop(struct rt2x00_dev *rt2x00dev)
{
899
	if (!test_and_clear_bit(DEVICE_STATE_STARTED, &rt2x00dev->flags))
900 901 902 903 904 905 906 907
		return;

	/*
	 * Perhaps we can add something smarter here,
	 * but for now just disabling the radio should do.
	 */
	rt2x00lib_disable_radio(rt2x00dev);

908 909 910
	rt2x00dev->intf_ap_count = 0;
	rt2x00dev->intf_sta_count = 0;
	rt2x00dev->intf_associated = 0;
911 912
}

913 914 915 916 917 918 919
/*
 * driver allocation handlers.
 */
int rt2x00lib_probe_dev(struct rt2x00_dev *rt2x00dev)
{
	int retval = -ENOMEM;

920 921
	mutex_init(&rt2x00dev->csr_mutex);

922 923
	set_bit(DEVICE_STATE_PRESENT, &rt2x00dev->flags);

924 925 926 927 928 929
	/*
	 * Make room for rt2x00_intf inside the per-interface
	 * structure ieee80211_vif.
	 */
	rt2x00dev->hw->vif_data_size = sizeof(struct rt2x00_intf);

930 931 932 933 934 935 936 937 938
	/*
	 * Determine which operating modes are supported, all modes
	 * which require beaconing, depend on the availability of
	 * beacon entries.
	 */
	rt2x00dev->hw->wiphy->interface_modes = BIT(NL80211_IFTYPE_STATION);
	if (rt2x00dev->ops->bcn->entry_num > 0)
		rt2x00dev->hw->wiphy->interface_modes |=
		    BIT(NL80211_IFTYPE_ADHOC) |
A
Andrey Yurovsky 已提交
939
		    BIT(NL80211_IFTYPE_AP) |
I
Ivo van Doorn 已提交
940 941
		    BIT(NL80211_IFTYPE_MESH_POINT) |
		    BIT(NL80211_IFTYPE_WDS);
942

943 944 945 946 947 948 949 950 951 952 953 954
	/*
	 * Let the driver probe the device to detect the capabilities.
	 */
	retval = rt2x00dev->ops->lib->probe_hw(rt2x00dev);
	if (retval) {
		ERROR(rt2x00dev, "Failed to allocate device.\n");
		goto exit;
	}

	/*
	 * Initialize configuration work.
	 */
955
	INIT_WORK(&rt2x00dev->intf_work, rt2x00lib_intf_scheduled);
956 957

	/*
I
Ivo van Doorn 已提交
958
	 * Allocate queue array.
959
	 */
I
Ivo van Doorn 已提交
960
	retval = rt2x00queue_allocate(rt2x00dev);
961 962 963 964 965 966 967 968 969 970 971 972
	if (retval)
		goto exit;

	/*
	 * Initialize ieee80211 structure.
	 */
	retval = rt2x00lib_probe_hw(rt2x00dev);
	if (retval) {
		ERROR(rt2x00dev, "Failed to initialize hw.\n");
		goto exit;
	}

973
	/*
974
	 * Register extra components.
975
	 */
976
	rt2x00link_register(rt2x00dev);
977
	rt2x00leds_register(rt2x00dev);
978 979 980 981 982 983 984 985 986 987 988 989 990
	rt2x00debug_register(rt2x00dev);

	return 0;

exit:
	rt2x00lib_remove_dev(rt2x00dev);

	return retval;
}
EXPORT_SYMBOL_GPL(rt2x00lib_probe_dev);

void rt2x00lib_remove_dev(struct rt2x00_dev *rt2x00dev)
{
991
	clear_bit(DEVICE_STATE_PRESENT, &rt2x00dev->flags);
992

993 994 995 996 997
	/*
	 * Disable radio.
	 */
	rt2x00lib_disable_radio(rt2x00dev);

998 999 1000 1001 1002
	/*
	 * Stop all work.
	 */
	cancel_work_sync(&rt2x00dev->intf_work);

1003 1004 1005 1006 1007 1008
	/*
	 * Uninitialize device.
	 */
	rt2x00lib_uninitialize(rt2x00dev);

	/*
1009
	 * Free extra components
1010 1011
	 */
	rt2x00debug_deregister(rt2x00dev);
1012 1013
	rt2x00leds_unregister(rt2x00dev);

1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024
	/*
	 * Free ieee80211_hw memory.
	 */
	rt2x00lib_remove_hw(rt2x00dev);

	/*
	 * Free firmware image.
	 */
	rt2x00lib_free_firmware(rt2x00dev);

	/*
I
Ivo van Doorn 已提交
1025
	 * Free queue structures.
1026
	 */
I
Ivo van Doorn 已提交
1027
	rt2x00queue_free(rt2x00dev);
1028 1029 1030 1031 1032 1033 1034 1035 1036 1037
}
EXPORT_SYMBOL_GPL(rt2x00lib_remove_dev);

/*
 * Device state handlers
 */
#ifdef CONFIG_PM
int rt2x00lib_suspend(struct rt2x00_dev *rt2x00dev, pm_message_t state)
{
	NOTICE(rt2x00dev, "Going to sleep.\n");
1038 1039

	/*
1040
	 * Prevent mac80211 from accessing driver while suspended.
1041
	 */
1042 1043
	if (!test_and_clear_bit(DEVICE_STATE_PRESENT, &rt2x00dev->flags))
		return 0;
1044 1045

	/*
1046
	 * Cleanup as much as possible.
1047 1048
	 */
	rt2x00lib_uninitialize(rt2x00dev);
1049 1050 1051 1052

	/*
	 * Suspend/disable extra components.
	 */
1053
	rt2x00leds_suspend(rt2x00dev);
1054 1055 1056
	rt2x00debug_deregister(rt2x00dev);

	/*
1057 1058 1059 1060 1061 1062 1063 1064 1065
	 * Set device mode to sleep for power management,
	 * on some hardware this call seems to consistently fail.
	 * From the specifications it is hard to tell why it fails,
	 * and if this is a "bad thing".
	 * Overall it is safe to just ignore the failure and
	 * continue suspending. The only downside is that the
	 * device will not be in optimal power save mode, but with
	 * the radio and the other components already disabled the
	 * device is as good as disabled.
1066
	 */
1067
	if (rt2x00dev->ops->lib->set_device_state(rt2x00dev, STATE_SLEEP))
1068 1069
		WARNING(rt2x00dev, "Device failed to enter sleep state, "
			"continue suspending.\n");
1070 1071 1072 1073 1074 1075 1076 1077 1078 1079

	return 0;
}
EXPORT_SYMBOL_GPL(rt2x00lib_suspend);

int rt2x00lib_resume(struct rt2x00_dev *rt2x00dev)
{
	NOTICE(rt2x00dev, "Waking up.\n");

	/*
1080
	 * Restore/enable extra components.
1081 1082
	 */
	rt2x00debug_register(rt2x00dev);
1083
	rt2x00leds_resume(rt2x00dev);
1084

1085 1086 1087
	/*
	 * We are ready again to receive requests from mac80211.
	 */
1088
	set_bit(DEVICE_STATE_PRESENT, &rt2x00dev->flags);
1089

1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101
	return 0;
}
EXPORT_SYMBOL_GPL(rt2x00lib_resume);
#endif /* CONFIG_PM */

/*
 * rt2x00lib module information.
 */
MODULE_AUTHOR(DRV_PROJECT);
MODULE_VERSION(DRV_VERSION);
MODULE_DESCRIPTION("rt2x00 library");
MODULE_LICENSE("GPL");