rt2x00dev.c 25.3 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
static void rt2x00lib_beacondone_iter(void *data, u8 *mac,
				      struct ieee80211_vif *vif)
183
{
184
	struct rt2x00_intf *intf = vif_to_intf(vif);
185

186
	if (vif->type != NL80211_IFTYPE_AP &&
A
Andrey Yurovsky 已提交
187
	    vif->type != NL80211_IFTYPE_ADHOC &&
I
Ivo van Doorn 已提交
188 189
	    vif->type != NL80211_IFTYPE_MESH_POINT &&
	    vif->type != NL80211_IFTYPE_WDS)
190 191
		return;

192 193 194
	spin_lock(&intf->lock);
	intf->delayed_flags |= DELAYED_UPDATE_BEACON;
	spin_unlock(&intf->lock);
195 196 197 198
}

void rt2x00lib_beacondone(struct rt2x00_dev *rt2x00dev)
{
199
	if (!test_bit(DEVICE_STATE_ENABLED_RADIO, &rt2x00dev->flags))
200 201
		return;

202 203 204
	ieee80211_iterate_active_interfaces_atomic(rt2x00dev->hw,
						   rt2x00lib_beacondone_iter,
						   rt2x00dev);
205

206
	ieee80211_queue_work(rt2x00dev->hw, &rt2x00dev->intf_work);
207 208 209
}
EXPORT_SYMBOL_GPL(rt2x00lib_beacondone);

I
Ivo van Doorn 已提交
210 211
void rt2x00lib_txdone(struct queue_entry *entry,
		      struct txdone_entry_desc *txdesc)
212
{
I
Ivo van Doorn 已提交
213
	struct rt2x00_dev *rt2x00dev = entry->queue->rt2x00dev;
214
	struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(entry->skb);
215
	struct skb_frame_desc *skbdesc = get_skb_frame_desc(entry->skb);
I
Ivo van Doorn 已提交
216
	enum data_queue_qid qid = skb_get_queue_mapping(entry->skb);
217
	unsigned int header_length = ieee80211_get_hdrlen_from_skb(entry->skb);
218
	u8 rate_idx, rate_flags, retry_rates;
219
	u8 skbdesc_flags = skbdesc->flags;
220
	unsigned int i;
I
Ivo van Doorn 已提交
221
	bool success;
I
Ivo van Doorn 已提交
222

223 224 225 226 227 228 229 230 231 232 233 234 235 236 237
	/*
	 * 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;

238 239 240 241
	/*
	 * Remove L2 padding which was added during
	 */
	if (test_bit(DRIVER_REQUIRE_L2PAD, &rt2x00dev->flags))
242
		rt2x00queue_remove_l2pad(entry->skb, header_length);
243

I
Ivo van Doorn 已提交
244 245 246
	/*
	 * If the IV/EIV data was stripped from the frame before it was
	 * passed to the hardware, we should now reinsert it again because
247
	 * mac80211 will expect the same data to be present it the
I
Ivo van Doorn 已提交
248 249 250
	 * frame as it was passed to us.
	 */
	if (test_bit(CONFIG_SUPPORT_HW_CRYPTO, &rt2x00dev->flags))
251
		rt2x00crypto_tx_insert_iv(entry->skb, header_length);
I
Ivo van Doorn 已提交
252

253 254 255 256 257
	/*
	 * 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);
258 259

	/*
I
Ivo van Doorn 已提交
260
	 * Determine if the frame has been successfully transmitted.
261
	 */
I
Ivo van Doorn 已提交
262
	success =
263
	    test_bit(TXDONE_SUCCESS, &txdesc->flags) ||
264
	    test_bit(TXDONE_UNKNOWN, &txdesc->flags);
I
Ivo van Doorn 已提交
265 266 267 268 269 270

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

272 273
	rate_idx = skbdesc->tx_rate_idx;
	rate_flags = skbdesc->tx_rate_flags;
274 275
	retry_rates = test_bit(TXDONE_FALLBACK, &txdesc->flags) ?
	    (txdesc->retry + 1) : 1;
276

I
Ivo van Doorn 已提交
277 278 279
	/*
	 * Initialize TX status
	 */
280 281
	memset(&tx_info->status, 0, sizeof(tx_info->status));
	tx_info->status.ack_signal = 0;
282 283 284 285

	/*
	 * Frame was send with retries, hardware tried
	 * different rates to send out the frame, at each
286 287
	 * retry it lowered the rate 1 step except when the
	 * lowest rate was used.
288 289 290 291
	 */
	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;
292 293 294 295 296 297 298 299 300 301

		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;
		}
