aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/ath9k/xmit.c
diff options
context:
space:
mode:
authorSujith <Sujith.Manoharan@atheros.com>2008-10-29 00:45:16 -0400
committerJohn W. Linville <linville@tuxdriver.com>2008-11-10 15:14:56 -0500
commit102e0572d330e6cdb89a8f8fbd3999e3c67a1f9e (patch)
treebe8df3f62c3f506ea8cec1e5285b810b5f8461d8 /drivers/net/wireless/ath9k/xmit.c
parent43453b3392c1ecfdd1471383ad42ba926533a722 (diff)
ath9k: Ensure ath_node is not NULL when updating tx chainmask
Also, random indentation and whitespace cleanup. Signed-off-by: Sujith <Sujith.Manoharan@atheros.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/ath9k/xmit.c')
-rw-r--r--drivers/net/wireless/ath9k/xmit.c57
1 files changed, 23 insertions, 34 deletions
diff --git a/drivers/net/wireless/ath9k/xmit.c b/drivers/net/wireless/ath9k/xmit.c
index 4e7108a179fb..bd902468868f 100644
--- a/drivers/net/wireless/ath9k/xmit.c
+++ b/drivers/net/wireless/ath9k/xmit.c
@@ -65,11 +65,12 @@ static u32 bits_per_symbol[][2] = {
65 * NB: must be called with txq lock held 65 * NB: must be called with txq lock held
66 */ 66 */
67 67
68static void ath_tx_txqaddbuf(struct ath_softc *sc, 68static void ath_tx_txqaddbuf(struct ath_softc *sc, struct ath_txq *txq,
69 struct ath_txq *txq, struct list_head *head) 69 struct list_head *head)
70{ 70{
71 struct ath_hal *ah = sc->sc_ah; 71 struct ath_hal *ah = sc->sc_ah;
72 struct ath_buf *bf; 72 struct ath_buf *bf;
73
73 /* 74 /*
74 * Insert the frame on the outbound list and 75 * Insert the frame on the outbound list and
75 * pass it on to the hardware. 76 * pass it on to the hardware.
@@ -360,6 +361,7 @@ static void ath_tx_complete_buf(struct ath_softc *sc,
360 if (bf_isxretried(bf)) 361 if (bf_isxretried(bf))
361 tx_status.flags |= ATH_TX_XRETRY; 362 tx_status.flags |= ATH_TX_XRETRY;
362 } 363 }
364
363 /* Unmap this frame */ 365 /* Unmap this frame */
364 pci_unmap_single(sc->pdev, 366 pci_unmap_single(sc->pdev,
365 bf->bf_dmacontext, 367 bf->bf_dmacontext,
@@ -497,8 +499,8 @@ static void ath_tx_set_retry(struct ath_softc *sc, struct ath_buf *bf)
497 499
498/* Update block ack window */ 500/* Update block ack window */
499 501
500static void ath_tx_update_baw(struct ath_softc *sc, 502static void ath_tx_update_baw(struct ath_softc *sc, struct ath_atx_tid *tid,
501 struct ath_atx_tid *tid, int seqno) 503 int seqno)
502{ 504{
503 int index, cindex; 505 int index, cindex;
504 506
@@ -522,12 +524,8 @@ static void ath_tx_update_baw(struct ath_softc *sc,
522 * half_gi - to use 4us v/s 3.6 us for symbol time 524 * half_gi - to use 4us v/s 3.6 us for symbol time
523 */ 525 */
524 526
525static u32 ath_pkt_duration(struct ath_softc *sc, 527static u32 ath_pkt_duration(struct ath_softc *sc, u8 rix, struct ath_buf *bf,
526 u8 rix, 528 int width, int half_gi, bool shortPreamble)
527 struct ath_buf *bf,
528 int width,
529 int half_gi,
530 bool shortPreamble)
531{ 529{
532 const struct ath9k_rate_table *rt = sc->sc_currates; 530 const struct ath9k_rate_table *rt = sc->sc_currates;
533 u32 nbits, nsymbits, duration, nsymbols; 531 u32 nbits, nsymbits, duration, nsymbols;
@@ -541,11 +539,8 @@ static u32 ath_pkt_duration(struct ath_softc *sc,
541 * for legacy rates, use old function to compute packet duration 539 * for legacy rates, use old function to compute packet duration
542 */ 540 */
543 if (!IS_HT_RATE(rc)) 541 if (!IS_HT_RATE(rc))
544 return ath9k_hw_computetxtime(sc->sc_ah, 542 return ath9k_hw_computetxtime(sc->sc_ah, rt, pktlen, rix,
545 rt, 543 shortPreamble);
546 pktlen,
547 rix,
548 shortPreamble);
549 /* 544 /*
550 * find number of symbols: PLCP + data 545 * find number of symbols: PLCP + data
551 */ 546 */
@@ -563,6 +558,7 @@ static u32 ath_pkt_duration(struct ath_softc *sc,
563 */ 558 */
564 streams = HT_RC_2_STREAMS(rc); 559 streams = HT_RC_2_STREAMS(rc);
565 duration += L_STF + L_LTF + L_SIG + HT_SIG + HT_STF + HT_LTF(streams); 560 duration += L_STF + L_LTF + L_SIG + HT_SIG + HT_STF + HT_LTF(streams);
561
566 return duration; 562 return duration;
567} 563}
568 564
@@ -578,7 +574,6 @@ static void ath_buf_set_rate(struct ath_softc *sc, struct ath_buf *bf)
578 int i, flags, rtsctsena = 0; 574 int i, flags, rtsctsena = 0;
579 u32 ctsduration = 0; 575 u32 ctsduration = 0;
580 u8 rix = 0, cix, ctsrate = 0; 576 u8 rix = 0, cix, ctsrate = 0;
581 u32 aggr_limit_with_rts = ah->ah_caps.rts_aggr_limit;
582 struct ath_node *an = NULL; 577 struct ath_node *an = NULL;
583 struct sk_buff *skb; 578 struct sk_buff *skb;
584 struct ieee80211_tx_info *tx_info; 579 struct ieee80211_tx_info *tx_info;
@@ -646,7 +641,7 @@ static void ath_buf_set_rate(struct ath_softc *sc, struct ath_buf *bf)
646 /* 641 /*
647 * For AR5416 - RTS cannot be followed by a frame larger than 8K. 642 * For AR5416 - RTS cannot be followed by a frame larger than 8K.
648 */ 643 */
649 if (bf_isaggr(bf) && (bf->bf_al > aggr_limit_with_rts)) { 644 if (bf_isaggr(bf) && (bf->bf_al > ah->ah_caps.rts_aggr_limit)) {
650 /* 645 /*
651 * Ensure that in the case of SM Dynamic power save 646 * Ensure that in the case of SM Dynamic power save
652 * while we are bursting the second aggregate the 647 * while we are bursting the second aggregate the
@@ -659,8 +654,8 @@ static void ath_buf_set_rate(struct ath_softc *sc, struct ath_buf *bf)
659 * CTS transmit rate is derived from the transmit rate 654 * CTS transmit rate is derived from the transmit rate
660 * by looking in the h/w rate table. We must also factor 655 * by looking in the h/w rate table. We must also factor
661 * in whether or not a short preamble is to be used. 656 * in whether or not a short preamble is to be used.
657 * NB: cix is set above where RTS/CTS is enabled
662 */ 658 */
663 /* NB: cix is set above where RTS/CTS is enabled */
664 BUG_ON(cix == 0xff); 659 BUG_ON(cix == 0xff);
665 ctsrate = rt->info[cix].rateCode | 660 ctsrate = rt->info[cix].rateCode |
666 (bf_isshpreamble(bf) ? rt->info[cix].shortPreamble : 0); 661 (bf_isshpreamble(bf) ? rt->info[cix].shortPreamble : 0);
@@ -689,15 +684,13 @@ static void ath_buf_set_rate(struct ath_softc *sc, struct ath_buf *bf)
689 ((bf->bf_rcs[i].flags & ATH_RC_SGI_FLAG) ? 684 ((bf->bf_rcs[i].flags & ATH_RC_SGI_FLAG) ?
690 ATH9K_RATESERIES_HALFGI : 0); 685 ATH9K_RATESERIES_HALFGI : 0);
691 686
692 series[i].PktDuration = ath_pkt_duration( 687 series[i].PktDuration = ath_pkt_duration(sc, rix, bf,
693 sc, rix, bf, 688 (bf->bf_rcs[i].flags & ATH_RC_CW40_FLAG) != 0,
694 (bf->bf_rcs[i].flags & ATH_RC_CW40_FLAG) != 0, 689 (bf->bf_rcs[i].flags & ATH_RC_SGI_FLAG),
695 (bf->bf_rcs[i].flags & ATH_RC_SGI_FLAG), 690 bf_isshpreamble(bf));
696 bf_isshpreamble(bf));
697 691
698 if (bf_isht(bf)) 692 if (bf_isht(bf) && an)
699 series[i].ChSel = 693 series[i].ChSel = ath_chainmask_sel_logic(sc, an);
700 ath_chainmask_sel_logic(sc, an);
701 else 694 else
702 series[i].ChSel = sc->sc_tx_chainmask; 695 series[i].ChSel = sc->sc_tx_chainmask;
703 696
@@ -748,6 +741,7 @@ static void ath_buf_set_rate(struct ath_softc *sc, struct ath_buf *bf)
748 ctsrate, 741 ctsrate,
749 ctsduration, 742 ctsduration,
750 series, 4, flags); 743 series, 4, flags);
744
751 if (sc->sc_config.ath_aggr_prot && flags) 745 if (sc->sc_config.ath_aggr_prot && flags)
752 ath9k_hw_set11n_burstduration(ah, ds, 8192); 746 ath9k_hw_set11n_burstduration(ah, ds, 8192);
753} 747}
@@ -1238,26 +1232,21 @@ static void ath_tx_stopdma(struct ath_softc *sc, struct ath_txq *txq)
1238static void ath_drain_txdataq(struct ath_softc *sc, bool retry_tx) 1232static void ath_drain_txdataq(struct ath_softc *sc, bool retry_tx)
1239{ 1233{
1240 struct ath_hal *ah = sc->sc_ah; 1234 struct ath_hal *ah = sc->sc_ah;
1241 int i; 1235 int i, status, npend = 0;
1242 int npend = 0;
1243 1236
1244 /* XXX return value */
1245 if (!(sc->sc_flags & SC_OP_INVALID)) { 1237 if (!(sc->sc_flags & SC_OP_INVALID)) {
1246 for (i = 0; i < ATH9K_NUM_TX_QUEUES; i++) { 1238 for (i = 0; i < ATH9K_NUM_TX_QUEUES; i++) {
1247 if (ATH_TXQ_SETUP(sc, i)) { 1239 if (ATH_TXQ_SETUP(sc, i)) {
1248 ath_tx_stopdma(sc, &sc->sc_txq[i]); 1240 ath_tx_stopdma(sc, &sc->sc_txq[i]);
1249
1250 /* The TxDMA may not really be stopped. 1241 /* The TxDMA may not really be stopped.
1251 * Double check the hal tx pending count */ 1242 * Double check the hal tx pending count */
1252 npend += ath9k_hw_numtxpending(ah, 1243 npend += ath9k_hw_numtxpending(ah,
1253 sc->sc_txq[i].axq_qnum); 1244 sc->sc_txq[i].axq_qnum);
1254 } 1245 }
1255 } 1246 }
1256 } 1247 }
1257 1248
1258 if (npend) { 1249 if (npend) {
1259 int status;
1260
1261 /* TxDMA not stopped, reset the hal */ 1250 /* TxDMA not stopped, reset the hal */
1262 DPRINTF(sc, ATH_DBG_XMIT, 1251 DPRINTF(sc, ATH_DBG_XMIT,
1263 "%s: Unable to stop TxDMA. Reset HAL!\n", __func__); 1252 "%s: Unable to stop TxDMA. Reset HAL!\n", __func__);
@@ -1360,6 +1349,7 @@ static int ath_tx_send_ampdu(struct ath_softc *sc,
1360 bf->bf_lastbf = bf->bf_lastfrm; /* one single frame */ 1349 bf->bf_lastbf = bf->bf_lastfrm; /* one single frame */
1361 ath_buf_set_rate(sc, bf); 1350 ath_buf_set_rate(sc, bf);
1362 ath_tx_txqaddbuf(sc, txctl->txq, bf_head); 1351 ath_tx_txqaddbuf(sc, txctl->txq, bf_head);
1352
1363 return 0; 1353 return 0;
1364} 1354}
1365 1355
@@ -1380,7 +1370,6 @@ static u32 ath_lookup_rate(struct ath_softc *sc,
1380 u16 aggr_limit, legacy = 0, maxampdu; 1370 u16 aggr_limit, legacy = 0, maxampdu;
1381 int i; 1371 int i;
1382 1372
1383
1384 skb = (struct sk_buff *)bf->bf_mpdu; 1373 skb = (struct sk_buff *)bf->bf_mpdu;
1385 tx_info = IEEE80211_SKB_CB(skb); 1374 tx_info = IEEE80211_SKB_CB(skb);
1386 tx_info_priv = (struct ath_tx_info_priv *) 1375 tx_info_priv = (struct ath_tx_info_priv *)