2 * Copyright (c) 2008, Atheros Communications Inc.
4 * Permission to use, copy, modify, and/or distribute this software for any
5 * purpose with or without fee is hereby granted, provided that the above
6 * copyright notice and this permission notice appear in all copies.
8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17 /* Implementation of the main "ATH" layer. */
22 static int ath_outdoor = AH_FALSE; /* enable outdoor use */
24 static const u_int8_t ath_bcast_mac[ETH_ALEN] =
25 { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
27 static u_int32_t ath_chainmask_sel_up_rssi_thres =
28 ATH_CHAINMASK_SEL_UP_RSSI_THRES;
29 static u_int32_t ath_chainmask_sel_down_rssi_thres =
30 ATH_CHAINMASK_SEL_DOWN_RSSI_THRES;
31 static u_int32_t ath_chainmask_sel_period =
32 ATH_CHAINMASK_SEL_TIMEOUT;
34 /* return bus cachesize in 4B word units */
36 static void bus_read_cachesize(struct ath_softc *sc, int *csz)
40 pci_read_config_byte(sc->pdev, PCI_CACHE_LINE_SIZE, (u_int8_t *)&u8tmp);
44 * This check was put in to avoid "unplesant" consequences if
45 * the bootrom has not fully initialized all PCI devices.
46 * Sometimes the cache line size register is not set
50 *csz = DEFAULT_CACHELINE >> 2; /* Use the default size */
54 * Set current operating mode
56 * This function initializes and fills the rate table in the ATH object based
57 * on the operating mode. The blink rates are also set up here, although
58 * they have been superceeded by the ath_led module.
61 static void ath_setcurmode(struct ath_softc *sc, enum wireless_mode mode)
63 const struct hal_rate_table *rt;
66 memset(sc->sc_rixmap, 0xff, sizeof(sc->sc_rixmap));
67 rt = sc->sc_rates[mode];
68 KASSERT(rt != NULL, ("no h/w rate set for phy mode %u", mode));
70 for (i = 0; i < rt->rateCount; i++)
71 sc->sc_rixmap[rt->info[i].rateCode] = (u_int8_t) i;
73 memzero(sc->sc_hwmap, sizeof(sc->sc_hwmap));
74 for (i = 0; i < 256; i++) {
75 u_int8_t ix = rt->rateCodeToIndex[i];
80 sc->sc_hwmap[i].ieeerate =
81 rt->info[ix].dot11Rate & IEEE80211_RATE_VAL;
82 sc->sc_hwmap[i].rateKbps = rt->info[ix].rateKbps;
84 if (rt->info[ix].shortPreamble ||
85 rt->info[ix].phy == PHY_OFDM) {
87 /* NB: this uses the last entry if the rate isn't found */
88 /* XXX beware of overlow */
91 sc->sc_curmode = mode;
93 * All protection frames are transmited at 2Mb/s for
94 * 11g, otherwise at 1Mb/s.
95 * XXX select protection rate index from rate table.
97 sc->sc_protrix = (mode == WIRELESS_MODE_11g ? 1 : 0);
98 /* rate index used to send mgt frames */
105 * Based on the wireless mode passed in, the rate table in the ATH object
106 * is set to the mode specific rate table. This also calls the callback
107 * function to set the rate in the protocol layer object.
110 static int ath_rate_setup(struct ath_softc *sc, enum wireless_mode mode)
112 struct ath_hal *ah = sc->sc_ah;
113 const struct hal_rate_table *rt;
116 case WIRELESS_MODE_11a:
118 ath9k_hw_getratetable(ah, ATH9K_MODE_SEL_11A);
120 case WIRELESS_MODE_11b:
122 ath9k_hw_getratetable(ah, ATH9K_MODE_SEL_11B);
124 case WIRELESS_MODE_11g:
126 ath9k_hw_getratetable(ah, ATH9K_MODE_SEL_11G);
128 case WIRELESS_MODE_11NA_HT20:
130 ath9k_hw_getratetable(ah, ATH9K_MODE_SEL_11NA_HT20);
132 case WIRELESS_MODE_11NG_HT20:
134 ath9k_hw_getratetable(ah, ATH9K_MODE_SEL_11NG_HT20);
136 case WIRELESS_MODE_11NA_HT40PLUS:
138 ath9k_hw_getratetable(ah, ATH9K_MODE_SEL_11NA_HT40PLUS);
140 case WIRELESS_MODE_11NA_HT40MINUS:
142 ath9k_hw_getratetable(ah,
143 ATH9K_MODE_SEL_11NA_HT40MINUS);
145 case WIRELESS_MODE_11NG_HT40PLUS:
147 ath9k_hw_getratetable(ah, ATH9K_MODE_SEL_11NG_HT40PLUS);
149 case WIRELESS_MODE_11NG_HT40MINUS:
151 ath9k_hw_getratetable(ah,
152 ATH9K_MODE_SEL_11NG_HT40MINUS);
155 DPRINTF(sc, ATH_DEBUG_FATAL, "%s: invalid mode %u\n",
159 rt = sc->sc_rates[mode];
163 /* setup rate set in 802.11 protocol layer */
164 ath_setup_rate(sc, mode, NORMAL_RATE, rt);
170 * Set up channel list
172 * Determines the proper set of channelflags based on the selected mode,
173 * allocates a channel array, and passes it to the HAL for initialization.
174 * If successful, the list is passed to the upper layer, then de-allocated.
177 static int ath_getchannels(struct ath_softc *sc,
179 enum hal_bool outDoor,
180 enum hal_bool xchanMode)
182 struct ath_hal *ah = sc->sc_ah;
183 struct hal_channel *chans;
185 u_int8_t regclassids[ATH_REGCLASSIDS_MAX];
188 chans = kmalloc(ATH_CHAN_MAX * sizeof(struct hal_channel), GFP_KERNEL);
190 DPRINTF(sc, ATH_DEBUG_FATAL,
191 "%s: unable to allocate channel table\n", __func__);
195 if (!ath9k_regd_init_channels(ah,
206 u_int32_t rd = ah->ah_currentRD;
208 DPRINTF(sc, ATH_DEBUG_FATAL,
209 "%s: unable to collect channel list from hal; "
210 "regdomain likely %u country code %u\n",
216 ath_setup_channel_list(sc,
229 * Determine mode from channel flags
231 * This routine will provide the enumerated WIRELESSS_MODE value based
232 * on the settings of the channel flags. If ho valid set of flags
233 * exist, the lowest mode (11b) is selected.
236 static enum wireless_mode ath_chan2mode(struct hal_channel *chan)
238 if ((chan->channelFlags & CHANNEL_A) == CHANNEL_A)
239 return WIRELESS_MODE_11a;
240 else if ((chan->channelFlags & CHANNEL_G) == CHANNEL_G)
241 return WIRELESS_MODE_11g;
242 else if ((chan->channelFlags & CHANNEL_B) == CHANNEL_B)
243 return WIRELESS_MODE_11b;
244 else if ((chan->channelFlags & CHANNEL_A_HT20) == CHANNEL_A_HT20)
245 return WIRELESS_MODE_11NA_HT20;
246 else if ((chan->channelFlags & CHANNEL_G_HT20) == CHANNEL_G_HT20)
247 return WIRELESS_MODE_11NG_HT20;
248 else if ((chan->channelFlags & CHANNEL_A_HT40PLUS) ==
250 return WIRELESS_MODE_11NA_HT40PLUS;
251 else if ((chan->channelFlags & CHANNEL_A_HT40MINUS) ==
253 return WIRELESS_MODE_11NA_HT40MINUS;
254 else if ((chan->channelFlags & CHANNEL_G_HT40PLUS) ==
256 return WIRELESS_MODE_11NG_HT40PLUS;
257 else if ((chan->channelFlags & CHANNEL_G_HT40MINUS) ==
259 return WIRELESS_MODE_11NG_HT40MINUS;
261 /* NB: should not get here */
262 return WIRELESS_MODE_11b;
268 * Performs the actions to change the channel in the hardware, and set up
269 * the current operating mode for the new channel.
272 static void ath_chan_change(struct ath_softc *sc, struct hal_channel *chan)
274 enum wireless_mode mode;
276 mode = ath_chan2mode(chan);
278 ath_rate_setup(sc, mode);
279 ath_setcurmode(sc, mode);
283 * Stop the device, grabbing the top-level lock to protect
284 * against concurrent entry through ath_init (which can happen
285 * if another thread does a system call and the thread doing the
286 * stop is preempted).
289 static int ath_stop(struct ath_softc *sc)
291 struct ath_hal *ah = sc->sc_ah;
293 DPRINTF(sc, ATH_DEBUG_CONFIG, "%s: invalid %u\n",
294 __func__, sc->sc_invalid);
297 * Shutdown the hardware and driver:
298 * stop output from above
299 * reset 802.11 state machine
300 * (sends station deassoc/deauth frames)
303 * clear transmit machinery
304 * clear receive machinery
306 * reclaim beacon resources
308 * Note that some of this work is not possible if the
309 * hardware is gone (invalid).
313 ath9k_hw_set_interrupts(ah, 0);
314 ath_draintxq(sc, AH_FALSE);
315 if (!sc->sc_invalid) {
317 ath9k_hw_phy_disable(ah);
319 sc->sc_rxlink = NULL;
327 * This function is called when starting a channel scan. It will perform
328 * power save wakeup processing, set the filter for the scan, and get the
329 * chip ready to send broadcast packets out during the scan.
332 void ath_scan_start(struct ath_softc *sc)
334 struct ath_hal *ah = sc->sc_ah;
336 u_int32_t now = (u_int32_t) jiffies_to_msecs(get_timestamp());
339 rfilt = ath_calcrxfilter(sc);
340 ath9k_hw_setrxfilter(ah, rfilt);
341 ath9k_hw_write_associd(ah, ath_bcast_mac, 0);
343 /* Restore previous power management state. */
345 DPRINTF(sc, ATH_DEBUG_CONFIG, "%d.%03d | %s: RX filter 0x%x aid 0\n",
346 now / 1000, now % 1000, __func__, rfilt);
352 * This routine is called by the upper layer when the scan is completed. This
353 * will set the filters back to normal operating mode, set the BSSID to the
354 * correct value, and restore the power save state.
357 void ath_scan_end(struct ath_softc *sc)
359 struct ath_hal *ah = sc->sc_ah;
361 u_int32_t now = (u_int32_t) jiffies_to_msecs(get_timestamp());
364 rfilt = ath_calcrxfilter(sc);
365 ath9k_hw_setrxfilter(ah, rfilt);
366 ath9k_hw_write_associd(ah, sc->sc_curbssid, sc->sc_curaid);
368 DPRINTF(sc, ATH_DEBUG_CONFIG, "%d.%03d | %s: RX filter 0x%x aid 0x%x\n",
369 now / 1000, now % 1000, __func__, rfilt, sc->sc_curaid);
373 * Set the current channel
375 * Set/change channels. If the channel is really being changed, it's done
376 * by reseting the chip. To accomplish this we must first cleanup any pending
377 * DMA, then restart stuff after a la ath_init.
379 int ath_set_channel(struct ath_softc *sc, struct hal_channel *hchan)
381 struct ath_hal *ah = sc->sc_ah;
382 enum hal_bool fastcc = AH_TRUE, stopped;
383 enum hal_ht_macmode ht_macmode;
385 if (sc->sc_invalid) /* if the device is invalid or removed */
388 DPRINTF(sc, ATH_DEBUG_CONFIG,
389 "%s: %u (%u MHz) -> %u (%u MHz), cflags:%x\n",
391 ath9k_hw_mhz2ieee(ah, sc->sc_curchan.channel,
392 sc->sc_curchan.channelFlags),
393 sc->sc_curchan.channel,
394 ath9k_hw_mhz2ieee(ah, hchan->channel, hchan->channelFlags),
395 hchan->channel, hchan->channelFlags);
397 ht_macmode = ath_cwm_macmode(sc);
399 if (hchan->channel != sc->sc_curchan.channel ||
400 hchan->channelFlags != sc->sc_curchan.channelFlags ||
401 sc->sc_update_chainmask || sc->sc_full_reset) {
402 enum hal_status status;
404 * This is only performed if the channel settings have
407 * To switch channels clear any pending DMA operations;
408 * wait long enough for the RX fifo to drain, reset the
409 * hardware at the new frequency, and then re-enable
410 * the relevant bits of the h/w.
412 ath9k_hw_set_interrupts(ah, 0); /* disable interrupts */
413 ath_draintxq(sc, AH_FALSE); /* clear pending tx frames */
414 stopped = ath_stoprecv(sc); /* turn off frame recv */
416 /* XXX: do not flush receive queue here. We don't want
417 * to flush data frames already in queue because of
418 * changing channel. */
420 if (!stopped || sc->sc_full_reset)
423 spin_lock_bh(&sc->sc_resetlock);
424 if (!ath9k_hw_reset(ah, sc->sc_opmode, hchan,
425 ht_macmode, sc->sc_tx_chainmask,
427 sc->sc_ht_extprotspacing,
429 DPRINTF(sc, ATH_DEBUG_FATAL,
430 "%s: unable to reset channel %u (%uMhz) "
431 "flags 0x%x hal status %u\n", __func__,
432 ath9k_hw_mhz2ieee(ah, hchan->channel,
433 hchan->channelFlags),
434 hchan->channel, hchan->channelFlags, status);
435 spin_unlock_bh(&sc->sc_resetlock);
438 spin_unlock_bh(&sc->sc_resetlock);
440 sc->sc_curchan = *hchan;
441 sc->sc_update_chainmask = 0;
442 sc->sc_full_reset = 0;
444 /* Re-enable rx framework */
445 if (ath_startrecv(sc) != 0) {
446 DPRINTF(sc, ATH_DEBUG_FATAL,
447 "%s: unable to restart recv logic\n", __func__);
451 * Change channels and update the h/w rate map
452 * if we're switching; e.g. 11a to 11b/g.
454 ath_chan_change(sc, hchan);
455 ath_update_txpow(sc); /* update tx power state */
457 * Re-enable interrupts.
459 ath9k_hw_set_interrupts(ah, sc->sc_imask);
464 /**********************/
465 /* Chainmask Handling */
466 /**********************/
468 static void ath_chainmask_sel_timertimeout(unsigned long data)
470 struct ath_chainmask_sel *cm = (struct ath_chainmask_sel *)data;
471 cm->switch_allowed = 1;
474 /* Start chainmask select timer */
475 static void ath_chainmask_sel_timerstart(struct ath_chainmask_sel *cm)
477 cm->switch_allowed = 0;
478 mod_timer(&cm->timer, ath_chainmask_sel_period);
481 /* Stop chainmask select timer */
482 static void ath_chainmask_sel_timerstop(struct ath_chainmask_sel *cm)
484 cm->switch_allowed = 0;
485 del_timer_sync(&cm->timer);
488 static void ath_chainmask_sel_init(struct ath_softc *sc, struct ath_node *an)
490 struct ath_chainmask_sel *cm = &an->an_chainmask_sel;
492 memzero(cm, sizeof(struct ath_chainmask_sel));
494 cm->cur_tx_mask = sc->sc_tx_chainmask;
495 cm->cur_rx_mask = sc->sc_rx_chainmask;
496 cm->tx_avgrssi = ATH_RSSI_DUMMY_MARKER;
497 setup_timer(&cm->timer,
498 ath_chainmask_sel_timertimeout, (unsigned long) cm);
501 int ath_chainmask_sel_logic(struct ath_softc *sc, struct ath_node *an)
503 struct ath_chainmask_sel *cm = &an->an_chainmask_sel;
506 * Disable auto-swtiching in one of the following if conditions.
507 * sc_chainmask_auto_sel is used for internal global auto-switching
508 * enabled/disabled setting
510 if ((sc->sc_no_tx_3_chains == AH_FALSE) ||
511 (sc->sc_config.chainmask_sel == AH_FALSE))
512 cm->cur_tx_mask = sc->sc_tx_chainmask;
513 return cm->cur_tx_mask;
515 if (cm->tx_avgrssi == ATH_RSSI_DUMMY_MARKER)
516 return cm->cur_tx_mask;
518 if (cm->switch_allowed) {
519 /* Switch down from tx 3 to tx 2. */
520 if (cm->cur_tx_mask == ATH_CHAINMASK_SEL_3X3 &&
521 ATH_RSSI_OUT(cm->tx_avgrssi) >=
522 ath_chainmask_sel_down_rssi_thres) {
523 cm->cur_tx_mask = sc->sc_tx_chainmask;
525 /* Don't let another switch happen until
526 * this timer expires */
527 ath_chainmask_sel_timerstart(cm);
529 /* Switch up from tx 2 to 3. */
530 else if (cm->cur_tx_mask == sc->sc_tx_chainmask &&
531 ATH_RSSI_OUT(cm->tx_avgrssi) <=
532 ath_chainmask_sel_up_rssi_thres) {
533 cm->cur_tx_mask = ATH_CHAINMASK_SEL_3X3;
535 /* Don't let another switch happen
536 * until this timer expires */
537 ath_chainmask_sel_timerstart(cm);
541 return cm->cur_tx_mask;
551 * This routine will stop the indicated VAP and put it in a "down" state.
552 * The down state is basically an initialization state that can be brought
553 * back up by calling the opposite up routine.
554 * This routine will bring the interface out of power save mode, set the
555 * LED states, update the rate control processing, stop DMA transfers, and
556 * set the VAP into the down state.
559 int ath_vap_down(struct ath_softc *sc, int if_id, u_int flags)
561 struct ath_hal *ah = sc->sc_ah;
564 avp = sc->sc_vaps[if_id];
566 DPRINTF(sc, ATH_DEBUG_FATAL, "%s: invalid interface id %u\n",
571 #ifdef CONFIG_SLOW_ANT_DIV
572 if (sc->sc_slowAntDiv)
573 ath_slow_ant_div_stop(&sc->sc_antdiv);
576 /* update ratectrl about the new state */
577 ath_rate_newstate(sc, avp, 0);
579 /* Reclaim beacon resources */
580 if (sc->sc_opmode == HAL_M_HOSTAP || sc->sc_opmode == HAL_M_IBSS) {
581 ath9k_hw_stoptxdma(ah, sc->sc_bhalq);
582 ath_beacon_return(sc, avp);
585 if (flags & ATH_IF_HW_OFF) {
586 sc->sc_imask &= ~(HAL_INT_SWBA | HAL_INT_BMISS);
587 ath9k_hw_set_interrupts(ah, sc->sc_imask & ~HAL_INT_GLOBAL);
597 * This routine brings the VAP out of the down state into a "listen" state
598 * where it waits for association requests. This is used in AP and AdHoc
602 int ath_vap_listen(struct ath_softc *sc, int if_id)
604 struct ath_hal *ah = sc->sc_ah;
607 DECLARE_MAC_BUF(mac);
609 avp = sc->sc_vaps[if_id];
611 DPRINTF(sc, ATH_DEBUG_FATAL, "%s: invalid interface id %u\n",
616 #ifdef CONFIG_SLOW_ANT_DIV
617 if (sc->sc_slowAntDiv)
618 ath_slow_ant_div_stop(&sc->sc_antdiv);
621 /* update ratectrl about the new state */
622 ath_rate_newstate(sc, avp, 0);
624 rfilt = ath_calcrxfilter(sc);
625 ath9k_hw_setrxfilter(ah, rfilt);
627 if (sc->sc_opmode == HAL_M_STA || sc->sc_opmode == HAL_M_IBSS) {
628 memcpy(sc->sc_curbssid, ath_bcast_mac, ETH_ALEN);
629 ath9k_hw_write_associd(ah, sc->sc_curbssid, sc->sc_curaid);
633 DPRINTF(sc, ATH_DEBUG_CONFIG,
634 "%s: RX filter 0x%x bssid %s aid 0x%x\n",
635 __func__, rfilt, print_mac(mac,
636 sc->sc_curbssid), sc->sc_curaid);
640 * Disable BMISS interrupt when we're not associated
642 ath9k_hw_set_interrupts(ah,
643 sc->sc_imask & ~(HAL_INT_SWBA | HAL_INT_BMISS));
644 sc->sc_imask &= ~(HAL_INT_SWBA | HAL_INT_BMISS);
645 /* need to reconfigure the beacons when it moves to RUN */
651 int ath_vap_join(struct ath_softc *sc, int if_id,
652 const u_int8_t bssid[ETH_ALEN], u_int flags)
654 struct ath_hal *ah = sc->sc_ah;
657 DECLARE_MAC_BUF(mac);
659 avp = sc->sc_vaps[if_id];
661 DPRINTF(sc, ATH_DEBUG_FATAL, "%s: invalid interface id %u\n",
666 /* update ratectrl about the new state */
667 ath_rate_newstate(sc, avp, 0);
669 rfilt = ath_calcrxfilter(sc);
670 ath9k_hw_setrxfilter(ah, rfilt);
672 memcpy(sc->sc_curbssid, bssid, ETH_ALEN);
674 ath9k_hw_write_associd(ah, sc->sc_curbssid, sc->sc_curaid);
676 DPRINTF(sc, ATH_DEBUG_CONFIG,
677 "%s: RX filter 0x%x bssid %s aid 0x%x\n",
679 print_mac(mac, sc->sc_curbssid), sc->sc_curaid);
682 * Update tx/rx chainmask. For legacy association,
683 * hard code chainmask to 1x1, for 11n association, use
684 * the chainmask configuration.
686 sc->sc_update_chainmask = 1;
687 if (flags & ATH_IF_HT) {
688 sc->sc_tx_chainmask = ah->ah_caps.halTxChainMask;
689 sc->sc_rx_chainmask = ah->ah_caps.halRxChainMask;
691 sc->sc_tx_chainmask = 1;
692 sc->sc_rx_chainmask = 1;
695 /* Enable rx chain mask detection if configured to do so */
697 sc->sc_rx_chainmask_detect = 0;
699 /* Set aggregation protection mode parameters */
701 sc->sc_config.ath_aggr_prot = 0;
704 * Reset our TSF so that its value is lower than the beacon that we are
705 * trying to catch. Only then hw will update its TSF register with the
706 * new beacon. Reset the TSF before setting the BSSID to avoid allowing
707 * in any frames that would update our TSF only to have us clear it
708 * immediately thereafter.
710 ath9k_hw_reset_tsf(ah);
714 * Disable BMISS interrupt when we're not associated
716 ath9k_hw_set_interrupts(ah,
717 sc->sc_imask & ~(HAL_INT_SWBA | HAL_INT_BMISS));
718 sc->sc_imask &= ~(HAL_INT_SWBA | HAL_INT_BMISS);
719 /* need to reconfigure the beacons when it moves to RUN */
725 int ath_vap_up(struct ath_softc *sc,
727 const u_int8_t bssid[ETH_ALEN],
728 u_int8_t aid, u_int flags)
730 struct ath_hal *ah = sc->sc_ah;
734 DECLARE_MAC_BUF(mac);
736 ASSERT(if_id != ATH_IF_ID_ANY);
737 avp = sc->sc_vaps[if_id];
739 DPRINTF(sc, ATH_DEBUG_FATAL, "%s: invalid interface id %u\n",
744 /* update ratectrl about the new state */
745 ath_rate_newstate(sc, avp, 1);
747 rfilt = ath_calcrxfilter(sc);
748 ath9k_hw_setrxfilter(ah, rfilt);
750 if (avp->av_opmode == HAL_M_STA || avp->av_opmode == HAL_M_IBSS) {
751 memcpy(sc->sc_curbssid, bssid, ETH_ALEN);
753 ath9k_hw_write_associd(ah, sc->sc_curbssid, sc->sc_curaid);
756 DPRINTF(sc, ATH_DEBUG_CONFIG,
757 "%s: RX filter 0x%x bssid %s aid 0x%x\n",
759 print_mac(mac, sc->sc_curbssid), sc->sc_curaid);
761 if ((avp->av_opmode != IEEE80211_IF_TYPE_STA) &&
762 (flags & ATH_IF_PRIVACY)) {
763 for (i = 0; i < IEEE80211_WEP_NKID; i++)
764 if (ath9k_hw_keyisvalid(ah, (u_int16_t) i))
765 ath9k_hw_keysetmac(ah, (u_int16_t) i, bssid);
768 switch (avp->av_opmode) {
772 * Allocate and setup the beacon frame.
774 * Stop any previous beacon DMA. This may be
775 * necessary, for example, when an ibss merge
776 * causes reconfiguration; there will be a state
777 * transition from RUN->RUN that means we may
778 * be called with beacon transmission active.
780 ath9k_hw_stoptxdma(ah, sc->sc_bhalq);
782 error = ath_beacon_alloc(sc, if_id);
786 if (flags & ATH_IF_BEACON_ENABLE)
792 * start rx chain mask detection if it is enabled.
793 * Use the default chainmask as starting point.
795 if (sc->sc_rx_chainmask_detect) {
796 if (flags & ATH_IF_HT)
797 sc->sc_rx_chainmask =
798 ah->ah_caps.halRxChainMask;
800 sc->sc_rx_chainmask = 1;
802 sc->sc_rx_chainmask_start = 1;
808 /* Moved beacon_config after dfs_wait check
809 * so that ath_beacon_config won't be called duing dfswait
810 * period - this will fix the beacon stuck afer DFS
812 * Configure the beacon and sleep timers. */
814 if (!sc->sc_beacons && !(flags & ATH_IF_BEACON_SYNC)) {
815 ath_beacon_config(sc, if_id);
819 /* Reset rssi stats; maybe not the best place... */
820 if (flags & ATH_IF_HW_ON) {
821 sc->sc_halstats.ns_avgbrssi = ATH_RSSI_DUMMY_MARKER;
822 sc->sc_halstats.ns_avgrssi = ATH_RSSI_DUMMY_MARKER;
823 sc->sc_halstats.ns_avgtxrssi = ATH_RSSI_DUMMY_MARKER;
824 sc->sc_halstats.ns_avgtxrate = ATH_RATE_DUMMY_MARKER;
830 int ath_vap_attach(struct ath_softc *sc,
832 struct ieee80211_vif *if_data,
833 enum hal_opmode opmode,
834 enum hal_opmode iv_opmode,
839 if (if_id >= ATH_BCBUF || sc->sc_vaps[if_id] != NULL) {
840 DPRINTF(sc, ATH_DEBUG_FATAL,
841 "%s: Invalid interface id = %u\n", __func__, if_id);
847 sc->sc_nostabeacons = nostabeacons;
853 /* copy nostabeacons - for WDS client */
854 sc->sc_nostabeacons = nostabeacons;
855 /* XXX not right, beacon buffer is allocated on RUN trans */
856 if (list_empty(&sc->sc_bbuf))
864 avp = kmalloc(sizeof(struct ath_vap), GFP_KERNEL);
868 memzero(avp, sizeof(struct ath_vap));
869 avp->av_if_data = if_data;
870 /* Set the VAP opmode */
871 avp->av_opmode = iv_opmode;
873 INIT_LIST_HEAD(&avp->av_mcastq.axq_q);
874 INIT_LIST_HEAD(&avp->av_mcastq.axq_acq);
875 spin_lock_init(&avp->av_mcastq.axq_lock);
876 if (opmode == HAL_M_HOSTAP || opmode == HAL_M_IBSS) {
877 if (sc->sc_hastsfadd) {
879 * Multiple vaps are to transmit beacons and we
880 * have h/w support for TSF adjusting; enable use
881 * of staggered beacons.
883 /* XXX check for beacon interval too small */
884 sc->sc_stagbeacons = 1;
887 if (sc->sc_hastsfadd)
888 ath9k_hw_set_tsfadjust(sc->sc_ah, sc->sc_stagbeacons);
890 sc->sc_vaps[if_id] = avp;
892 /* Set the device opmode */
893 sc->sc_opmode = opmode;
895 /* default VAP configuration */
896 avp->av_config.av_fixed_rateset = IEEE80211_FIXED_RATE_NONE;
897 avp->av_config.av_fixed_retryset = 0x03030303;
902 int ath_vap_detach(struct ath_softc *sc, int if_id)
904 struct ath_hal *ah = sc->sc_ah;
907 avp = sc->sc_vaps[if_id];
909 DPRINTF(sc, ATH_DEBUG_FATAL, "%s: invalid interface id %u\n",
915 * Quiesce the hardware while we remove the vap. In
916 * particular we need to reclaim all references to the
917 * vap state by any frames pending on the tx queues.
919 * XXX can we do this w/o affecting other vap's?
921 ath9k_hw_set_interrupts(ah, 0); /* disable interrupts */
922 ath_draintxq(sc, AH_FALSE); /* stop xmit side */
923 ath_stoprecv(sc); /* stop recv side */
924 ath_flushrecv(sc); /* flush recv queue */
926 /* Reclaim any pending mcast bufs on the vap. */
927 ath_tx_draintxq(sc, &avp->av_mcastq, AH_FALSE);
929 if (sc->sc_opmode == HAL_M_HOSTAP && sc->sc_nostabeacons)
930 sc->sc_nostabeacons = 0;
933 sc->sc_vaps[if_id] = NULL;
936 /* restart H/W in case there are other VAPs */
938 /* Restart rx+tx machines if device is still running. */
939 if (ath_startrecv(sc) != 0) /* restart recv */
940 DPRINTF(sc, ATH_DEBUG_FATAL,
941 "%s: unable to start recv logic\n", __func__);
943 /* restart beacons */
944 ath_beacon_config(sc, ATH_IF_ID_ANY);
946 ath9k_hw_set_interrupts(ah, sc->sc_imask);
951 int ath_vap_config(struct ath_softc *sc,
952 int if_id, struct ath_vap_config *if_config)
956 if (if_id >= ATH_BCBUF) {
957 DPRINTF(sc, ATH_DEBUG_FATAL,
958 "%s: Invalid interface id = %u\n", __func__, if_id);
962 avp = sc->sc_vaps[if_id];
966 memcpy(&avp->av_config, if_config, sizeof(avp->av_config));
975 int ath_open(struct ath_softc *sc, struct hal_channel *initial_chan)
977 struct ath_hal *ah = sc->sc_ah;
978 enum hal_status status;
980 enum hal_ht_macmode ht_macmode = ath_cwm_macmode(sc);
982 DPRINTF(sc, ATH_DEBUG_CONFIG, "%s: mode %d\n", __func__, sc->sc_opmode);
985 * Stop anything previously setup. This is safe
986 * whether this is the first time through or not.
990 /* Initialize chanmask selection */
991 sc->sc_tx_chainmask = ah->ah_caps.halTxChainMask;
992 sc->sc_rx_chainmask = ah->ah_caps.halRxChainMask;
994 /* Reset SERDES registers */
995 ath9k_hw_configpcipowersave(ah, 0);
998 * The basic interface to setting the hardware in a good
999 * state is ``reset''. On return the hardware is known to
1000 * be powered up and with interrupts disabled. This must
1001 * be followed by initialization of the appropriate bits
1002 * and then setup of the interrupt mask.
1004 sc->sc_curchan = *initial_chan;
1006 spin_lock_bh(&sc->sc_resetlock);
1007 if (!ath9k_hw_reset(ah, sc->sc_opmode, &sc->sc_curchan, ht_macmode,
1008 sc->sc_tx_chainmask, sc->sc_rx_chainmask,
1009 sc->sc_ht_extprotspacing, AH_FALSE, &status)) {
1010 DPRINTF(sc, ATH_DEBUG_FATAL,
1011 "%s: unable to reset hardware; hal status %u "
1012 "(freq %u flags 0x%x)\n", __func__, status,
1013 sc->sc_curchan.channel, sc->sc_curchan.channelFlags);
1015 spin_unlock_bh(&sc->sc_resetlock);
1018 spin_unlock_bh(&sc->sc_resetlock);
1020 * This is needed only to setup initial state
1021 * but it's best done after a reset.
1023 ath_update_txpow(sc);
1026 * Setup the hardware after reset:
1027 * The receive engine is set going.
1028 * Frame transmit is handled entirely
1029 * in the frame output path; there's nothing to do
1030 * here except setup the interrupt mask.
1032 if (ath_startrecv(sc) != 0) {
1033 DPRINTF(sc, ATH_DEBUG_FATAL,
1034 "%s: unable to start recv logic\n", __func__);
1038 /* Setup our intr mask. */
1039 sc->sc_imask = HAL_INT_RX | HAL_INT_TX
1040 | HAL_INT_RXEOL | HAL_INT_RXORN
1041 | HAL_INT_FATAL | HAL_INT_GLOBAL;
1043 if (ah->ah_caps.halGTTSupport)
1044 sc->sc_imask |= HAL_INT_GTT;
1046 if (sc->sc_hashtsupport)
1047 sc->sc_imask |= HAL_INT_CST;
1050 * Enable MIB interrupts when there are hardware phy counters.
1051 * Note we only do this (at the moment) for station mode.
1053 if (sc->sc_needmib &&
1054 ((sc->sc_opmode == HAL_M_STA) || (sc->sc_opmode == HAL_M_IBSS)))
1055 sc->sc_imask |= HAL_INT_MIB;
1057 * Some hardware processes the TIM IE and fires an
1058 * interrupt when the TIM bit is set. For hardware
1059 * that does, if not overridden by configuration,
1060 * enable the TIM interrupt when operating as station.
1062 if (ah->ah_caps.halEnhancedPmSupport && sc->sc_opmode == HAL_M_STA &&
1063 !sc->sc_config.swBeaconProcess)
1064 sc->sc_imask |= HAL_INT_TIM;
1066 * Don't enable interrupts here as we've not yet built our
1067 * vap and node data structures, which will be needed as soon
1068 * as we start receiving.
1070 ath_chan_change(sc, initial_chan);
1072 /* XXX: we must make sure h/w is ready and clear invalid flag
1073 * before turning on interrupt. */
1080 * Reset the hardware w/o losing operational state. This is
1081 * basically a more efficient way of doing ath_stop, ath_init,
1082 * followed by state transitions to the current 802.11
1083 * operational state. Used to recover from errors rx overrun
1084 * and to reset the hardware when rf gain settings must be reset.
1087 static int ath_reset_start(struct ath_softc *sc, u_int32_t flag)
1089 struct ath_hal *ah = sc->sc_ah;
1091 ath9k_hw_set_interrupts(ah, 0); /* disable interrupts */
1092 ath_draintxq(sc, flag & RESET_RETRY_TXQ); /* stop xmit side */
1093 ath_stoprecv(sc); /* stop recv side */
1094 ath_flushrecv(sc); /* flush recv queue */
1099 static int ath_reset_end(struct ath_softc *sc, u_int32_t flag)
1101 struct ath_hal *ah = sc->sc_ah;
1103 if (ath_startrecv(sc) != 0) /* restart recv */
1104 DPRINTF(sc, ATH_DEBUG_FATAL,
1105 "%s: unable to start recv logic\n", __func__);
1108 * We may be doing a reset in response to a request
1109 * that changes the channel so update any state that
1110 * might change as a result.
1112 ath_chan_change(sc, &sc->sc_curchan);
1114 ath_update_txpow(sc); /* update tx power state */
1117 ath_beacon_config(sc, ATH_IF_ID_ANY); /* restart beacons */
1118 ath9k_hw_set_interrupts(ah, sc->sc_imask);
1120 /* Restart the txq */
1121 if (flag & RESET_RETRY_TXQ) {
1123 for (i = 0; i < HAL_NUM_TX_QUEUES; i++) {
1124 if (ATH_TXQ_SETUP(sc, i)) {
1125 spin_lock_bh(&sc->sc_txq[i].axq_lock);
1126 ath_txq_schedule(sc, &sc->sc_txq[i]);
1127 spin_unlock_bh(&sc->sc_txq[i].axq_lock);
1134 int ath_reset(struct ath_softc *sc)
1136 struct ath_hal *ah = sc->sc_ah;
1137 enum hal_status status;
1139 enum hal_ht_macmode ht_macmode = ath_cwm_macmode(sc);
1141 /* NB: indicate channel change so we do a full reset */
1142 spin_lock_bh(&sc->sc_resetlock);
1143 if (!ath9k_hw_reset(ah, sc->sc_opmode, &sc->sc_curchan,
1145 sc->sc_tx_chainmask, sc->sc_rx_chainmask,
1146 sc->sc_ht_extprotspacing, AH_FALSE, &status)) {
1147 DPRINTF(sc, ATH_DEBUG_FATAL,
1148 "%s: unable to reset hardware; hal status %u\n",
1152 spin_unlock_bh(&sc->sc_resetlock);
1157 int ath_suspend(struct ath_softc *sc)
1159 struct ath_hal *ah = sc->sc_ah;
1161 /* No I/O if device has been surprise removed */
1165 /* Shut off the interrupt before setting sc->sc_invalid to '1' */
1166 ath9k_hw_set_interrupts(ah, 0);
1168 /* XXX: we must make sure h/w will not generate any interrupt
1169 * before setting the invalid flag. */
1172 /* disable HAL and put h/w to sleep */
1173 ath9k_hw_disable(sc->sc_ah);
1175 ath9k_hw_configpcipowersave(sc->sc_ah, 1);
1180 /* Interrupt handler. Most of the actual processing is deferred.
1181 * It's the caller's responsibility to ensure the chip is awake. */
1183 int ath_intr(struct ath_softc *sc)
1185 struct ath_hal *ah = sc->sc_ah;
1186 enum hal_int status;
1187 int sched = ATH_ISR_NOSCHED;
1190 if (sc->sc_invalid) {
1192 * The hardware is not ready/present, don't
1193 * touch anything. Note this can happen early
1194 * on if the IRQ is shared.
1196 return ATH_ISR_NOTMINE;
1198 if (!ath9k_hw_intrpend(ah)) { /* shared irq, not for us */
1199 return ATH_ISR_NOTMINE;
1203 * Figure out the reason(s) for the interrupt. Note
1204 * that the hal returns a pseudo-ISR that may include
1205 * bits we haven't explicitly enabled so we mask the
1206 * value to insure we only process bits we requested.
1208 ath9k_hw_getisr(ah, &status); /* NB: clears ISR too */
1210 status &= sc->sc_imask; /* discard unasked-for bits */
1213 * If there are no status bits set, then this interrupt was not
1214 * for me (should have been caught above).
1218 return ATH_ISR_NOTMINE;
1220 sc->sc_intrstatus = status;
1222 if (status & HAL_INT_FATAL) {
1223 /* need a chip reset */
1224 sched = ATH_ISR_SCHED;
1225 } else if (status & HAL_INT_RXORN) {
1226 /* need a chip reset */
1227 sched = ATH_ISR_SCHED;
1229 if (status & HAL_INT_SWBA) {
1230 /* schedule a tasklet for beacon handling */
1231 tasklet_schedule(&sc->bcon_tasklet);
1233 if (status & HAL_INT_RXEOL) {
1235 * NB: the hardware should re-read the link when
1236 * RXE bit is written, but it doesn't work
1237 * at least on older hardware revs.
1239 sched = ATH_ISR_SCHED;
1242 if (status & HAL_INT_TXURN)
1243 /* bump tx trigger level */
1244 ath9k_hw_updatetxtriglevel(ah, AH_TRUE);
1245 /* XXX: optimize this */
1246 if (status & HAL_INT_RX)
1247 sched = ATH_ISR_SCHED;
1248 if (status & HAL_INT_TX)
1249 sched = ATH_ISR_SCHED;
1250 if (status & HAL_INT_BMISS)
1251 sched = ATH_ISR_SCHED;
1252 /* carrier sense timeout */
1253 if (status & HAL_INT_CST)
1254 sched = ATH_ISR_SCHED;
1255 if (status & HAL_INT_MIB) {
1257 * Disable interrupts until we service the MIB
1258 * interrupt; otherwise it will continue to
1261 ath9k_hw_set_interrupts(ah, 0);
1263 * Let the hal handle the event. We assume
1264 * it will clear whatever condition caused
1267 ath9k_hw_procmibevent(ah, &sc->sc_halstats);
1268 ath9k_hw_set_interrupts(ah, sc->sc_imask);
1270 if (status & HAL_INT_TIM_TIMER) {
1271 if (!sc->sc_hasautosleep) {
1272 /* Clear RxAbort bit so that we can
1274 ath9k_hw_setrxabort(ah, 0);
1275 /* Set flag indicating we're waiting
1277 sc->sc_waitbeacon = 1;
1279 sched = ATH_ISR_SCHED;
1285 if (sched == ATH_ISR_SCHED)
1286 /* turn off every interrupt except SWBA */
1287 ath9k_hw_set_interrupts(ah, (sc->sc_imask & HAL_INT_SWBA));
1293 /* Deferred interrupt processing */
1295 static void ath9k_tasklet(unsigned long data)
1297 struct ath_softc *sc = (struct ath_softc *)data;
1298 u_int32_t status = sc->sc_intrstatus;
1300 if (status & HAL_INT_FATAL) {
1301 /* need a chip reset */
1302 ath_internal_reset(sc);
1306 if (status & (HAL_INT_RX | HAL_INT_RXEOL | HAL_INT_RXORN)) {
1307 /* XXX: fill me in */
1309 if (status & HAL_INT_RXORN) {
1311 if (status & HAL_INT_RXEOL) {
1314 spin_lock_bh(&sc->sc_rxflushlock);
1315 ath_rx_tasklet(sc, 0);
1316 spin_unlock_bh(&sc->sc_rxflushlock);
1318 /* XXX: optimize this */
1319 if (status & HAL_INT_TX)
1321 /* XXX: fill me in */
1323 if (status & HAL_INT_BMISS) {
1325 if (status & (HAL_INT_TIM | HAL_INT_DTIMSYNC)) {
1326 if (status & HAL_INT_TIM) {
1328 if (status & HAL_INT_DTIMSYNC) {
1334 /* re-enable hardware interrupt */
1335 ath9k_hw_set_interrupts(sc->sc_ah, sc->sc_imask);
1338 void ath_set_macmode(struct ath_softc *sc, enum hal_ht_macmode macmode)
1340 ath9k_hw_set11nmac2040(sc->sc_ah, macmode);
1343 int ath_init(u_int16_t devid, struct ath_softc *sc)
1345 struct ath_hal *ah = NULL;
1346 enum hal_status status;
1351 /* XXX: hardware will not be ready until ath_open() being called */
1354 sc->sc_debug = DBG_DEFAULT;
1355 DPRINTF(sc, ATH_DEBUG_CONFIG, "%s: devid 0x%x\n", __func__, devid);
1357 /* Initialize tasklet */
1358 tasklet_init(&sc->intr_tq, ath9k_tasklet, (unsigned long)sc);
1359 tasklet_init(&sc->bcon_tasklet, ath9k_beacon_tasklet,
1363 * Cache line size is used to size and align various
1364 * structures used to communicate with the hardware.
1366 bus_read_cachesize(sc, &csz);
1367 /* XXX assert csz is non-zero */
1368 sc->sc_cachelsz = csz << 2; /* convert to bytes */
1370 spin_lock_init(&sc->sc_resetlock);
1372 ah = ath9k_hw_attach(devid, sc, sc->mem, &status);
1374 DPRINTF(sc, ATH_DEBUG_FATAL,
1375 "%s: unable to attach hardware; HAL status %u\n",
1382 /* Get the chipset-specific aggr limit. */
1383 sc->sc_rtsaggrlimit = ah->ah_caps.halRtsAggrLimit;
1386 * Check if the MAC has multi-rate retry support.
1387 * We do this by trying to setup a fake extended
1388 * descriptor. MAC's that don't have support will
1389 * return false w/o doing anything. MAC's that do
1390 * support it will return true w/o doing anything.
1392 * XXX This is lame. Just query a hal property, Luke!
1394 sc->sc_mrretry = ath9k_hw_setupxtxdesc(ah, NULL, 0, 0, 0, 0, 0, 0);
1397 * Check if the device has hardware counters for PHY
1398 * errors. If so we need to enable the MIB interrupt
1399 * so we can act on stat triggers.
1401 if (ath9k_hw_phycounters(ah))
1404 /* Get the hardware key cache size. */
1405 sc->sc_keymax = ah->ah_caps.halKeyCacheSize;
1406 if (sc->sc_keymax > ATH_KEYMAX) {
1407 DPRINTF(sc, ATH_DEBUG_KEYCACHE,
1408 "%s: Warning, using only %u entries in %u key cache\n",
1409 __func__, ATH_KEYMAX, sc->sc_keymax);
1410 sc->sc_keymax = ATH_KEYMAX;
1414 * Reset the key cache since some parts do not
1415 * reset the contents on initial power up.
1417 for (i = 0; i < sc->sc_keymax; i++)
1418 ath9k_hw_keyreset(ah, (u_int16_t) i);
1420 * Mark key cache slots associated with global keys
1421 * as in use. If we knew TKIP was not to be used we
1422 * could leave the +32, +64, and +32+64 slots free.
1423 * XXX only for splitmic.
1425 for (i = 0; i < IEEE80211_WEP_NKID; i++) {
1426 set_bit(i, sc->sc_keymap);
1427 set_bit(i + 32, sc->sc_keymap);
1428 set_bit(i + 64, sc->sc_keymap);
1429 set_bit(i + 32 + 64, sc->sc_keymap);
1432 * Collect the channel list using the default country
1433 * code and including outdoor channels. The 802.11 layer
1434 * is resposible for filtering this list based on settings
1435 * like the phy mode.
1437 rd = ah->ah_currentRD;
1439 error = ath_getchannels(sc,
1446 /* default to STA mode */
1447 sc->sc_opmode = HAL_M_MONITOR;
1449 /* Setup rate tables for all potential media types. */
1450 /* 11g encompasses b,g */
1452 ath_rate_setup(sc, WIRELESS_MODE_11a);
1453 ath_rate_setup(sc, WIRELESS_MODE_11g);
1455 /* NB: setup here so ath_rate_update is happy */
1456 ath_setcurmode(sc, WIRELESS_MODE_11a);
1459 * Allocate hardware transmit queues: one queue for
1460 * beacon frames and one data queue for each QoS
1461 * priority. Note that the hal handles reseting
1462 * these queues at the needed time.
1464 sc->sc_bhalq = ath_beaconq_setup(ah);
1465 if (sc->sc_bhalq == -1) {
1466 DPRINTF(sc, ATH_DEBUG_FATAL,
1467 "%s: unable to setup a beacon xmit queue\n", __func__);
1471 sc->sc_cabq = ath_txq_setup(sc, HAL_TX_QUEUE_CAB, 0);
1472 if (sc->sc_cabq == NULL) {
1473 DPRINTF(sc, ATH_DEBUG_FATAL,
1474 "%s: unable to setup CAB xmit queue\n", __func__);
1479 sc->sc_config.cabqReadytime = ATH_CABQ_READY_TIME;
1480 ath_cabq_update(sc);
1482 for (i = 0; i < ARRAY_SIZE(sc->sc_haltype2q); i++)
1483 sc->sc_haltype2q[i] = -1;
1485 /* Setup data queues */
1486 /* NB: ensure BK queue is the lowest priority h/w queue */
1487 if (!ath_tx_setup(sc, HAL_WME_AC_BK)) {
1488 DPRINTF(sc, ATH_DEBUG_FATAL,
1489 "%s: unable to setup xmit queue for BK traffic\n",
1495 if (!ath_tx_setup(sc, HAL_WME_AC_BE)) {
1496 DPRINTF(sc, ATH_DEBUG_FATAL,
1497 "%s: unable to setup xmit queue for BE traffic\n",
1502 if (!ath_tx_setup(sc, HAL_WME_AC_VI)) {
1503 DPRINTF(sc, ATH_DEBUG_FATAL,
1504 "%s: unable to setup xmit queue for VI traffic\n",
1509 if (!ath_tx_setup(sc, HAL_WME_AC_VO)) {
1510 DPRINTF(sc, ATH_DEBUG_FATAL,
1511 "%s: unable to setup xmit queue for VO traffic\n",
1517 if (ah->ah_caps.halHTSupport)
1518 sc->sc_hashtsupport = 1;
1520 sc->sc_rc = ath_rate_attach(ah);
1521 if (sc->sc_rc == NULL) {
1526 if (ath9k_hw_getcapability(ah, HAL_CAP_CIPHER, HAL_CIPHER_TKIP, NULL)) {
1528 * Whether we should enable h/w TKIP MIC.
1529 * XXX: if we don't support WME TKIP MIC, then we wouldn't
1530 * report WMM capable, so it's always safe to turn on
1531 * TKIP MIC in this case.
1533 ath9k_hw_setcapability(sc->sc_ah, HAL_CAP_TKIP_MIC, 0, 1, NULL);
1535 sc->sc_hasclrkey = ath9k_hw_getcapability(ah, HAL_CAP_CIPHER,
1536 HAL_CIPHER_CLR, NULL);
1539 * Check whether the separate key cache entries
1540 * are required to handle both tx+rx MIC keys.
1541 * With split mic keys the number of stations is limited
1542 * to 27 otherwise 59.
1544 if (ath9k_hw_getcapability(ah, HAL_CAP_CIPHER, HAL_CIPHER_TKIP, NULL)
1545 && ath9k_hw_getcapability(ah, HAL_CAP_CIPHER, HAL_CIPHER_MIC, NULL)
1546 && ath9k_hw_getcapability(ah, HAL_CAP_TKIP_SPLIT, 0, NULL))
1547 sc->sc_splitmic = 1;
1549 /* turn on mcast key search if possible */
1550 if (ath9k_hw_getcapability(ah, HAL_CAP_MCAST_KEYSRCH, 0, NULL)
1552 (void)ath9k_hw_setcapability(ah, HAL_CAP_MCAST_KEYSRCH, 1,
1555 sc->sc_config.txpowlimit = ATH_TXPOWER_MAX;
1556 sc->sc_config.txpowlimit_override = 0;
1558 /* 11n Capabilities */
1559 if (sc->sc_hashtsupport) {
1564 /* Check for misc other capabilities. */
1565 sc->sc_hasbmask = ah->ah_caps.halBssIdMaskSupport ? 1 : 0;
1567 ath9k_hw_getcapability(ah, HAL_CAP_TSF_ADJUST, 0, NULL);
1570 * If we cannot transmit on three chains, prevent chain mask
1571 * selection logic from switching between 2x2 and 3x3 chain
1572 * masks based on RSSI.
1574 sc->sc_no_tx_3_chains =
1575 (ah->ah_caps.halTxChainMask == ATH_CHAINMASK_SEL_3X3) ?
1577 sc->sc_config.chainmask_sel = sc->sc_no_tx_3_chains;
1579 sc->sc_tx_chainmask = ah->ah_caps.halTxChainMask;
1580 sc->sc_rx_chainmask = ah->ah_caps.halRxChainMask;
1582 /* Configuration for rx chain detection */
1583 sc->sc_rxchaindetect_ref = 0;
1584 sc->sc_rxchaindetect_thresh5GHz = 35;
1585 sc->sc_rxchaindetect_thresh2GHz = 35;
1586 sc->sc_rxchaindetect_delta5GHz = 30;
1587 sc->sc_rxchaindetect_delta2GHz = 30;
1590 * Query the hal about antenna support
1591 * Enable rx fast diversity if hal has support
1593 if (ath9k_hw_getcapability(ah, HAL_CAP_DIVERSITY, 0, NULL)) {
1594 sc->sc_hasdiversity = 1;
1595 ath9k_hw_setcapability(ah, HAL_CAP_DIVERSITY,
1597 sc->sc_diversity = 1;
1599 sc->sc_hasdiversity = 0;
1600 sc->sc_diversity = 0;
1601 ath9k_hw_setcapability(ah, HAL_CAP_DIVERSITY,
1604 sc->sc_defant = ath9k_hw_getdefantenna(ah);
1607 * Not all chips have the VEOL support we want to
1608 * use with IBSS beacons; check here for it.
1610 sc->sc_hasveol = ah->ah_caps.halVEOLSupport;
1612 ath9k_hw_getmac(ah, sc->sc_myaddr);
1613 if (sc->sc_hasbmask) {
1614 ath9k_hw_getbssidmask(ah, sc->sc_bssidmask);
1615 ATH_SET_VAP_BSSID_MASK(sc->sc_bssidmask);
1616 ath9k_hw_setbssidmask(ah, sc->sc_bssidmask);
1618 sc->sc_hasautosleep = ah->ah_caps.halAutoSleepSupport;
1619 sc->sc_waitbeacon = 0;
1620 sc->sc_slottime = HAL_SLOT_TIME_9; /* default to short slot time */
1622 /* initialize beacon slots */
1623 for (i = 0; i < ARRAY_SIZE(sc->sc_bslot); i++)
1624 sc->sc_bslot[i] = ATH_IF_ID_ANY;
1626 /* save MISC configurations */
1627 sc->sc_config.swBeaconProcess = 1;
1629 #ifdef CONFIG_SLOW_ANT_DIV
1630 sc->sc_slowAntDiv = 1;
1631 /* range is 40 - 255, we use something in the middle */
1632 ath_slow_ant_div_init(&sc->sc_antdiv, sc, 0x127);
1634 sc->sc_slowAntDiv = 0;
1639 /* cleanup tx queues */
1640 for (i = 0; i < HAL_NUM_TX_QUEUES; i++)
1641 if (ATH_TXQ_SETUP(sc, i))
1642 ath_tx_cleanupq(sc, &sc->sc_txq[i]);
1645 ath9k_hw_detach(ah);
1649 void ath_deinit(struct ath_softc *sc)
1651 struct ath_hal *ah = sc->sc_ah;
1654 DPRINTF(sc, ATH_DEBUG_CONFIG, "%s\n", __func__);
1657 if (!sc->sc_invalid)
1658 ath9k_hw_setpower(sc->sc_ah, HAL_PM_AWAKE);
1659 ath_rate_detach(sc->sc_rc);
1660 /* cleanup tx queues */
1661 for (i = 0; i < HAL_NUM_TX_QUEUES; i++)
1662 if (ATH_TXQ_SETUP(sc, i))
1663 ath_tx_cleanupq(sc, &sc->sc_txq[i]);
1664 ath9k_hw_detach(ah);
1667 /*******************/
1668 /* Node Management */
1669 /*******************/
1671 struct ath_node *ath_node_attach(struct ath_softc *sc, u8 *addr, int if_id)
1673 struct ath_vap *avp;
1674 struct ath_node *an;
1675 DECLARE_MAC_BUF(mac);
1677 avp = sc->sc_vaps[if_id];
1678 ASSERT(avp != NULL);
1680 /* mac80211 sta_notify callback is from an IRQ context, so no sleep */
1681 an = kmalloc(sizeof(struct ath_node), GFP_ATOMIC);
1684 memzero(an, sizeof(*an));
1687 memcpy(an->an_addr, addr, ETH_ALEN);
1688 atomic_set(&an->an_refcnt, 1);
1690 /* set up per-node tx/rx state */
1691 ath_tx_node_init(sc, an);
1692 ath_rx_node_init(sc, an);
1694 ath_chainmask_sel_init(sc, an);
1695 ath_chainmask_sel_timerstart(&an->an_chainmask_sel);
1696 list_add(&an->list, &sc->node_list);
1698 DPRINTF(sc, ATH_DEBUG_NODE, "%s: an %p for: %s\n",
1699 __func__, an, print_mac(mac, addr));
1704 void ath_node_detach(struct ath_softc *sc, struct ath_node *an, bool bh_flag)
1706 unsigned long flags;
1708 DECLARE_MAC_BUF(mac);
1710 ath_chainmask_sel_timerstop(&an->an_chainmask_sel);
1711 an->an_flags |= ATH_NODE_CLEAN;
1712 ath_tx_node_cleanup(sc, an, bh_flag);
1713 ath_rx_node_cleanup(sc, an);
1715 ath_tx_node_free(sc, an);
1716 ath_rx_node_free(sc, an);
1718 spin_lock_irqsave(&sc->node_lock, flags);
1720 list_del(&an->list);
1722 spin_unlock_irqrestore(&sc->node_lock, flags);
1724 DPRINTF(sc, ATH_DEBUG_NODE, "%s: an %p for: %s\n",
1725 __func__, an, print_mac(mac, an->an_addr));
1730 /* Finds a node and increases the refcnt if found */
1732 struct ath_node *ath_node_get(struct ath_softc *sc, u8 *addr)
1734 struct ath_node *an = NULL, *an_found = NULL;
1736 if (list_empty(&sc->node_list)) /* FIXME */
1738 list_for_each_entry(an, &sc->node_list, list) {
1739 if (!compare_ether_addr(an->an_addr, addr)) {
1740 atomic_inc(&an->an_refcnt);
1749 /* Decrements the refcnt and if it drops to zero, detach the node */
1751 void ath_node_put(struct ath_softc *sc, struct ath_node *an, bool bh_flag)
1753 if (atomic_dec_and_test(&an->an_refcnt))
1754 ath_node_detach(sc, an, bh_flag);
1757 /* Finds a node, doesn't increment refcnt. Caller must hold sc->node_lock */
1758 struct ath_node *ath_node_find(struct ath_softc *sc, u8 *addr)
1760 struct ath_node *an = NULL, *an_found = NULL;
1762 if (list_empty(&sc->node_list))
1765 list_for_each_entry(an, &sc->node_list, list)
1766 if (!compare_ether_addr(an->an_addr, addr)) {
1777 * Setup driver-specific state for a newly associated node. This routine
1778 * really only applies if compression or XR are enabled, there is no code
1779 * covering any other cases.
1782 void ath_newassoc(struct ath_softc *sc,
1783 struct ath_node *an, int isnew, int isuapsd)
1787 /* if station reassociates, tear down the aggregation state. */
1789 for (tidno = 0; tidno < WME_NUM_TID; tidno++) {
1791 ath_tx_aggr_teardown(sc, an, tidno);
1793 ath_rx_aggr_teardown(sc, an, tidno);
1802 void ath_key_reset(struct ath_softc *sc, u_int16_t keyix, int freeslot)
1804 ath9k_hw_keyreset(sc->sc_ah, keyix);
1806 clear_bit(keyix, sc->sc_keymap);
1809 int ath_keyset(struct ath_softc *sc,
1811 struct hal_keyval *hk,
1812 const u_int8_t mac[ETH_ALEN])
1814 enum hal_bool status;
1816 status = ath9k_hw_set_keycache_entry(sc->sc_ah,
1817 keyix, hk, mac, AH_FALSE);
1819 return status != AH_FALSE;
1822 /***********************/
1823 /* TX Power/Regulatory */
1824 /***********************/
1827 * Set Transmit power in HAL
1829 * This routine makes the actual HAL calls to set the new transmit power
1833 void ath_update_txpow(struct ath_softc *sc)
1835 struct ath_hal *ah = sc->sc_ah;
1838 if (sc->sc_curtxpow != sc->sc_config.txpowlimit) {
1839 ath9k_hw_set_txpowerlimit(ah, sc->sc_config.txpowlimit);
1840 /* read back in case value is clamped */
1841 ath9k_hw_getcapability(ah, HAL_CAP_TXPOW, 1, &txpow);
1842 sc->sc_curtxpow = txpow;
1846 /* Return the current country and domain information */
1847 void ath_get_currentCountry(struct ath_softc *sc,
1848 struct hal_country_entry *ctry)
1850 ath9k_regd_get_current_country(sc->sc_ah, ctry);
1852 /* If HAL not specific yet, since it is band dependent,
1853 * use the one we passed in. */
1854 if (ctry->countryCode == CTRY_DEFAULT) {
1857 } else if (ctry->iso[0] && ctry->iso[1]) {
1858 if (!ctry->iso[2]) {
1867 /**************************/
1868 /* Slow Antenna Diversity */
1869 /**************************/
1871 void ath_slow_ant_div_init(struct ath_antdiv *antdiv,
1872 struct ath_softc *sc,
1877 /* antdivf_rssitrig can range from 40 - 0xff */
1878 trig = (rssitrig > 0xff) ? 0xff : rssitrig;
1879 trig = (rssitrig < 40) ? 40 : rssitrig;
1881 antdiv->antdiv_sc = sc;
1882 antdiv->antdivf_rssitrig = trig;
1885 void ath_slow_ant_div_start(struct ath_antdiv *antdiv,
1886 u_int8_t num_antcfg,
1887 const u_int8_t *bssid)
1889 antdiv->antdiv_num_antcfg =
1890 num_antcfg < ATH_ANT_DIV_MAX_CFG ?
1891 num_antcfg : ATH_ANT_DIV_MAX_CFG;
1892 antdiv->antdiv_state = ATH_ANT_DIV_IDLE;
1893 antdiv->antdiv_curcfg = 0;
1894 antdiv->antdiv_bestcfg = 0;
1895 antdiv->antdiv_laststatetsf = 0;
1897 memcpy(antdiv->antdiv_bssid, bssid, sizeof(antdiv->antdiv_bssid));
1899 antdiv->antdiv_start = 1;
1902 void ath_slow_ant_div_stop(struct ath_antdiv *antdiv)
1904 antdiv->antdiv_start = 0;
1907 static int32_t ath_find_max_val(int32_t *val,
1908 u_int8_t num_val, u_int8_t *max_index)
1910 u_int32_t MaxVal = *val++;
1911 u_int32_t cur_index = 0;
1914 while (++cur_index < num_val) {
1915 if (*val > MaxVal) {
1917 *max_index = cur_index;
1926 void ath_slow_ant_div(struct ath_antdiv *antdiv,
1927 struct ieee80211_hdr *hdr,
1928 struct ath_rx_status *rx_stats)
1930 struct ath_softc *sc = antdiv->antdiv_sc;
1931 struct ath_hal *ah = sc->sc_ah;
1932 u_int64_t curtsf = 0;
1933 u_int8_t bestcfg, curcfg = antdiv->antdiv_curcfg;
1934 __le16 fc = hdr->frame_control;
1936 if (antdiv->antdiv_start && ieee80211_is_beacon(fc)
1937 && !compare_ether_addr(hdr->addr3, antdiv->antdiv_bssid)) {
1938 antdiv->antdiv_lastbrssi[curcfg] = rx_stats->rs_rssi;
1939 antdiv->antdiv_lastbtsf[curcfg] = ath9k_hw_gettsf64(sc->sc_ah);
1940 curtsf = antdiv->antdiv_lastbtsf[curcfg];
1945 switch (antdiv->antdiv_state) {
1946 case ATH_ANT_DIV_IDLE:
1947 if ((antdiv->antdiv_lastbrssi[curcfg] <
1948 antdiv->antdivf_rssitrig)
1949 && ((curtsf - antdiv->antdiv_laststatetsf) >
1950 ATH_ANT_DIV_MIN_IDLE_US)) {
1953 if (curcfg == antdiv->antdiv_num_antcfg)
1956 if (HAL_OK == ath9k_hw_select_antconfig(ah, curcfg)) {
1957 antdiv->antdiv_bestcfg = antdiv->antdiv_curcfg;
1958 antdiv->antdiv_curcfg = curcfg;
1959 antdiv->antdiv_laststatetsf = curtsf;
1960 antdiv->antdiv_state = ATH_ANT_DIV_SCAN;
1965 case ATH_ANT_DIV_SCAN:
1966 if ((curtsf - antdiv->antdiv_laststatetsf) <
1967 ATH_ANT_DIV_MIN_SCAN_US)
1971 if (curcfg == antdiv->antdiv_num_antcfg)
1974 if (curcfg == antdiv->antdiv_bestcfg) {
1975 ath_find_max_val(antdiv->antdiv_lastbrssi,
1976 antdiv->antdiv_num_antcfg, &bestcfg);
1977 if (HAL_OK == ath9k_hw_select_antconfig(ah, bestcfg)) {
1978 antdiv->antdiv_bestcfg = bestcfg;
1979 antdiv->antdiv_curcfg = bestcfg;
1980 antdiv->antdiv_laststatetsf = curtsf;
1981 antdiv->antdiv_state = ATH_ANT_DIV_IDLE;
1984 if (HAL_OK == ath9k_hw_select_antconfig(ah, curcfg)) {
1985 antdiv->antdiv_curcfg = curcfg;
1986 antdiv->antdiv_laststatetsf = curtsf;
1987 antdiv->antdiv_state = ATH_ANT_DIV_SCAN;
1995 /***********************/
1996 /* Descriptor Handling */
1997 /***********************/
2000 * Set up DMA descriptors
2002 * This function will allocate both the DMA descriptor structure, and the
2003 * buffers it contains. These are used to contain the descriptors used
2007 int ath_descdma_setup(struct ath_softc *sc,
2008 struct ath_descdma *dd,
2009 struct list_head *head,
2014 #define DS2PHYS(_dd, _ds) \
2015 ((_dd)->dd_desc_paddr + ((caddr_t)(_ds) - (caddr_t)(_dd)->dd_desc))
2016 #define ATH_DESC_4KB_BOUND_CHECK(_daddr) ((((_daddr) & 0xFFF) > 0xF7F) ? 1 : 0)
2017 #define ATH_DESC_4KB_BOUND_NUM_SKIPPED(_len) ((_len) / 4096)
2019 struct ath_desc *ds;
2021 int i, bsize, error;
2023 DPRINTF(sc, ATH_DEBUG_CONFIG, "%s: %s DMA: %u buffers %u desc/buf\n",
2024 __func__, name, nbuf, ndesc);
2026 /* ath_desc must be a multiple of DWORDs */
2027 if ((sizeof(struct ath_desc) % 4) != 0) {
2028 DPRINTF(sc, ATH_DEBUG_FATAL, "%s: ath_desc not DWORD aligned\n",
2030 ASSERT((sizeof(struct ath_desc) % 4) == 0);
2036 dd->dd_desc_len = sizeof(struct ath_desc) * nbuf * ndesc;
2039 * Need additional DMA memory because we can't use
2040 * descriptors that cross the 4K page boundary. Assume
2041 * one skipped descriptor per 4K page.
2043 if (!(sc->sc_ah->ah_caps.hal4kbSplitTransSupport)) {
2044 u_int32_t ndesc_skipped =
2045 ATH_DESC_4KB_BOUND_NUM_SKIPPED(dd->dd_desc_len);
2048 while (ndesc_skipped) {
2049 dma_len = ndesc_skipped * sizeof(struct ath_desc);
2050 dd->dd_desc_len += dma_len;
2052 ndesc_skipped = ATH_DESC_4KB_BOUND_NUM_SKIPPED(dma_len);
2056 /* allocate descriptors */
2057 dd->dd_desc = pci_alloc_consistent(sc->pdev,
2059 &dd->dd_desc_paddr);
2060 if (dd->dd_desc == NULL) {
2065 DPRINTF(sc, ATH_DEBUG_CONFIG, "%s: %s DMA map: %p (%u) -> %llx (%u)\n",
2066 __func__, dd->dd_name, ds, (u_int32_t) dd->dd_desc_len,
2067 ito64(dd->dd_desc_paddr), /*XXX*/(u_int32_t) dd->dd_desc_len);
2069 /* allocate buffers */
2070 bsize = sizeof(struct ath_buf) * nbuf;
2071 bf = kmalloc(bsize, GFP_KERNEL);
2079 INIT_LIST_HEAD(head);
2080 for (i = 0; i < nbuf; i++, bf++, ds += ndesc) {
2082 bf->bf_daddr = DS2PHYS(dd, ds);
2084 if (!(sc->sc_ah->ah_caps.hal4kbSplitTransSupport)) {
2086 * Skip descriptor addresses which can cause 4KB
2087 * boundary crossing (addr + length) with a 32 dword
2090 while (ATH_DESC_4KB_BOUND_CHECK(bf->bf_daddr)) {
2091 ASSERT((caddr_t) bf->bf_desc <
2092 ((caddr_t) dd->dd_desc +
2097 bf->bf_daddr = DS2PHYS(dd, ds);
2100 list_add_tail(&bf->list, head);
2104 pci_free_consistent(sc->pdev,
2105 dd->dd_desc_len, dd->dd_desc, dd->dd_desc_paddr);
2107 memzero(dd, sizeof(*dd));
2109 #undef ATH_DESC_4KB_BOUND_CHECK
2110 #undef ATH_DESC_4KB_BOUND_NUM_SKIPPED
2115 * Cleanup DMA descriptors
2117 * This function will free the DMA block that was allocated for the descriptor
2118 * pool. Since this was allocated as one "chunk", it is freed in the same
2122 void ath_descdma_cleanup(struct ath_softc *sc,
2123 struct ath_descdma *dd,
2124 struct list_head *head)
2126 /* Free memory associated with descriptors */
2127 pci_free_consistent(sc->pdev,
2128 dd->dd_desc_len, dd->dd_desc, dd->dd_desc_paddr);
2130 INIT_LIST_HEAD(head);
2131 kfree(dd->dd_bufptr);
2132 memzero(dd, sizeof(*dd));
2139 void ath_internal_reset(struct ath_softc *sc)
2141 ath_reset_start(sc, 0);
2143 ath_reset_end(sc, 0);
2146 void ath_setrxfilter(struct ath_softc *sc)
2150 rxfilt = ath_calcrxfilter(sc);
2151 ath9k_hw_setrxfilter(sc->sc_ah, rxfilt);
2154 int ath_get_hal_qnum(u16 queue, struct ath_softc *sc)
2160 qnum = sc->sc_haltype2q[HAL_WME_AC_VO];
2163 qnum = sc->sc_haltype2q[HAL_WME_AC_VI];
2166 qnum = sc->sc_haltype2q[HAL_WME_AC_BE];
2169 qnum = sc->sc_haltype2q[HAL_WME_AC_BK];
2172 qnum = sc->sc_haltype2q[HAL_WME_AC_BE];
2179 int ath_get_mac80211_qnum(u_int queue, struct ath_softc *sc)
2206 * Expand time stamp to TSF
2208 * Extend 15-bit time stamp from rx descriptor to
2209 * a full 64-bit TSF using the current h/w TSF.
2212 u_int64_t ath_extend_tsf(struct ath_softc *sc, u_int32_t rstamp)
2216 tsf = ath9k_hw_gettsf64(sc->sc_ah);
2217 if ((tsf & 0x7fff) < rstamp)
2219 return (tsf & ~0x7fff) | rstamp;
2223 * Set Default Antenna
2225 * Call into the HAL to set the default antenna to use. Not really valid for
2229 void ath_setdefantenna(void *context, u_int antenna)
2231 struct ath_softc *sc = (struct ath_softc *)context;
2232 struct ath_hal *ah = sc->sc_ah;
2234 /* XXX block beacon interrupts */
2235 ath9k_hw_setantenna(ah, antenna);
2236 sc->sc_defant = antenna;
2237 sc->sc_rxotherant = 0;
2243 * This will wake up the chip if required, and set the slot time for the
2244 * frame (maximum transmit time). Slot time is assumed to be already set
2245 * in the ATH object member sc_slottime
2248 void ath_setslottime(struct ath_softc *sc)
2250 ath9k_hw_setslottime(sc->sc_ah, sc->sc_slottime);
2251 sc->sc_updateslot = OK;