302 303
		tx_info->status.rates[i].count = 1;
	}
I
Ivo van Doorn 已提交
304
	if (i < (IEEE80211_TX_MAX_RATES - 1))
305
		tx_info->status.rates[i].idx = -1; /* terminate */
I
Ivo van Doorn 已提交
306

307
	if (!(tx_info->flags & IEEE80211_TX_CTL_NO_ACK)) {
I
Ivo van Doorn 已提交
308
		if (success)
309
			tx_info->flags |= IEEE80211_TX_STAT_ACK;
I
Ivo van Doorn 已提交
310
		else
I
Ivo van Doorn 已提交
311
			rt2x00dev->low_level_stats.dot11ACKFailureCount++;
312 313
	}

314 315 316 317 318 319 320 321 322 323 324 325 326 327 328
	/*
	 * 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;
	}

329
	if (rate_flags & IEEE80211_TX_RC_USE_RTS_CTS) {
I
Ivo van Doorn 已提交
330
		if (success)
I
Ivo van Doorn 已提交
331
			rt2x00dev->low_level_stats.dot11RTSSuccessCount++;
I
Ivo van Doorn 已提交
332
		else
I
Ivo van Doorn 已提交
333
			rt2x00dev->low_level_stats.dot11RTSFailureCount++;
334 335 336
	}

	/*
337 338 339 340
	 * 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.
341
	 */
342
	if (!(skbdesc_flags & SKBDESC_NOT_MAC80211))
343
		ieee80211_tx_status_irqsafe(rt2x00dev->hw, entry->skb);
344
	else
I
Ivo van Doorn 已提交
345
		dev_kfree_skb_irq(entry->skb);
I
Ivo van Doorn 已提交
346 347 348 349

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

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

355
	clear_bit(ENTRY_OWNER_DEVICE_DATA, &entry->flags);
I
Ivo van Doorn 已提交
356 357 358 359 360 361 362 363 364
	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);
365 366 367
}
EXPORT_SYMBOL_GPL(rt2x00lib_txdone);

368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406
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;
}

407 408
void rt2x00lib_rxdone(struct rt2x00_dev *rt2x00dev,
		      struct queue_entry *entry)
409
{
410 411
	struct rxdone_entry_desc rxdesc;
	struct sk_buff *skb;
412
	struct ieee80211_rx_status *rx_status = &rt2x00dev->rx_status;
I
Ivo van Doorn 已提交
413
	unsigned int header_length;
414
	int rate_idx;
415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432
	/*
	 * 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);
433

434 435
	/*
	 * The data behind the ieee80211 header must be
436
	 * aligned on a 4 byte boundary.
437
	 */
I
Ivo van Doorn 已提交
438
	header_length = ieee80211_get_hdrlen_from_skb(entry->skb);
439

I
Ivo van Doorn 已提交
440 441 442
	/*
	 * Hardware might have stripped the IV/EIV/ICV data,
	 * in that case it is possible that the data was
D
Daniel Mack 已提交
443
	 * provided separately (through hardware descriptor)
I
Ivo van Doorn 已提交
444 445
	 * in which case we should reinsert the data into the frame.
	 */
446
	if ((rxdesc.dev_flags & RXDONE_CRYPTO_IV) &&
447
	    (rxdesc.flags & RX_FLAG_IV_STRIPPED))
448
		rt2x00crypto_rx_insert_iv(entry->skb, header_length,
449
					  &rxdesc);
450 451 452
	else if (header_length &&
		 (rxdesc.size > header_length) &&
		 (rxdesc.dev_flags & RXDONE_L2PAD))
453
		rt2x00queue_remove_l2pad(entry->skb, header_length);
454
	else
455
		rt2x00queue_align_payload(entry->skb, header_length);
456

457 458 459
	/* Trim buffer to correct size */
	skb_trim(entry->skb, rxdesc.size);

460
	/*
461 462 463 464
	 * 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.
465
	 */
466 467 468 469 470 471
	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;
472 473
	}

