Enforce the RTS aggregation limit if RTS/CTS protection is enabled;
if any subframes in an aggregate have different protection from the first frame in the formed aggregate, don't add that frame to the aggregate. This is likely a suboptimal method (I think we'll mostly be OK marking frames that have seqno's with the same protection as normal data frames) but I'll just be cautious for now.
This commit is contained in:
parent
ce656facf3
commit
045bc7882e
@ -706,14 +706,6 @@ ath_tx_form_aggr(struct ath_softc *sc, struct ath_node *an, struct ath_tid *tid,
|
||||
* if any active rate is non-HT.
|
||||
*/
|
||||
|
||||
/*
|
||||
* XXX TODO: AR5416 has an 8K aggregation size limit
|
||||
* when RTS is enabled, and RTS is required for dual-stream
|
||||
* rates.
|
||||
*
|
||||
* For now, limit all aggregates for the AR5416 to be 8K.
|
||||
*/
|
||||
|
||||
/*
|
||||
* do not exceed aggregation limit
|
||||
*/
|
||||
@ -724,6 +716,20 @@ ath_tx_form_aggr(struct ath_softc *sc, struct ath_node *an, struct ath_tid *tid,
|
||||
break;
|
||||
}
|
||||
|
||||
/*
|
||||
* If RTS/CTS is set on the first frame, enforce
|
||||
* the RTS aggregate limit.
|
||||
*/
|
||||
if (bf_first->bf_state.bfs_txflags &
|
||||
(HAL_TXDESC_CTSENA | HAL_TXDESC_RTSENA)) {
|
||||
if (nframes &&
|
||||
(sc->sc_rts_aggr_limit <
|
||||
(al + bpad + al_delta + prev_al))) {
|
||||
status = ATH_AGGR_8K_LIMITED;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Do not exceed subframe limit.
|
||||
*/
|
||||
@ -734,7 +740,24 @@ ath_tx_form_aggr(struct ath_softc *sc, struct ath_node *an, struct ath_tid *tid,
|
||||
}
|
||||
|
||||
/*
|
||||
* TODO: If it's _before_ the BAW left edge, complain very loudly.
|
||||
* If the current frame has an RTS/CTS configuration
|
||||
* that differs from the first frame, don't include
|
||||
* this in the aggregate. It's possible that the
|
||||
* "right" thing to do here is enforce the aggregate
|
||||
* configuration.
|
||||
*/
|
||||
if ((bf_first->bf_state.bfs_txflags &
|
||||
(HAL_TXDESC_RTSENA | HAL_TXDESC_CTSENA)) !=
|
||||
(bf->bf_state.bfs_txflags &
|
||||
(HAL_TXDESC_RTSENA | HAL_TXDESC_CTSENA))) {
|
||||
status = ATH_AGGR_NONAGGR;
|
||||
break;
|
||||
}
|
||||
|
||||
/*
|
||||
* TODO: If it's _before_ the BAW left edge, complain very
|
||||
* loudly.
|
||||
*
|
||||
* This means something (else) has slid the left edge along
|
||||
* before we got a chance to be TXed.
|
||||
*/
|
||||
@ -813,11 +836,6 @@ ath_tx_form_aggr(struct ath_softc *sc, struct ath_node *an, struct ath_tid *tid,
|
||||
ath_tx_addto_baw(sc, an, tid, bf);
|
||||
bf->bf_state.bfs_addedbaw = 1;
|
||||
|
||||
/*
|
||||
* XXX TODO: If any frame in the aggregate requires RTS/CTS,
|
||||
* set the first frame.
|
||||
*/
|
||||
|
||||
/*
|
||||
* XXX enforce ACK for aggregate frames (this needs to be
|
||||
* XXX handled more gracefully?
|
||||
|
Loading…
x
Reference in New Issue
Block a user