Hi Bruce,

On 08/11/2014 10:44 PM, Bruce Richardson wrote:
> Adjust the fast-path code to fix the regression caused by the pool
> pointer moving to the second cache line. This change adjusts the
> prefetching and also the way in which the mbufs are freed back to the
> mempool.
>
> Signed-off-by: Bruce Richardson <bruce.richardson at intel.com>

Just one comment here (maybe this code should be reviewed by someone
knowing the ixgbe driver better than me):


> @@ -252,14 +250,6 @@ tx_xmit_pkts(void *tx_queue, struct rte_mbuf **tx_pkts,
>       volatile union ixgbe_adv_tx_desc *tx_r = txq->tx_ring;
>       uint16_t n = 0;
>
> -     /*
> -      * Begin scanning the H/W ring for done descriptors when the
> -      * number of available descriptors drops below tx_free_thresh.  For
> -      * each done descriptor, free the associated buffer.
> -      */
> -     if (txq->nb_tx_free < txq->tx_free_thresh)
> -             ixgbe_tx_free_bufs(txq);
> -
>       /* Only use descriptors that are available */
>       nb_pkts = (uint16_t)RTE_MIN(txq->nb_tx_free, nb_pkts);
>       if (unlikely(nb_pkts == 0))
> @@ -323,6 +313,15 @@ tx_xmit_pkts(void *tx_queue, struct rte_mbuf **tx_pkts,
>       if (txq->tx_tail >= txq->nb_tx_desc)
>               txq->tx_tail = 0;
>
> +     /*
> +      * Begin scanning the H/W ring for done descriptors when the
> +      * number of available descriptors drops below tx_free_thresh.  For
> +      * each done descriptor, free the associated buffer.
> +      */
> +     if (txq->nb_tx_free < txq->tx_free_thresh)
> +             ixgbe_tx_free_bufs(txq);
> +
> +
>       /* update tail pointer */
>       rte_wmb();
>       IXGBE_PCI_REG_WRITE(txq->tdt_reg_addr, txq->tx_tail);

It looks like these 2 hunks are reverted in next commit. I'm not sure
this is what you expected.


Reply via email to