474
	/*
475
	 * Update extra components
476
	 */
477 478
	rt2x00link_update_stats(rt2x00dev, entry->skb, &rxdesc);
	rt2x00debug_update_crypto(rt2x00dev, &rxdesc);
479

480
	rx_status->mactime = rxdesc.timestamp;
481
	rx_status->rate_idx = rate_idx;
482 483
	rx_status->signal = rxdesc.rssi;
	rx_status->flag = rxdesc.flags;
484
	rx_status->antenna = rt2x00dev->link.ant.active.rx;
485 486

	/*
I
Ivo van Doorn 已提交
487 488
	 * Send frame to mac80211 & debugfs.
	 * mac80211 will clean up the skb structure.
489
	 */
490
	rt2x00debug_dump_frame(rt2x00dev, DUMP_FRAME_RXDONE, entry->skb);
491 492
	memcpy(IEEE80211_SKB_RXCB(entry->skb), rx_status, sizeof(*rx_status));
	ieee80211_rx_irqsafe(rt2x00dev->hw, entry->skb);
493 494 495 496 497

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

500
	rt2x00dev->ops->lib->clear_entry(entry);
I
Ivo van Doorn 已提交
501 502

	rt2x00queue_index_inc(entry->queue, Q_INDEX);
503 504 505 506 507 508
}
EXPORT_SYMBOL_GPL(rt2x00lib_rxdone);

/*
 * Driver initialization handlers.
 */
