diff options
-rw-r--r-- | drivers/net/wireless/ath/ath9k/ath9k.h | 1 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath9k/xmit.c | 24 |
2 files changed, 10 insertions, 15 deletions
diff --git a/drivers/net/wireless/ath/ath9k/ath9k.h b/drivers/net/wireless/ath/ath9k/ath9k.h index d816c9df1f63..e2ebf1a56c00 100644 --- a/drivers/net/wireless/ath/ath9k/ath9k.h +++ b/drivers/net/wireless/ath/ath9k/ath9k.h | |||
@@ -190,7 +190,6 @@ void ath_descdma_cleanup(struct ath_softc *sc, struct ath_descdma *dd, | |||
190 | #define ATH_AGGR_MIN_QDEPTH 2 | 190 | #define ATH_AGGR_MIN_QDEPTH 2 |
191 | #define ATH_AMPDU_SUBFRAME_DEFAULT 32 | 191 | #define ATH_AMPDU_SUBFRAME_DEFAULT 32 |
192 | #define ATH_AMPDU_LIMIT_MAX (64 * 1024 - 1) | 192 | #define ATH_AMPDU_LIMIT_MAX (64 * 1024 - 1) |
193 | #define ATH_AMPDU_LIMIT_DEFAULT ATH_AMPDU_LIMIT_MAX | ||
194 | 193 | ||
195 | #define IEEE80211_SEQ_SEQ_SHIFT 4 | 194 | #define IEEE80211_SEQ_SEQ_SHIFT 4 |
196 | #define IEEE80211_SEQ_MAX 4096 | 195 | #define IEEE80211_SEQ_MAX 4096 |
diff --git a/drivers/net/wireless/ath/ath9k/xmit.c b/drivers/net/wireless/ath/ath9k/xmit.c index 2c01fda5b723..6eb2927c8aec 100644 --- a/drivers/net/wireless/ath/ath9k/xmit.c +++ b/drivers/net/wireless/ath/ath9k/xmit.c | |||
@@ -455,7 +455,7 @@ static u32 ath_lookup_rate(struct ath_softc *sc, struct ath_buf *bf, | |||
455 | struct ieee80211_tx_rate *rates; | 455 | struct ieee80211_tx_rate *rates; |
456 | struct ath_tx_info_priv *tx_info_priv; | 456 | struct ath_tx_info_priv *tx_info_priv; |
457 | u32 max_4ms_framelen, frmlen; | 457 | u32 max_4ms_framelen, frmlen; |
458 | u16 aggr_limit, legacy = 0, maxampdu; | 458 | u16 aggr_limit, legacy = 0; |
459 | int i; | 459 | int i; |
460 | 460 | ||
461 | skb = bf->bf_mpdu; | 461 | skb = bf->bf_mpdu; |
@@ -490,16 +490,15 @@ static u32 ath_lookup_rate(struct ath_softc *sc, struct ath_buf *bf, | |||
490 | if (tx_info->flags & IEEE80211_TX_CTL_RATE_CTRL_PROBE || legacy) | 490 | if (tx_info->flags & IEEE80211_TX_CTL_RATE_CTRL_PROBE || legacy) |
491 | return 0; | 491 | return 0; |
492 | 492 | ||
493 | aggr_limit = min(max_4ms_framelen, (u32)ATH_AMPDU_LIMIT_DEFAULT); | 493 | aggr_limit = min(max_4ms_framelen, (u32)ATH_AMPDU_LIMIT_MAX); |
494 | 494 | ||
495 | /* | 495 | /* |
496 | * h/w can accept aggregates upto 16 bit lengths (65535). | 496 | * h/w can accept aggregates upto 16 bit lengths (65535). |
497 | * The IE, however can hold upto 65536, which shows up here | 497 | * The IE, however can hold upto 65536, which shows up here |
498 | * as zero. Ignore 65536 since we are constrained by hw. | 498 | * as zero. Ignore 65536 since we are constrained by hw. |
499 | */ | 499 | */ |
500 | maxampdu = tid->an->maxampdu; | 500 | if (tid->an->maxampdu) |
501 | if (maxampdu) | 501 | aggr_limit = min(aggr_limit, tid->an->maxampdu); |
502 | aggr_limit = min(aggr_limit, maxampdu); | ||
503 | 502 | ||
504 | return aggr_limit; | 503 | return aggr_limit; |
505 | } | 504 | } |
@@ -507,7 +506,6 @@ static u32 ath_lookup_rate(struct ath_softc *sc, struct ath_buf *bf, | |||
507 | /* | 506 | /* |
508 | * Returns the number of delimiters to be added to | 507 | * Returns the number of delimiters to be added to |
509 | * meet the minimum required mpdudensity. | 508 | * meet the minimum required mpdudensity. |
510 | * caller should make sure that the rate is HT rate . | ||
511 | */ | 509 | */ |
512 | static int ath_compute_num_delims(struct ath_softc *sc, struct ath_atx_tid *tid, | 510 | static int ath_compute_num_delims(struct ath_softc *sc, struct ath_atx_tid *tid, |
513 | struct ath_buf *bf, u16 frmlen) | 511 | struct ath_buf *bf, u16 frmlen) |
@@ -515,7 +513,7 @@ static int ath_compute_num_delims(struct ath_softc *sc, struct ath_atx_tid *tid, | |||
515 | const struct ath_rate_table *rt = sc->cur_rate_table; | 513 | const struct ath_rate_table *rt = sc->cur_rate_table; |
516 | struct sk_buff *skb = bf->bf_mpdu; | 514 | struct sk_buff *skb = bf->bf_mpdu; |
517 | struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb); | 515 | struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb); |
518 | u32 nsymbits, nsymbols, mpdudensity; | 516 | u32 nsymbits, nsymbols; |
519 | u16 minlen; | 517 | u16 minlen; |
520 | u8 rc, flags, rix; | 518 | u8 rc, flags, rix; |
521 | int width, half_gi, ndelim, mindelim; | 519 | int width, half_gi, ndelim, mindelim; |
@@ -537,14 +535,12 @@ static int ath_compute_num_delims(struct ath_softc *sc, struct ath_atx_tid *tid, | |||
537 | * on highest rate in rate series (i.e. first rate) to determine | 535 | * on highest rate in rate series (i.e. first rate) to determine |
538 | * required minimum length for subframe. Take into account | 536 | * required minimum length for subframe. Take into account |
539 | * whether high rate is 20 or 40Mhz and half or full GI. | 537 | * whether high rate is 20 or 40Mhz and half or full GI. |
540 | */ | 538 | * |
541 | mpdudensity = tid->an->mpdudensity; | ||
542 | |||
543 | /* | ||
544 | * If there is no mpdu density restriction, no further calculation | 539 | * If there is no mpdu density restriction, no further calculation |
545 | * is needed. | 540 | * is needed. |
546 | */ | 541 | */ |
547 | if (mpdudensity == 0) | 542 | |
543 | if (tid->an->mpdudensity == 0) | ||
548 | return ndelim; | 544 | return ndelim; |
549 | 545 | ||
550 | rix = tx_info->control.rates[0].idx; | 546 | rix = tx_info->control.rates[0].idx; |
@@ -554,9 +550,9 @@ static int ath_compute_num_delims(struct ath_softc *sc, struct ath_atx_tid *tid, | |||
554 | half_gi = (flags & IEEE80211_TX_RC_SHORT_GI) ? 1 : 0; | 550 | half_gi = (flags & IEEE80211_TX_RC_SHORT_GI) ? 1 : 0; |
555 | 551 | ||
556 | if (half_gi) | 552 | if (half_gi) |
557 | nsymbols = NUM_SYMBOLS_PER_USEC_HALFGI(mpdudensity); | 553 | nsymbols = NUM_SYMBOLS_PER_USEC_HALFGI(tid->an->mpdudensity); |
558 | else | 554 | else |
559 | nsymbols = NUM_SYMBOLS_PER_USEC(mpdudensity); | 555 | nsymbols = NUM_SYMBOLS_PER_USEC(tid->an->mpdudensity); |
560 | 556 | ||
561 | if (nsymbols == 0) | 557 | if (nsymbols == 0) |
562 | nsymbols = 1; | 558 | nsymbols = 1; |