From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from dpdk.org (dpdk.org [92.243.14.124]) by dpdk.space (Postfix) with ESMTP id ECDA5A00E6 for ; Thu, 16 May 2019 10:17:17 +0200 (CEST) Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id CE8725B1E; Thu, 16 May 2019 10:17:16 +0200 (CEST) Received: from mx1.redhat.com (mx1.redhat.com [209.132.183.28]) by dpdk.org (Postfix) with ESMTP id A28605B16 for ; Thu, 16 May 2019 10:17:15 +0200 (CEST) Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 00F8530BC3E1; Thu, 16 May 2019 08:17:15 +0000 (UTC) Received: from [10.36.112.43] (ovpn-112-43.ams2.redhat.com [10.36.112.43]) by smtp.corp.redhat.com (Postfix) with ESMTPS id A86966A259; Thu, 16 May 2019 08:17:13 +0000 (UTC) To: Mesut Ali Ergin , beilei.xing@intel.com, qi.z.zhang@intel.com Cc: dev@dpdk.org References: <1557980885-183777-1-git-send-email-mesut.a.ergin@intel.com> <1557980885-183777-3-git-send-email-mesut.a.ergin@intel.com> From: Maxime Coquelin Message-ID: Date: Thu, 16 May 2019 10:17:11 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.6.1 MIME-Version: 1.0 In-Reply-To: <1557980885-183777-3-git-send-email-mesut.a.ergin@intel.com> Content-Type: text/plain; charset="UTF-8"; format="flowed" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.43]); Thu, 16 May 2019 08:17:15 +0000 (UTC) Subject: Re: [dpdk-dev] [PATCH 2/3] net/i40e: add runtime option to disable vector rx X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" Message-ID: <20190516081711.5cxuMOWJ_0oD9YTU10aEgM0HvWSaaEvAGzqfGiEPfng@z> On 5/16/19 6:28 AM, Mesut Ali Ergin wrote: > Vector RX functions are not at feature parity with non-vector ones and > currently the vector RX path is enabled by default. Hence, the only > option to force selection of non-vector variants and be able to retain > functionality is to disable vector PMD globally at compile time via the > config file option. > > This patch introduces a new runtime device config option named > disable-vec-rx to allow users to limit the driver to make a choice among > non-vector RX functions, on a per device basis. This runtime option > defaults to a value of zero, allowing vector RX functions to be > selected (current behavior). When disable-vec-rx=1 is specified for a > device, even if all the other requirements to select a vector RX > function are satisfied, the driver will still pick one out of the > appropriate non-vector RX functions. > > Signed-off-by: Mesut Ali Ergin > --- > doc/guides/nics/i40e.rst | 14 +++++++++ > drivers/net/i40e/i40e_ethdev.c | 70 +++++++++++++++++++++++++++++++++++++++++- > drivers/net/i40e/i40e_ethdev.h | 1 + > drivers/net/i40e/i40e_rxtx.c | 4 +++ > 4 files changed, 88 insertions(+), 1 deletion(-) > > diff --git a/doc/guides/nics/i40e.rst b/doc/guides/nics/i40e.rst > index a97484c..532cc64 100644 > --- a/doc/guides/nics/i40e.rst > +++ b/doc/guides/nics/i40e.rst > @@ -183,6 +183,20 @@ Runtime Config Options > > -w 84:00.0,use-latest-supported-vec=1 > > +- ``Disable RX Vector Functions `` (default ``vector RX enabled``) > + > + When config file option for the vector PMD is enabled, vector RX functions may > + be the default choice of the driver at device initialization time, if certain > + conditions apply. However, vector RX functions may not always be at feature > + parity with non-vector ones. In order to allow users to override vector RX > + function selection behavior at runtime, the ``devargs`` parameter > + ``disable-vec-rx`` is introduced, such that > + > + -w DBDF,disable-vec-rx=1 > + > + would force driver to limit its choices to non-vector RX function variants for > + the device specified by the DBDF. > + > Vector RX Pre-conditions > ~~~~~~~~~~~~~~~~~~~~~~~~ > For Vector RX it is assumed that the number of descriptor rings will be a power > diff --git a/drivers/net/i40e/i40e_ethdev.c b/drivers/net/i40e/i40e_ethdev.c > index cab440f..19fbd23 100644 > --- a/drivers/net/i40e/i40e_ethdev.c > +++ b/drivers/net/i40e/i40e_ethdev.c > @@ -44,6 +44,7 @@ > #define ETH_I40E_SUPPORT_MULTI_DRIVER "support-multi-driver" > #define ETH_I40E_QUEUE_NUM_PER_VF_ARG "queue-num-per-vf" > #define ETH_I40E_USE_LATEST_VEC "use-latest-supported-vec" > +#define ETH_I40E_DISABLE_VEC_RX "disable-vec-rx" > > #define I40E_CLEAR_PXE_WAIT_MS 200 > > @@ -410,6 +411,7 @@ static const char *const valid_keys[] = { > ETH_I40E_SUPPORT_MULTI_DRIVER, > ETH_I40E_QUEUE_NUM_PER_VF_ARG, > ETH_I40E_USE_LATEST_VEC, > + ETH_I40E_DISABLE_VEC_RX, > NULL}; > > static const struct rte_pci_id pci_id_i40e_map[] = { > @@ -1263,6 +1265,68 @@ i40e_use_latest_vec(struct rte_eth_dev *dev) > return 0; > } > > +static int > +i40e_parse_disable_vec_rx_handler(__rte_unused const char *key, > + const char *value, > + void *opaque) > +{ > + struct i40e_adapter *ad; > + > + ad = (struct i40e_adapter *)opaque; > + > + switch (atoi(value)) { > + case 0: > + /* Selection of RX vector functions left untouched*/ > + break; > + case 1: > + /* Disable RX vector functions as requested*/ > + ad->rx_vec_allowed = false; > + break; > + default: > + PMD_DRV_LOG(WARNING, "Value should be 0 or 1, set it as 1!"); You may want to propagate the error here. > + break; > + } > + > + return 0; > +} > + > +int > +i40e_disable_vec_rx(struct rte_eth_dev *dev) > +{ > + struct i40e_adapter *ad = > + I40E_DEV_PRIVATE_TO_ADAPTER(dev->data->dev_private); > + struct rte_kvargs *kvlist; > + int kvargs_count; > + > + > + if (!dev->device->devargs) > + return 0; > + > + kvlist = rte_kvargs_parse(dev->device->devargs->args, valid_keys); > + if (!kvlist) > + return -EINVAL; > + > + kvargs_count = rte_kvargs_count(kvlist, ETH_I40E_DISABLE_VEC_RX); > + if (!kvargs_count) { > + rte_kvargs_free(kvlist); > + return 0; > + } > + > + if (kvargs_count > 1) > + PMD_DRV_LOG(WARNING, "More than one argument \"%s\" and only " > + "the first invalid or last valid one is used !", > + ETH_I40E_DISABLE_VEC_RX); > + > + if (rte_kvargs_process(kvlist, ETH_I40E_DISABLE_VEC_RX, > + i40e_parse_disable_vec_rx_handler, ad) < 0) { > + rte_kvargs_free(kvlist); > + return -EINVAL; > + } > + > + rte_kvargs_free(kvlist); > + return 0; > +} > + > #define I40E_ALARM_INTERVAL 50000 /* us */ > > static int > @@ -1795,6 +1859,9 @@ i40e_dev_configure(struct rte_eth_dev *dev) > ad->tx_simple_allowed = true; > ad->tx_vec_allowed = true; > > + /* Check if users wanted to disable vector RX functions */ > + i40e_disable_vec_rx(dev); Ditto, error should be propagated. > + > /* Only legacy filter API needs the following fdir config. So when the > * legacy filter API is deprecated, the following codes should also be > * removed. > @@ -12790,4 +12857,5 @@ RTE_PMD_REGISTER_PARAM_STRING(net_i40e, > ETH_I40E_FLOATING_VEB_LIST_ARG "=" > ETH_I40E_QUEUE_NUM_PER_VF_ARG "=1|2|4|8|16" > ETH_I40E_SUPPORT_MULTI_DRIVER "=1" > - ETH_I40E_USE_LATEST_VEC "=0|1"); > + ETH_I40E_USE_LATEST_VEC "=0|1" > + ETH_I40E_DISABLE_VEC_RX "=0|1"); > diff --git a/drivers/net/i40e/i40e_ethdev.h b/drivers/net/i40e/i40e_ethdev.h > index 9855038..906bfe9 100644 > --- a/drivers/net/i40e/i40e_ethdev.h > +++ b/drivers/net/i40e/i40e_ethdev.h > @@ -1248,6 +1248,7 @@ int i40e_config_rss_filter(struct i40e_pf *pf, > struct i40e_rte_flow_rss_conf *conf, bool add); > int i40e_vf_representor_init(struct rte_eth_dev *ethdev, void *init_params); > int i40e_vf_representor_uninit(struct rte_eth_dev *ethdev); > +int i40e_disable_vec_rx(struct rte_eth_dev *dev); > > #define I40E_DEV_TO_PCI(eth_dev) \ > RTE_DEV_TO_PCI((eth_dev)->device) > diff --git a/drivers/net/i40e/i40e_rxtx.c b/drivers/net/i40e/i40e_rxtx.c > index 1489552..7e66f59 100644 > --- a/drivers/net/i40e/i40e_rxtx.c > +++ b/drivers/net/i40e/i40e_rxtx.c > @@ -1736,6 +1736,10 @@ i40e_dev_rx_queue_setup_runtime(struct rte_eth_dev *dev, > */ > ad->rx_bulk_alloc_allowed = true; > ad->rx_vec_allowed = true; > + > + /* Check if users wanted to disable vector RX functions */ > + i40e_disable_vec_rx(dev); > + Ditto, error should be propagated. > dev->data->scattered_rx = use_scattered_rx; > if (use_def_burst_func) > ad->rx_bulk_alloc_allowed = false; >