I
Ivo van Doorn 已提交
509 510
const struct rt2x00_rate rt2x00_supported_rates[12] = {
	{
I
Ivo van Doorn 已提交
511
		.flags = DEV_RATE_CCK,
I
Ivo van Doorn 已提交
512
		.bitrate = 10,
513
		.ratemask = BIT(0),
I
Ivo van Doorn 已提交
514
		.plcp = 0x00,
515
		.mcs = RATE_MCS(RATE_MODE_CCK, 0),
I
Ivo van Doorn 已提交
516 517
	},
	{
I
Ivo van Doorn 已提交
518
		.flags = DEV_RATE_CCK | DEV_RATE_SHORT_PREAMBLE,
I
Ivo van Doorn 已提交
519
		.bitrate = 20,
520
		.ratemask = BIT(1),
I
Ivo van Doorn 已提交
521
		.plcp = 0x01,
522
		.mcs = RATE_MCS(RATE_MODE_CCK, 1),
I
Ivo van Doorn 已提交
523 524
	},
	{
I
Ivo van Doorn 已提交
525
		.flags = DEV_RATE_CCK | DEV_RATE_SHORT_PREAMBLE,
I
Ivo van Doorn 已提交
526
		.bitrate = 55,
527
		.ratemask = BIT(2),
I
Ivo van Doorn 已提交
528
		.plcp = 0x02,
529
		.mcs = RATE_MCS(RATE_MODE_CCK, 2),
I
Ivo van Doorn 已提交
530 531
	},
	{
I
Ivo van Doorn 已提交
532
		.flags = DEV_RATE_CCK | DEV_RATE_SHORT_PREAMBLE,
I
Ivo van Doorn 已提交
533
		.bitrate = 110,
534
		.ratemask = BIT(3),
I
Ivo van Doorn 已提交
535
		.plcp = 0x03,
536
		.mcs = RATE_MCS(RATE_MODE_CCK, 3),
I
Ivo van Doorn 已提交
537 538
	},
	{
I
Ivo van Doorn 已提交
539
		.flags = DEV_RATE_OFDM,
I
Ivo van Doorn 已提交
540
		.bitrate = 60,
541
		.ratemask = BIT(4),
I
Ivo van Doorn 已提交
542
		.plcp = 0x0b,
543
		.mcs = RATE_MCS(RATE_MODE_OFDM, 0),
I
Ivo van Doorn 已提交
544 545 546 547
	},
	{
		.flags = DEV_RATE_OFDM,
		.bitrate = 90,
548
		.ratemask = BIT(5),
I
Ivo van Doorn 已提交
549
		.plcp = 0x0f,
550
		.mcs = RATE_MCS(RATE_MODE_OFDM, 1),
I
Ivo van Doorn 已提交
551 552
	},
	{
I
Ivo van Doorn 已提交
553
		.flags = DEV_RATE_OFDM,
I
Ivo van Doorn 已提交
554
		.bitrate = 120,
555
		.ratemask = BIT(6),
I
Ivo van Doorn 已提交
556
		.plcp = 0x0a,
557
		.mcs = RATE_MCS(RATE_MODE_OFDM, 2),
I
Ivo van Doorn 已提交
558 559 560 561
	},
	{
		.flags = DEV_RATE_OFDM,
		.bitrate = 180,
562
		.ratemask = BIT(7),
I
Ivo van Doorn 已提交
563
		.plcp = 0x0e,
564
		.mcs = RATE_MCS(RATE_MODE_OFDM, 3),
I
Ivo van Doorn 已提交
565 566
	},
	{
I
Ivo van Doorn 已提交
567
		.flags = DEV_RATE_OFDM,
I
Ivo van Doorn 已提交
568
		.bitrate = 240,
569
		.ratemask = BIT(8),
I
Ivo van Doorn 已提交
570
		.plcp = 0x09,
571
		.mcs = RATE_MCS(RATE_MODE_OFDM, 4),
I
Ivo van Doorn 已提交
572 573 574 575
	},
	{
		.flags = DEV_RATE_OFDM,
		.bitrate = 360,
576
		.ratemask = BIT(9),
I
Ivo van Doorn 已提交
577
		.plcp = 0x0d,
578
		.mcs = RATE_MCS(RATE_MODE_OFDM, 5),
I
Ivo van Doorn 已提交
579 580 581 582
	},
	{
		.flags = DEV_RATE_OFDM,
		.bitrate = 480,
583
		.ratemask = BIT(10),
I
Ivo van Doorn 已提交
584
		.plcp = 0x08,
585
		.mcs = RATE_MCS(RATE_MODE_OFDM, 6),
I
Ivo van Doorn 已提交
586 587 588 589
	},
	{
		.flags = DEV_RATE_OFDM,
		.bitrate = 540,
590
		.ratemask = BIT(11),
I
Ivo van Doorn 已提交
591
		.plcp = 0x0c,
592
		.mcs = RATE_MCS(RATE_MODE_OFDM, 7),
I
Ivo van Doorn 已提交
593 594 595
	},
};

596 597 598 599
static void rt2x00lib_channel(struct ieee80211_channel *entry,
			      const int channel, const int tx_power,
			      const int value)
{
600
	entry->center_freq = ieee80211_channel_to_frequency(channel);
601 602 603
	entry->hw_value = value;
	entry->max_power = tx_power;
	entry->max_antenna_gain = 0xff;
604 605 606
}

static void rt2x00lib_rate(struct ieee80211_rate *entry,
I
Ivo van Doorn 已提交
607
			   const u16 index, const struct rt2x00_rate *rate)
