Applied to master, thanks!

2016-06-13 21:48 GMT-07:00 Ilya Maximets <i.maxim...@samsung.com>:

> Looks good to me.
> Acked-by: Ilya Maximets <i.maxim...@samsung.com>
>
>
> On 11.06.2016 02:08, Daniele Di Proietto wrote:
> > Thanks for the patch, it looks good to me.
> >
> > If everybody agrees (Ilya?) I can push this to master.
> >
> > Thanks,
> >
> > Daniele
> >
> > 2016-06-10 9:49 GMT-07:00 Kevin Traynor <kevin.tray...@intel.com
> <mailto:kevin.tray...@intel.com>>:
> >
> >     If the guest is connected but not servicing the virt queue, this
> leads
> >     to vhost send retries until timeout. This is fine in isolation but if
> >     there are other high rate queues also being serviced by the same PMD
> >     it can lead to a performance hit on those queues. Change to only
> retry
> >     when at least some packets have been successfully sent on the
> previous
> >     attempt.
> >
> >     Also, limit retries to avoid a similar delays if packets are being
> sent
> >     at a very low rate due to few available descriptors.
> >
> >     Reported-by: Bhanuprakash Bodireddy <
> bhanuprakash.bodire...@intel.com <mailto:bhanuprakash.bodire...@intel.com
> >>
> >     Signed-off-by: Kevin Traynor <kevin.tray...@intel.com <mailto:
> kevin.tray...@intel.com>>
> >     Acked-by: Bhanuprakash Bodireddy <bhanuprakash.bodire...@intel.com
> <mailto:bhanuprakash.bodire...@intel.com>>
> >     ---
> >
> >      RFC->v2
> >      - Change to PATCH after ML discussion.
> >      - Rebase.
> >      - Add retry limit when packets are being sent.
> >      - Add Ack from Bhanu.
> >
> >      lib/netdev-dpdk.c |   34 ++++++----------------------------
> >      1 files changed, 6 insertions(+), 28 deletions(-)
> >
> >     diff --git a/lib/netdev-dpdk.c b/lib/netdev-dpdk.c
> >     index 19d355f..582569c 100644
> >     --- a/lib/netdev-dpdk.c
> >     +++ b/lib/netdev-dpdk.c
> >     @@ -141,10 +141,7 @@ static char *cuse_dev_name = NULL;    /*
> Character device cuse_dev_name. */
> >      #endif
> >      static char *vhost_sock_dir = NULL;   /* Location of vhost-user
> sockets */
> >
> >     -/*
> >     - * Maximum amount of time in micro seconds to try and enqueue to
> vhost.
> >     - */
> >     -#define VHOST_ENQ_RETRY_USECS 100
> >     +#define VHOST_ENQ_RETRY_NUM 8
> >
> >      static const struct rte_eth_conf port_conf = {
> >          .rxmode = {
> >     @@ -1377,7 +1374,7 @@ __netdev_dpdk_vhost_send(struct netdev
> *netdev, int qid,
> >          struct rte_mbuf **cur_pkts = (struct rte_mbuf **) pkts;
> >          unsigned int total_pkts = cnt;
> >          unsigned int qos_pkts = cnt;
> >     -    uint64_t start = 0;
> >     +    int retries = 0;
> >
> >          qid = dev->tx_q[qid % dev->real_n_txq].map;
> >
> >     @@ -1404,32 +1401,13 @@ __netdev_dpdk_vhost_send(struct netdev
> *netdev, int qid,
> >              if (OVS_LIKELY(tx_pkts)) {
> >                  /* Packets have been sent.*/
> >                  cnt -= tx_pkts;
> >     -            /* Prepare for possible next iteration.*/
> >     +            /* Prepare for possible retry.*/
> >                  cur_pkts = &cur_pkts[tx_pkts];
> >              } else {
> >     -            uint64_t timeout = VHOST_ENQ_RETRY_USECS *
> rte_get_timer_hz() / 1E6;
> >     -            unsigned int expired = 0;
> >     -
> >     -            if (!start) {
> >     -                start = rte_get_timer_cycles();
> >     -            }
> >     -
> >     -            /*
> >     -             * Unable to enqueue packets to vhost interface.
> >     -             * Check available entries before retrying.
> >     -             */
> >     -            while (!rte_vring_available_entries(virtio_dev,
> vhost_qid)) {
> >     -                if (OVS_UNLIKELY((rte_get_timer_cycles() - start) >
> timeout)) {
> >     -                    expired = 1;
> >     -                    break;
> >     -                }
> >     -            }
> >     -            if (expired) {
> >     -                /* break out of main loop. */
> >     -                break;
> >     -            }
> >     +            /* No packets sent - do not retry.*/
> >     +            break;
> >              }
> >     -    } while (cnt);
> >     +    } while (cnt && (retries++ < VHOST_ENQ_RETRY_NUM));
> >
> >          rte_spinlock_unlock(&dev->tx_q[qid].tx_lock);
> >
> >     --
> >     1.7.4.1
> >
> >     _______________________________________________
> >     dev mailing list
> >     dev@openvswitch.org <mailto:dev@openvswitch.org>
> >     http://openvswitch.org/mailman/listinfo/dev
> >
> >
>
_______________________________________________
dev mailing list
dev@openvswitch.org
http://openvswitch.org/mailman/listinfo/dev

Reply via email to