Looks OK to me. I didn't quite get why open_int() is called so.
What does it open?
-- 
Victor

----- Original Message -----
> From: "Yuanhan Liu" <yuanhan.liu at linux.intel.com>
> To: dev at dpdk.org
> Cc: "huawei xie" <huawei.xie at intel.com>, "Yuanhan Liu" <yuanhan.liu at 
> linux.intel.com>, "Tetsuya Mukawa"
> <mukawa at igel.co.jp>
> Sent: Saturday, May 7, 2016 9:40:24 AM
> Subject: [dpdk-dev] [PATCH 6/6] vhost: add pmd client and reconnect option
> 
> Add client and reconnect option to vhost pmd. reconnect only works when
> client is given as well.
> 
> Cc: Tetsuya Mukawa <mukawa at igel.co.jp>
> Signed-off-by: Yuanhan Liu <yuanhan.liu at linux.intel.com>
> ---
>  drivers/net/vhost/rte_eth_vhost.c | 54
>  ++++++++++++++++++++++++++++++---------
>  1 file changed, 42 insertions(+), 12 deletions(-)
> 
> diff --git a/drivers/net/vhost/rte_eth_vhost.c
> b/drivers/net/vhost/rte_eth_vhost.c
> index 36697cf..7636ef8 100644
> --- a/drivers/net/vhost/rte_eth_vhost.c
> +++ b/drivers/net/vhost/rte_eth_vhost.c
> @@ -47,12 +47,16 @@
>  
>  #define ETH_VHOST_IFACE_ARG          "iface"
>  #define ETH_VHOST_QUEUES_ARG         "queues"
> +#define ETH_VHOST_CLIENT_ARG         "client"
> +#define ETH_VHOST_RECONNECT_ARG              "reconnect"
>  
>  static const char *drivername = "VHOST PMD";
>  
>  static const char *valid_arguments[] = {
>       ETH_VHOST_IFACE_ARG,
>       ETH_VHOST_QUEUES_ARG,
> +     ETH_VHOST_CLIENT_ARG,
> +     ETH_VHOST_RECONNECT_ARG,
>       NULL
>  };
>  
> @@ -87,6 +91,7 @@ struct pmd_internal {
>       char *dev_name;
>       char *iface_name;
>       uint16_t max_queues;
> +     uint64_t flags;
>  
>       volatile uint16_t once;
>  };
> @@ -456,7 +461,8 @@ eth_dev_start(struct rte_eth_dev *dev)
>       int ret = 0;
>  
>       if (rte_atomic16_cmpset(&internal->once, 0, 1)) {
> -             ret = rte_vhost_driver_register(internal->iface_name, 0);
> +             ret = rte_vhost_driver_register(internal->iface_name,
> +                                             internal->flags);
>               if (ret)
>                       return ret;
>       }
> @@ -661,7 +667,7 @@ static const struct eth_dev_ops ops = {
>  
>  static int
>  eth_dev_vhost_create(const char *name, char *iface_name, int16_t queues,
> -                  const unsigned numa_node)
> +                  const unsigned numa_node, uint64_t flags)
>  {
>       struct rte_eth_dev_data *data = NULL;
>       struct pmd_internal *internal = NULL;
> @@ -718,6 +724,7 @@ eth_dev_vhost_create(const char *name, char *iface_name,
> int16_t queues,
>       internal->iface_name = strdup(iface_name);
>       if (internal->iface_name == NULL)
>               goto error;
> +     internal->flags = flags;
>  
>       list->eth_dev = eth_dev;
>       pthread_mutex_lock(&internal_list_lock);
> @@ -782,18 +789,15 @@ open_iface(const char *key __rte_unused, const char
> *value, void *extra_args)
>  }
>  
>  static inline int
> -open_queues(const char *key __rte_unused, const char *value, void
> *extra_args)
> +open_int(const char *key __rte_unused, const char *value, void *extra_args)
>  {
> -     uint16_t *q = extra_args;
> +     uint16_t *n = extra_args;
>  
>       if (value == NULL || extra_args == NULL)
>               return -EINVAL;
>  
> -     *q = (uint16_t)strtoul(value, NULL, 0);
> -     if (*q == USHRT_MAX && errno == ERANGE)
> -             return -1;
> -
> -     if (*q > RTE_MAX_QUEUES_PER_PORT)
> +     *n = (uint16_t)strtoul(value, NULL, 0);
> +     if (*n == USHRT_MAX && errno == ERANGE)
>               return -1;
>  
>       return 0;
> @@ -806,6 +810,9 @@ rte_pmd_vhost_devinit(const char *name, const char
> *params)
>       int ret = 0;
>       char *iface_name;
>       uint16_t queues;
> +     uint64_t flags = 0;
> +     int client_mode;
> +     int reconnect;
>  
>       RTE_LOG(INFO, PMD, "Initializing pmd_vhost for %s\n", name);
>  
> @@ -825,14 +832,37 @@ rte_pmd_vhost_devinit(const char *name, const char
> *params)
>  
>       if (rte_kvargs_count(kvlist, ETH_VHOST_QUEUES_ARG) == 1) {
>               ret = rte_kvargs_process(kvlist, ETH_VHOST_QUEUES_ARG,
> -                                      &open_queues, &queues);
> -             if (ret < 0)
> +                                      &open_int, &queues);
> +             if (ret < 0 || queues > RTE_MAX_QUEUES_PER_PORT)
>                       goto out_free;
>  
>       } else
>               queues = 1;
>  
> -     eth_dev_vhost_create(name, iface_name, queues, rte_socket_id());
> +     if (rte_kvargs_count(kvlist, ETH_VHOST_CLIENT_ARG) == 1) {
> +             ret = rte_kvargs_process(kvlist, ETH_VHOST_CLIENT_ARG,
> +                                      &open_int, &client_mode);
> +             if (ret < 0)
> +                     goto out_free;
> +     }
> +     if (rte_kvargs_count(kvlist, ETH_VHOST_RECONNECT_ARG) == 1) {
> +             ret = rte_kvargs_process(kvlist, ETH_VHOST_RECONNECT_ARG,
> +                                      &open_int, &reconnect);
> +             if (ret < 0)
> +                     goto out_free;
> +     }
> +     if (client_mode)
> +             flags |= RTE_VHOST_USER_CLIENT;
> +     if (reconnect)
> +             flags |= RTE_VHOST_USER_RECONNECT;
> +     if (reconnect && !client_mode) {
> +             RTE_LOG(ERR, PMD,
> +                     "reconnect works only when client is specified\n");
> +             ret = -1;
> +             goto out_free;
> +     }
> +
> +     eth_dev_vhost_create(name, iface_name, queues, rte_socket_id(), flags);
>  
>  out_free:
>       rte_kvargs_free(kvlist);
> --
> 1.9.0
> 
> 

Reply via email to