608
{
I
Ivo van Doorn 已提交
609 610
	entry->flags = 0;
	entry->bitrate = rate->bitrate;
611 612
	entry->hw_value =index;
	entry->hw_value_short = index;
I
Ivo van Doorn 已提交
613

614
	if (rate->flags & DEV_RATE_SHORT_PREAMBLE)
I
Ivo van Doorn 已提交
615
		entry->flags |= IEEE80211_RATE_SHORT_PREAMBLE;
616 617 618 619 620 621 622 623
}

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;
624
	unsigned int num_rates;
625 626
	unsigned int i;

627 628 629 630 631
	num_rates = 0;
	if (spec->supported_rates & SUPPORT_RATE_CCK)
		num_rates += 4;
	if (spec->supported_rates & SUPPORT_RATE_OFDM)
		num_rates += 8;
632 633 634

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

637
	rates = kzalloc(sizeof(*rates) * num_rates, GFP_KERNEL);
638 639 640 641 642 643
	if (!rates)
		goto exit_free_channels;

	/*
	 * Initialize Rate list.
	 */
644
	for (i = 0; i < num_rates; i++)
I
Ivo van Doorn 已提交
645
		rt2x00lib_rate(&rates[i], i, rt2x00_get_rate(i));
646 647 648 649 650 651

	/*
	 * Initialize Channel list.
	 */
	for (i = 0; i < spec->num_channels; i++) {
		rt2x00lib_channel(&channels[i],
652 653
				  spec->channels[i].channel,
				  spec->channels_info[i].tx_power1, i);
654 655 656
	}

	/*
657
	 * Intitialize 802.11b, 802.11g
658
	 * Rates: CCK, OFDM.
659
	 * Channels: 2.4 GHz
660
	 */
661
	if (spec->supported_bands & SUPPORT_BAND_2GHZ) {
662 663 664 665 666 667
		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];
668 669
		memcpy(&rt2x00dev->bands[IEEE80211_BAND_2GHZ].ht_cap,
		       &spec->ht, sizeof(spec->ht));
670 671 672 673 674 675 676
	}

	/*
	 * Intitialize 802.11a
	 * Rates: OFDM.
	 * Channels: OFDM, UNII, HiperLAN2.
	 */
677
	if (spec->supported_bands & SUPPORT_BAND_5GHZ) {
678 679 680 681 682 683 684 685
		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];
686 687
		memcpy(&rt2x00dev->bands[IEEE80211_BAND_5GHZ].ht_cap,
		       &spec->ht, sizeof(spec->ht));
688 689 690 691
	}

	return 0;

692
 exit_free_channels:
693 694 695 696 697 698 699
	kfree(channels);
	ERROR(rt2x00dev, "Allocation ieee80211 modes failed.\n");
	return -ENOMEM;
}

static void rt2x00lib_remove_hw(struct rt2x00_dev *rt2x00dev)
{
700
	if (test_bit(DEVICE_STATE_REGISTERED_HW, &rt2x00dev->flags))
701 702
		ieee80211_unregister_hw(rt2x00dev->hw);

703 704 705 706 707
	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;
708
	}
709 710

	kfree(rt2x00dev->spec.channels_info);
711 712 713 714 715 716 717
}

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

718 719 720
	if (test_bit(DEVICE_STATE_REGISTERED_HW, &rt2x00dev->flags))
		return 0;

721 722 723 724 725 726 727
	/*
	 * Initialize HW modes.
	 */
	status = rt2x00lib_probe_hw_modes(rt2x00dev, spec);
	if (status)
		return status;

728 729 730 731 732
	/*
	 * Initialize HW fields.
	 */
	rt2x00dev->hw->queues = rt2x00dev->ops->tx_queues;

733 734 735
	/*
	 * Initialize extra TX headroom required.
	 */
736 737 738 739 740 741 742 743 744 745 746
	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;
747

748 749 750 751
	/*
	 * Register HW.
	 */
	status = ieee80211_register_hw(rt2x00dev->hw);
