From: Yuanhan Liu <yuanhan....@linux.intel.com>

Signed-off-by: Yuanhan Liu <yuanhan....@linux.intel.com>

Conflicts:
        lib/librte_vhost/virtio_net.c
---
 drivers/net/virtio/virtio_rxtx_1.1.c | 18 ++++++++++--------
 lib/librte_vhost/virtio_net.c        | 17 ++++++++++-------
 2 files changed, 20 insertions(+), 15 deletions(-)

diff --git a/drivers/net/virtio/virtio_rxtx_1.1.c 
b/drivers/net/virtio/virtio_rxtx_1.1.c
index e47a346..05f9dc7 100644
--- a/drivers/net/virtio/virtio_rxtx_1.1.c
+++ b/drivers/net/virtio/virtio_rxtx_1.1.c
@@ -89,7 +89,7 @@
 }
 
 static inline void
-virtio_xmit(struct virtnet_tx *txvq, struct rte_mbuf *mbuf)
+virtio_xmit(struct virtnet_tx *txvq, struct rte_mbuf *mbuf, int first_mbuf)
 {
        struct virtio_tx_region *txr = txvq->virtio_net_hdr_mz->addr;
        struct virtqueue *vq = txvq->vq;
@@ -105,6 +105,8 @@
                          RTE_PTR_DIFF(&txr[idx].tx_hdr, txr);
        desc[idx].len   = vq->hw->vtnet_hdr_size;
        desc[idx].flags = VRING_DESC_F_NEXT;
+       if (!first_mbuf)
+               desc[idx].flags |= DESC_HW;
 
        do {
                idx = (vq->vq_avail_idx++) & (vq->vq_nentries - 1);
@@ -115,12 +117,6 @@
 
        desc[idx].flags &= ~VRING_DESC_F_NEXT;
 
-       /*
-        * update the head last, so that when the host saw such flag
-        * is set, it means all others in the same chain is also set
-        */
-       rte_smp_wmb();
-       desc[head_idx].flags |= DESC_HW;
 }
 
 uint16_t
@@ -129,6 +125,7 @@
        struct virtnet_tx *txvq = tx_queue;
        struct virtqueue *vq = txvq->vq;
        uint16_t i;
+       uint16_t head_idx = vq->vq_avail_idx;
 
        if (unlikely(nb_pkts < 1))
                return nb_pkts;
@@ -148,10 +145,15 @@
                        }
                }
 
-               virtio_xmit(txvq, txm);
+               virtio_xmit(txvq, txm, i == 0);
                txvq->stats.bytes += txm->pkt_len;
        }
 
+       if (likely(i)) {
+               rte_smp_wmb();
+               vq->vq_ring.desc_1_1[head_idx & (vq->vq_nentries - 1)].flags |= 
DESC_HW;
+       }
+
        txvq->stats.packets += i;
        txvq->stats.errors  += nb_pkts - i;
 
diff --git a/lib/librte_vhost/virtio_net.c b/lib/librte_vhost/virtio_net.c
index df88e31..c9e466f 100644
--- a/lib/librte_vhost/virtio_net.c
+++ b/lib/librte_vhost/virtio_net.c
@@ -1009,9 +1009,6 @@ static inline bool __attribute__((always_inline))
         */
        if (likely((desc->len == dev->vhost_hlen) &&
                   (desc->flags & VRING_DESC_F_NEXT) != 0)) {
-               rte_smp_wmb();
-               desc->flags = 0;
-
                desc = &descs[(head_idx++) & (vq->size - 1)];
                if (unlikely(desc->flags & VRING_DESC_F_INDIRECT))
                        return -1;
@@ -1072,8 +1069,6 @@ static inline bool __attribute__((always_inline))
                        if ((desc->flags & VRING_DESC_F_NEXT) == 0)
                                break;
 
-                       rte_smp_wmb();
-                       desc->flags = 0;
                        desc = &descs[(head_idx++) & (vq->size - 1)];
                        if (unlikely(desc->flags & VRING_DESC_F_INDIRECT))
                                return -1;
@@ -1112,8 +1107,6 @@ static inline bool __attribute__((always_inline))
                        mbuf_avail  = cur->buf_len - RTE_PKTMBUF_HEADROOM;
                }
        }
-       rte_smp_wmb();
-       desc->flags = 0;
 
        prev->data_len = mbuf_offset;
        m->pkt_len    += mbuf_offset;
@@ -1134,7 +1127,9 @@ static inline bool __attribute__((always_inline))
        uint16_t i;
        uint16_t idx;
        struct vring_desc_1_1 *desc = vq->desc_1_1;
+       uint16_t head_idx = vq->last_used_idx;
 
+       count = RTE_MIN(MAX_PKT_BURST, count);
        for (i = 0; i < count; i++) {
                idx = vq->last_used_idx & (vq->size - 1);
                if (!(desc[idx].flags & DESC_HW))
@@ -1150,6 +1145,14 @@ static inline bool __attribute__((always_inline))
                dequeue_desc(dev, vq, mbuf_pool, pkts[i], desc);
        }
 
+       if (likely(i)) {
+               for (idx = 1; idx < (uint16_t)(vq->last_used_idx - head_idx); 
idx++) {
+                       desc[(idx + head_idx) & (vq->size - 1)].flags = 0;
+               }
+               rte_smp_wmb();
+               desc[head_idx & (vq->size - 1)].flags = 0;
+       }
+
        return i;
 }
 
-- 
1.8.3.1

Reply via email to