Search Linux Wireless

Re: [PATCH 1/2] ath9k: try more than one tid when scheduling a new aggregate

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 01/15/2011 05:30 AM, Felix Fietkau wrote:
Sometimes the first TID in the first AC's list is not available for forming
a new aggregate (the BAW might not allow it), however other TIDs may have
data available for sending.
Prevent a slowdown of other TIDs by going through multiple entries until
we've either hit the last one or enough AMPDUs are pending in the hardware
queue.

I had attempted a similar patch, but I was thinking we should iterate
through all of the txq->axq_acq entries, not just use the first one?

If you agree, I can merge my patch with your patch below
and re-post.

Thanks,
Ben


>
> Signed-off-by: Felix Fietkau<nbd@xxxxxxxxxxx>
> ---
>   drivers/net/wireless/ath/ath9k/xmit.c |    9 ++++++---
>   1 files changed, 6 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/net/wireless/ath/ath9k/xmit.c b/drivers/net/wireless/ath/ath9k/xmit.c
> index ab4f7b4..fffd13d 100644
> --- a/drivers/net/wireless/ath/ath9k/xmit.c
> +++ b/drivers/net/wireless/ath/ath9k/xmit.c
> @@ -1224,12 +1224,14 @@ void ath_tx_cleanupq(struct ath_softc *sc, struct ath_txq *txq)
>   void ath_txq_schedule(struct ath_softc *sc, struct ath_txq *txq)
>   {
>   	struct ath_atx_ac *ac;
> -	struct ath_atx_tid *tid;
> +	struct ath_atx_tid *tid, *last;
>
> -	if (list_empty(&txq->axq_acq))
> +	if (list_empty(&txq->axq_acq) ||
> +	    txq->axq_ampdu_depth>= ATH_AGGR_MIN_QDEPTH)
>   		return;
>
>   	ac = list_first_entry(&txq->axq_acq, struct ath_atx_ac, list);
> +	last = list_entry(ac->tid_q.prev, struct ath_atx_tid, list);
>   	list_del(&ac->list);
>   	ac->sched = false;
>
> @@ -1253,7 +1255,8 @@ void ath_txq_schedule(struct ath_softc *sc, struct ath_txq *txq)
>   		if (!list_empty(&tid->buf_q))
>   			ath_tx_queue_tid(txq, tid);
>
> -		break;
> +		if (tid == last || txq->axq_ampdu_depth>= ATH_AGGR_MIN_QDEPTH)
> +			break;
>   	} while (!list_empty(&ac->tid_q));
>
>   	if (!list_empty(&ac->tid_q)) {

Thanks,
Ben

--
Ben Greear <greearb@xxxxxxxxxxxxxxx>
Candela Technologies Inc  http://www.candelatech.com

--
To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Host AP]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Linux Kernel]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Device Mapper]
  Powered by Linux