752
	if (status)
753 754
		return status;

755
	set_bit(DEVICE_STATE_REGISTERED_HW, &rt2x00dev->flags);
756 757 758 759 760 761 762

	return 0;
}

/*
 * Initialization/uninitialization handlers.
 */
763
static void rt2x00lib_uninitialize(struct rt2x00_dev *rt2x00dev)
764
{
765
	if (!test_and_clear_bit(DEVICE_STATE_INITIALIZED, &rt2x00dev->flags))
766 767 768
		return;

	/*
769
	 * Unregister extra components.
770 771 772 773 774 775 776 777 778
	 */
	rt2x00rfkill_unregister(rt2x00dev);

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

	/*
I
Ivo van Doorn 已提交
779
	 * Free allocated queue entries.
780
	 */
I
Ivo van Doorn 已提交
781
	rt2x00queue_uninitialize(rt2x00dev);
782 783
}

784
static int rt2x00lib_initialize(struct rt2x00_dev *rt2x00dev)
785 786 787
{
	int status;

788
	if (test_bit(DEVICE_STATE_INITIALIZED, &rt2x00dev->flags))
789 790 791
		return 0;

	/*
I
Ivo van Doorn 已提交
792
	 * Allocate all queue entries.
793
	 */
I
Ivo van Doorn 已提交
794 795
	status = rt2x00queue_initialize(rt2x00dev);
	if (status)
796 797 798 799 800 801
		return status;

	/*
	 * Initialize the device.
	 */
	status = rt2x00dev->ops->lib->initialize(rt2x00dev);
802 803 804 805
	if (status) {
		rt2x00queue_uninitialize(rt2x00dev);
		return status;
	}
806

807
	set_bit(DEVICE_STATE_INITIALIZED, &rt2x00dev->flags);
808 809

	/*
810
	 * Register the extra components.
811
	 */
812
	rt2x00rfkill_register(rt2x00dev);
813 814 815 816

	return 0;
}

817 818 819 820
int rt2x00lib_start(struct rt2x00_dev *rt2x00dev)
{
	int retval;

821
	if (test_bit(DEVICE_STATE_STARTED, &rt2x00dev->flags))
822 823 824 825 826 827
		return 0;

	/*
	 * If this is the first interface which is added,
	 * we should load the firmware now.
	 */
828 829 830
	retval = rt2x00lib_load_firmware(rt2x00dev);
	if (retval)
		return retval;
831 832 833 834 835 836 837 838

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

839 840 841 842
	rt2x00dev->intf_ap_count = 0;
	rt2x00dev->intf_sta_count = 0;
	rt2x00dev->intf_associated = 0;

843 844 845 846 847 848 849
	/* Enable the radio */
	retval = rt2x00lib_enable_radio(rt2x00dev);
	if (retval) {
		rt2x00queue_uninitialize(rt2x00dev);
		return retval;
	}

850
	set_bit(DEVICE_STATE_STARTED, &rt2x00dev->flags);
851 852 853 854 855 856

	return 0;
}

void rt2x00lib_stop(struct rt2x00_dev *rt2x00dev)
{
857
	if (!test_and_clear_bit(DEVICE_STATE_STARTED, &rt2x00dev->flags))
858 859 860 861 862 863 864 865
		return;

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

866 867 868
	rt2x00dev->intf_ap_count = 0;
	rt2x00dev->intf_sta_count = 0;
	rt2x00dev->intf_associated = 0;
869 870
}

871 872 873 874 875 876 877
/*
 * driver allocation handlers.
 */
int rt2x00lib_probe_dev(struct rt2x00_dev *rt2x00dev)
{
	int retval = -ENOMEM;

878 879
	mutex_init(&rt2x00dev->csr_mutex);

880 881
	set_bit(DEVICE_STATE_PRESENT, &rt2x00dev->flags);

882 883 884 885 886 887
	/*
	 * Make room for rt2x00_intf inside the per-interface
	 * structure ieee80211_vif.
	 */
	rt2x00dev->hw->vif_data_size = sizeof(struct rt2x00_intf);

888 889 890 891 892 893 894 895 896
	/*
	 * 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 已提交
897
		    BIT(NL80211_IFTYPE_AP) |
I
Ivo van Doorn 已提交
898 899
		    BIT(NL80211_IFTYPE_MESH_POINT) |
		    BIT(NL80211_IFTYPE_WDS);
900

901 902 903 904 905 906 907 908 909 910 911 912
	/*
	 * 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.
	 */
913
	INIT_WORK(&rt2x00dev->intf_work, rt2x00lib_intf_scheduled);
914 915

	/*
I
Ivo van Doorn 已提交
916
	 * Allocate queue array.
917
	 */
I
Ivo van Doorn 已提交
918
	retval = rt2x00queue_allocate(rt2x00dev);
919 920 921 922 923 924 925 926 927 928 929 930
	if (retval)
		goto exit;

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

931
	/*
932
	 * Register extra components.
933
	 */
934
	rt2x00link_register(rt2x00dev);
935
	rt2x00leds_register(rt2x00dev);
936 937 938 939 940 941 942 943 944 945 946 947 948
	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)
{
949
	clear_bit(DEVICE_STATE_PRESENT, &rt2x00dev->flags);
950

951 952 953 954 955
	/*
	 * Disable radio.
	 */
	rt2x00lib_disable_radio(rt2x00dev);

956 957 958 959 960
	/*
	 * Stop all work.
	 */
	cancel_work_sync(&rt2x00dev->intf_work);

961 962 963 964 965 966
	/*
	 * Uninitialize device.
	 */
	rt2x00lib_uninitialize(rt2x00dev);

	/*
967
	 * Free extra components
968 969
	 */
	rt2x00debug_deregister(rt2x00dev);
970 971
	rt2x00leds_unregister(rt2x00dev);

972 973 974 975 976 977 978 979 980 981 982
	/*
	 * Free ieee80211_hw memory.
	 */
	rt2x00lib_remove_hw(rt2x00dev);

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

	/*
I
Ivo van Doorn 已提交
983
	 * Free queue structures.
984
	 */
I
Ivo van Doorn 已提交
985
	rt2x00queue_free(rt2x00dev);
986 987 988 989 990 991 992 993 994 995
}
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");
996 997

	/*
998
	 * Prevent mac80211 from accessing driver while suspended.
999
	 */
1000 1001
	if (!test_and_clear_bit(DEVICE_STATE_PRESENT, &rt2x00dev->flags))
		return 0;
1002 1003

	/*
1004
	 * Cleanup as much as possible.
1005 1006
	 */
	rt2x00lib_uninitialize(rt2x00dev);
1007 1008 1009 1010

	/*
	 * Suspend/disable extra components.
	 */
1011
	rt2x00leds_suspend(rt2x00dev);
1012 1013 1014
	rt2x00debug_deregister(rt2x00dev);

	/*
1015 1016 1017 1018 1019 1020 1021 1022 1023
	 * 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.
1024
	 */
1025
	if (rt2x00dev->ops->lib->set_device_state(rt2x00dev, STATE_SLEEP))
1026 1027
		WARNING(rt2x00dev, "Device failed to enter sleep state, "
			"continue suspending.\n");
1028 1029 1030 1031 1032 1033 1034 1035 1036 1037

	return 0;
}
EXPORT_SYMBOL_GPL(rt2x00lib_suspend);

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

	/*
1038
	 * Restore/enable extra components.
1039 1040
	 */
	rt2x00debug_register(rt2x00dev);
1041
	rt2x00leds_resume(rt2x00dev);
1042

1043 1044 1045
	/*
	 * We are ready again to receive requests from mac80211.
	 */
1046
	set_bit(DEVICE_STATE_PRESENT, &rt2x00dev->flags);
1047

1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059
	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");