DPDK patches and discussions
 help / color / mirror / Atom feed
From: "Zhang, Qi Z" <qi.z.zhang@intel.com>
To: "Zhao1, Wei" <wei.zhao1@intel.com>, "dev@dpdk.org" <dev@dpdk.org>
Cc: "Zhao1, Wei" <wei.zhao1@intel.com>
Subject: Re: [dpdk-dev] [PATCH] net/i40e: move RSS to flow API
Date: Fri, 22 Dec 2017 04:36:26 +0000	[thread overview]
Message-ID: <039ED4275CED7440929022BC67E7061153123DE8@SHSMSX103.ccr.corp.intel.com> (raw)
In-Reply-To: <20171124084312.57832-1-wei.zhao1@intel.com>

Hi Wei:

	Please check my comment below.
	Besides, there some line over 80 character warning need to fix

Regards
Qi
	
> -----Original Message-----
> From: dev [mailto:dev-bounces@dpdk.org] On Behalf Of Wei Zhao
> Sent: Friday, November 24, 2017 4:43 PM
> To: dev@dpdk.org
> Cc: Zhao1, Wei <wei.zhao1@intel.com>
> Subject: [dpdk-dev] [PATCH] net/i40e: move RSS to flow API
> 
> Rte_flow actually defined to include RSS, but till now, RSS is out of rte_flow.
> This patch is to move i40e existing RSS to rte_flow.
> This patch also enable queue region configuration using flow API for i40e.
> 
> Signed-off-by: Wei Zhao <wei.zhao1@intel.com>
> ---
>  drivers/net/i40e/i40e_ethdev.c |  91 +++++++++++
> drivers/net/i40e/i40e_ethdev.h |  11 ++
>  drivers/net/i40e/i40e_flow.c   | 336
> +++++++++++++++++++++++++++++++++++++++++
>  3 files changed, 438 insertions(+)
> 
> diff --git a/drivers/net/i40e/i40e_ethdev.c b/drivers/net/i40e/i40e_ethdev.c
> index 811cc9f..75b3bf3 100644
> --- a/drivers/net/i40e/i40e_ethdev.c
> +++ b/drivers/net/i40e/i40e_ethdev.c
> @@ -1349,6 +1349,10 @@ eth_i40e_dev_init(struct rte_eth_dev *dev)
>  	/* initialize queue region configuration */
>  	i40e_init_queue_region_conf(dev);
> 
> +	/* initialize rss configuration from rte_flow */
> +	memset(&pf->rss_info, 0,
> +		sizeof(struct i40e_rte_flow_rss_conf));
> +
>  	return 0;
> 
>  err_init_fdir_filter_list:
> @@ -10943,12 +10947,23 @@ i40e_tunnel_filter_restore(struct i40e_pf *pf)
>  	}
>  }
> 
> +/* Restore rss filter */
> +static inline void
> +i40e_rss_filter_restore(struct i40e_pf *pf) {
> +	struct i40e_rte_flow_rss_conf *conf =
> +					&pf->rss_info;
> +	if (conf->num)
> +		i40e_config_rss_filter(pf, conf, TRUE); }
> +
>  static void
>  i40e_filter_restore(struct i40e_pf *pf)  {
>  	i40e_ethertype_filter_restore(pf);
>  	i40e_tunnel_filter_restore(pf);
>  	i40e_fdir_filter_restore(pf);
> +	i40e_rss_filter_restore(pf);
>  }
> 
>  static bool
> @@ -11366,6 +11381,82 @@ i40e_cloud_filter_qinq_create(struct i40e_pf
> *pf)
>  	return ret;
>  }
> 
> +int
> +i40e_config_rss_filter(struct i40e_pf *pf,
> +		struct i40e_rte_flow_rss_conf *conf, bool add) {
> +	struct i40e_hw *hw = I40E_PF_TO_HW(pf);
> +	uint32_t i, lut = 0;
> +	uint16_t j, num;
> +	struct rte_eth_rss_conf rss_conf = conf->rss_conf;
> +	struct i40e_rte_flow_rss_conf *rss_info = &pf->rss_info;
> +
> +	if (!add) {
> +		if (memcmp(conf, rss_info,
> +			sizeof(struct i40e_rte_flow_rss_conf)) == 0) {
> +			i40e_pf_disable_rss(pf);
> +			memset(rss_info, 0,
> +				sizeof(struct i40e_rte_flow_rss_conf));
> +			return 0;
> +		}
> +		return -EINVAL;
> +	}
> +
> +	if (rss_info->num)
> +		return -EINVAL;
> +
> +	/* If both VMDQ and RSS enabled, not all of PF queues are configured.
> +	 * It's necessary to calculate the actual PF queues that are configured.
> +	 */
> +	if (pf->dev_data->dev_conf.rxmode.mq_mode &
> ETH_MQ_RX_VMDQ_FLAG)
> +		num = i40e_pf_calc_configured_queues_num(pf);
> +	else
> +		num = pf->dev_data->nb_rx_queues;
> +
> +	num = RTE_MIN(num, conf->num);
> +	PMD_DRV_LOG(INFO, "Max of contiguous %u PF queues are
> configured",
> +			num);
> +
> +	if (num == 0) {
> +		PMD_DRV_LOG(ERR, "No PF queues are configured to enable RSS");
> +		return -ENOTSUP;
> +	}
> +
> +	/* Fill in redirection table */
> +	for (i = 0, j = 0; i < hw->func_caps.rss_table_size; i++, j++) {
> +		if (j == num)
> +			j = 0;
> +		lut = (lut << 8) | (conf->queue[j] & ((0x1 <<
> +			hw->func_caps.rss_table_entry_width) - 1));
> +		if ((i & 3) == 3)
> +			I40E_WRITE_REG(hw, I40E_PFQF_HLUT(i >> 2), lut);
> +	}
> +
> +	if ((rss_conf.rss_hf & pf->adapter->flow_types_mask) == 0) {
> +		i40e_pf_disable_rss(pf);
> +		return 0;
> +	}
> +	if (rss_conf.rss_key == NULL || rss_conf.rss_key_len <
> +		(I40E_PFQF_HKEY_MAX_INDEX + 1) * sizeof(uint32_t)) {
> +		/* Random default keys */
> +		static uint32_t rss_key_default[] = {0x6b793944,
> +			0x23504cb5, 0x5bea75b6, 0x309f4f12, 0x3dc0a2b8,
> +			0x024ddcdf, 0x339b8ca0, 0x4c4af64a, 0x34fac605,
> +			0x55d85839, 0x3a58997d, 0x2ec938e1, 0x66031581};
> +
> +		rss_conf.rss_key = (uint8_t *)rss_key_default;
> +		rss_conf.rss_key_len = (I40E_PFQF_HKEY_MAX_INDEX + 1) *
> +							sizeof(uint32_t);
> +	}
> +
> +	return i40e_hw_rss_hash_set(pf, &rss_conf);
> +
> +	rte_memcpy(rss_info,
> +		conf, sizeof(struct i40e_rte_flow_rss_conf));
> +
> +	return 0;
> +}
> +
>  RTE_INIT(i40e_init_log);
>  static void
>  i40e_init_log(void)
> diff --git a/drivers/net/i40e/i40e_ethdev.h b/drivers/net/i40e/i40e_ethdev.h
> index cd67453..0a59e39 100644
> --- a/drivers/net/i40e/i40e_ethdev.h
> +++ b/drivers/net/i40e/i40e_ethdev.h
> @@ -891,6 +891,13 @@ struct i40e_customized_pctype {
>  	bool valid;   /* Check if it's valid */
>  };
> 
> +struct i40e_rte_flow_rss_conf {
> +	struct rte_eth_rss_conf rss_conf; /**< RSS parameters. */
> +	uint16_t queue_region_conf; /**< Queue region config flag */
> +	uint16_t num; /**< Number of entries in queue[]. */
> +	uint16_t queue[I40E_MAX_Q_PER_TC]; /**< Queues indices to use. */ };
> +
>  /*
>   * Structure to store private data specific for PF instance.
>   */
> @@ -945,6 +952,7 @@ struct i40e_pf {
>  	struct i40e_fdir_info fdir; /* flow director info */
>  	struct i40e_ethertype_rule ethertype; /* Ethertype filter rule */
>  	struct i40e_tunnel_rule tunnel; /* Tunnel filter rule */
> +	struct i40e_rte_flow_rss_conf rss_info; /* rss info */
>  	struct i40e_queue_regions queue_region; /* queue region info */
>  	struct i40e_fc_conf fc_conf; /* Flow control conf */
>  	struct i40e_mirror_rule_list mirror_list; @@ -1071,6 +1079,7 @@ union
> i40e_filter_t {
>  	struct i40e_fdir_filter_conf fdir_filter;
>  	struct rte_eth_tunnel_filter_conf tunnel_filter;
>  	struct i40e_tunnel_filter_conf consistent_tunnel_filter;
> +	struct i40e_rte_flow_rss_conf rss_conf;
>  };
> 
>  typedef int (*parse_filter_t)(struct rte_eth_dev *dev, @@ -1198,6 +1207,8
> @@ int i40e_dcb_init_configure(struct rte_eth_dev *dev, bool sw_dcb);  int
> i40e_flush_queue_region_all_conf(struct rte_eth_dev *dev,
>  		struct i40e_hw *hw, struct i40e_pf *pf, uint16_t on);  void
> i40e_init_queue_region_conf(struct rte_eth_dev *dev);
> +int i40e_config_rss_filter(struct i40e_pf *pf,
> +		struct i40e_rte_flow_rss_conf *conf, bool add);
> 
>  #define I40E_DEV_TO_PCI(eth_dev) \
>  	RTE_DEV_TO_PCI((eth_dev)->device)
> diff --git a/drivers/net/i40e/i40e_flow.c b/drivers/net/i40e/i40e_flow.c index
> 7e4936e..e127f4c 100644
> --- a/drivers/net/i40e/i40e_flow.c
> +++ b/drivers/net/i40e/i40e_flow.c
> @@ -138,6 +138,8 @@ static int i40e_flow_flush_fdir_filter(struct i40e_pf
> *pf);  static int i40e_flow_flush_ethertype_filter(struct i40e_pf *pf);  static
> int i40e_flow_flush_tunnel_filter(struct i40e_pf *pf);  static int
> +i40e_flow_flush_rss_filter(struct rte_eth_dev *dev); static int
>  i40e_flow_parse_qinq_filter(struct rte_eth_dev *dev,
>  			      const struct rte_flow_attr *attr,
>  			      const struct rte_flow_item pattern[], @@ -4095,6
> +4097,297 @@ i40e_flow_parse_qinq_filter(struct rte_eth_dev *dev,  }
> 
>  static int
> +i40e_flow_parse_rss_pattern(__rte_unused struct rte_eth_dev *dev,
> +			     const struct rte_flow_item *pattern,
> +			     struct rte_flow_error *error,
> +			     uint8_t *action_flag,
> +			     struct i40e_queue_regions *info) {
> +	const struct rte_flow_item_vlan *vlan_spec, *vlan_mask;
> +	const struct rte_flow_item *item = pattern;
> +	enum rte_flow_item_type item_type;
> +
> +	if (item->type == RTE_FLOW_ITEM_TYPE_END)
> +		return 0;
> +
> +	for (; item->type != RTE_FLOW_ITEM_TYPE_END; item++) {
> +		if (item->last) {
> +			rte_flow_error_set(error, EINVAL,
> +					   RTE_FLOW_ERROR_TYPE_ITEM,
> +					   item,
> +					   "Not support range");
> +			return -rte_errno;
> +		}
> +		item_type = item->type;
> +		switch (item_type) {
> +		case RTE_FLOW_ITEM_TYPE_ETH:
> +			*action_flag = 1;
> +			break;
> +		case RTE_FLOW_ITEM_TYPE_VLAN:
> +			vlan_spec =
> +				(const struct rte_flow_item_vlan *)item->spec;
> +			vlan_mask =
> +				(const struct rte_flow_item_vlan *)item->mask;
> +			if (vlan_spec && vlan_mask) {
> +				if (vlan_mask->tci ==
> +					rte_cpu_to_be_16(I40E_TCI_MASK)) {
> +					info->region[0].user_priority[0] =
> +						(vlan_spec->tci >> 13) & 0x7;
> +					info->region[0].user_priority_num = 1;
> +					info->queue_region_number = 1;
> +					*action_flag = 0;
> +				}
> +			}
> +			break;
> +		default:
> +			break;
> +		}
> +	}
> +
> +	return 0;

[Qi:] The function only check item->last, besides seems all kinds of pattern sequence will be accept, this may not match device's capability.
I suggest to add more strict pattern check and more comment to explain the acceptable pattern.

> +}
> +
> +static int
> +i40e_flow_parse_rss_action(struct rte_eth_dev *dev,
> +			    const struct rte_flow_action *actions,
> +			    struct rte_flow_error *error,
> +			    uint8_t *action_flag,
> +			    struct i40e_queue_regions *conf_info,
> +			    union i40e_filter_t *filter)
> +{
> +	const struct rte_flow_action *act;
> +	const struct rte_flow_action_rss *rss;
> +	struct i40e_pf *pf = I40E_DEV_PRIVATE_TO_PF(dev->data->dev_private);
> +	struct i40e_queue_regions *info = &pf->queue_region;
> +	struct i40e_rte_flow_rss_conf *rss_config =
> +			&filter->rss_conf;
> +	struct i40e_rte_flow_rss_conf *rss_info = &pf->rss_info;
> +	uint16_t i, j, n;
> +	uint32_t index = 0;
> +
> +	NEXT_ITEM_OF_ACTION(act, actions, index);
> +	rss = (const struct rte_flow_action_rss *)act->conf;
> +
> +	if (action_flag) {
> +		for (n = 0; n < 64; n++) {
> +			if (rss->rss_conf->rss_hf & (1 << n)) {
> +				conf_info->region[0].user_priority[0] = n;
> +				conf_info->region[0].user_priority_num = 1;
> +				conf_info->queue_region_number = 1;
> +				break;
> +			}
> +		}
> +	}

[Qi:] Convert act->conf to struct rte_flow_action_rss and access its data should after you checked the act->type is RTE_FLOW_ACTION_TYPE_RSS, 
So, it's better to switch place with following type check code.
> +
> +	/**
> +	 * rss only supports forwarding,
> +	 * check if the first not void action is RSS.
> +	 */
> +	if (act->type != RTE_FLOW_ACTION_TYPE_RSS) {
> +		memset(rss_config, 0, sizeof(struct i40e_rte_flow_rss_conf));
> +		rte_flow_error_set(error, EINVAL,
> +			RTE_FLOW_ERROR_TYPE_ACTION,
> +			act, "Not supported action.");
> +		return -rte_errno;
> +	}
> +
> +	for (n = 0; n < conf_info->queue_region_number; n++) {
> +		if (conf_info->region[n].user_priority_num ||
> +				conf_info->region[n].flowtype_num) {
> +			if (!((rte_is_power_of_2(rss->num)) &&
> +					rss->num <= 64)) {
> +				PMD_DRV_LOG(ERR, "The region sizes should be any of
> the following values: 1, 2, 4, 8, 16, 32, 64 as long as the "
> +				"total number of queues do not exceed the VSI
> allocation");
> +				return -rte_errno;
> +			}
> +
> +			if (conf_info->region[n].user_priority[n] >=
> +					I40E_MAX_USER_PRIORITY) {
> +				PMD_DRV_LOG(ERR, "the user priority max index is 7");
> +				return -rte_errno;
> +			}
> +
> +			if (conf_info->region[n].hw_flowtype[n] >=
> +					I40E_FILTER_PCTYPE_MAX) {
> +				PMD_DRV_LOG(ERR, "the hw_flowtype or PCTYPE max
> index is 63");
> +				return -rte_errno;
> +			}
> +
> +			if (rss_info->num < rss->num ||
> +				rss_info->queue[0] < rss->queue[0] ||
> +				(rss->queue[0] + rss->num >
> +					rss_info->num + rss_info->queue[0])) {
> +				rte_flow_error_set(error, EINVAL,
> +					RTE_FLOW_ERROR_TYPE_ACTION,
> +					act,
> +					"no valid queues");
> +				return -rte_errno;
> +			}
> +
> +			for (i = 0; i < info->queue_region_number; i++) {
> +				if (info->region[i].queue_num == rss->num &&
> +					info->region[i].queue_start_index ==
> +						rss->queue[0])
> +					break;
> +			}
> +
> +			if (i == info->queue_region_number) {
> +				if (i > I40E_REGION_MAX_INDEX) {
> +					PMD_DRV_LOG(ERR, "the queue region max index is
> 7");
> +					return -rte_errno;
> +				}
> +
> +				info->region[i].queue_num =
> +					rss->num;
> +				info->region[i].queue_start_index =
> +					rss->queue[0];
> +				info->region[i].region_id =
> +					info->queue_region_number;
> +
> +				j = info->region[i].user_priority_num;
> +				if (conf_info->region[n].user_priority_num) {
> +					info->region[i].user_priority[j] =
> +						conf_info->
> +						region[n].user_priority[0];
> +					info->region[i].user_priority_num++;
> +				}
> +
> +				j = info->region[i].flowtype_num;
> +				if (conf_info->region[n].flowtype_num) {
> +					info->region[i].hw_flowtype[j] =
> +						conf_info->
> +						region[n].hw_flowtype[0];
> +					info->region[i].flowtype_num++;
> +				}
> +				info->queue_region_number++;
> +			} else {
> +				j = info->region[i].user_priority_num;
> +				if (conf_info->region[n].user_priority_num) {
> +					info->region[i].user_priority[j] =
> +						conf_info->
> +						region[n].user_priority[0];
> +					info->region[i].user_priority_num++;
> +				}
> +
> +				j = info->region[i].flowtype_num;
> +				if (conf_info->region[n].flowtype_num) {
> +					info->region[i].hw_flowtype[j] =
> +						conf_info->
> +						region[n].hw_flowtype[0];
> +					info->region[i].flowtype_num++;
> +				}
> +			}
> +		}
> +
> +		rss_config->queue_region_conf = TRUE;
> +		return 0;
> +	}
> +
> +	if (!rss || !rss->num) {
> +		rte_flow_error_set(error, EINVAL,
> +				RTE_FLOW_ERROR_TYPE_ACTION,
> +				act,
> +				"no valid queues");
> +		return -rte_errno;
> +	}
> +
> +	for (n = 0; n < rss->num; n++) {
> +		if (rss->queue[n] >= dev->data->nb_rx_queues) {
> +			rte_flow_error_set(error, EINVAL,
> +				   RTE_FLOW_ERROR_TYPE_ACTION,
> +				   act,
> +				   "queue id > max number of queues");
> +			return -rte_errno;
> +		}
> +	}
> +	if (rss->rss_conf)
> +		rss_config->rss_conf = *rss->rss_conf;
> +	else
> +		rss_config->rss_conf.rss_hf =
> +			pf->adapter->flow_types_mask;
> +
> +	for (n = 0; n < rss->num; ++n)
> +		rss_config->queue[n] = rss->queue[n];
> +	rss_config->num = rss->num;
> +	index++;
> +
> +	/* check if the next not void action is END */
> +	NEXT_ITEM_OF_ACTION(act, actions, index);
> +	if (act->type != RTE_FLOW_ACTION_TYPE_END) {
> +		memset(rss_config, 0, sizeof(struct i40e_rte_flow_rss_conf));
> +		rte_flow_error_set(error, EINVAL,
> +			RTE_FLOW_ERROR_TYPE_ACTION,
> +			act, "Not supported action.");
> +		return -rte_errno;
> +	}
> +	rss_config->queue_region_conf = FALSE;
> +
> +	return 0;
> +}
> +
> +static int
> +i40e_parse_rss_filter(struct rte_eth_dev *dev,
> +			const struct rte_flow_attr *attr,
> +			const struct rte_flow_item pattern[],
> +			const struct rte_flow_action actions[],
> +			union i40e_filter_t *filter,
> +			struct rte_flow_error *error)
> +{
> +	int ret;
> +	struct i40e_queue_regions info;
> +	uint8_t action_flag = 0;
> +
> +	memset(&info, 0, sizeof(struct i40e_queue_regions));
> +
> +	ret = i40e_flow_parse_rss_pattern(dev, pattern,
> +					error, &action_flag, &info);
> +	if (ret)
> +		return ret;
> +
> +	ret = i40e_flow_parse_rss_action(dev, actions, error,
> +					&action_flag, &info, filter);
> +	if (ret)
> +		return ret;
> +
> +	ret = i40e_flow_parse_attr(attr, error);
> +	if (ret)
> +		return ret;
> +
> +	cons_filter_type = RTE_ETH_FILTER_HASH;
> +
> +	return 0;
> +}
> +
> +static int
> +i40e_config_rss_filter_set(struct rte_eth_dev *dev,
> +		struct i40e_rte_flow_rss_conf *conf, bool add) {

[Qi:] why parameter "add", it is always set with 1 and we have i40e_config_rss_filter_del with add = 0.

> +	struct i40e_pf *pf = I40E_DEV_PRIVATE_TO_PF(dev->data->dev_private);
> +	struct i40e_hw *hw =
> I40E_DEV_PRIVATE_TO_HW(dev->data->dev_private);
> +
> +	if (conf->queue_region_conf) {
> +		i40e_flush_queue_region_all_conf(dev, hw, pf, add);
> +		conf->queue_region_conf = 0;
> +	} else {
> +		i40e_config_rss_filter(pf, conf, add);
> +	}
> +	return 0;
> +}
> +
> +static int
> +i40e_config_rss_filter_del(struct rte_eth_dev *dev,
> +		struct i40e_rte_flow_rss_conf *conf, bool add) {

[Qi:] same question for "add".

> +	struct i40e_pf *pf = I40E_DEV_PRIVATE_TO_PF(dev->data->dev_private);
> +	struct i40e_hw *hw =
> I40E_DEV_PRIVATE_TO_HW(dev->data->dev_private);
> +
> +	i40e_flush_queue_region_all_conf(dev, hw, pf, add);
> +
> +	i40e_config_rss_filter(pf, conf, add);
> +	return 0;
> +}
> +
> +static int
>  i40e_flow_validate(struct rte_eth_dev *dev,
>  		   const struct rte_flow_attr *attr,
>  		   const struct rte_flow_item pattern[], @@ -4130,6 +4423,17 @@
> i40e_flow_validate(struct rte_eth_dev *dev,
> 
>  	memset(&cons_filter, 0, sizeof(cons_filter));
> 
> +	/* Get the non-void item of action */
> +	while ((actions + i)->type == RTE_FLOW_ACTION_TYPE_VOID)
> +		i++;
> +
> +	if ((actions + i)->type == RTE_FLOW_ACTION_TYPE_RSS) {
> +		ret = i40e_parse_rss_filter(dev, attr, pattern,
> +					actions, &cons_filter, error);
> +		return ret;
> +	}
> +
> +	i = 0;
>  	/* Get the non-void item number of pattern */
>  	while ((pattern + i)->type != RTE_FLOW_ITEM_TYPE_END) {
>  		if ((pattern + i)->type != RTE_FLOW_ITEM_TYPE_VOID) @@ -4217,6
> +4521,11 @@ i40e_flow_create(struct rte_eth_dev *dev,
>  		flow->rule = TAILQ_LAST(&pf->tunnel.tunnel_list,
>  					i40e_tunnel_filter_list);
>  		break;
> +	case RTE_ETH_FILTER_HASH:
> +		ret = i40e_config_rss_filter_set(dev,
> +			    &cons_filter.rss_conf, 1);
> +		flow->rule = &pf->rss_info;
> +		break;
>  	default:
>  		goto free_flow;
>  	}
> @@ -4255,6 +4564,9 @@ i40e_flow_destroy(struct rte_eth_dev *dev,
>  		ret = i40e_flow_add_del_fdir_filter(dev,
>  		       &((struct i40e_fdir_filter *)flow->rule)->fdir, 0);
>  		break;
> +	case RTE_ETH_FILTER_HASH:
> +		ret = i40e_config_rss_filter_del(dev,
> +			   (struct i40e_rte_flow_rss_conf *)flow->rule, 0);
>  	default:
>  		PMD_DRV_LOG(WARNING, "Filter type (%d) not supported",
>  			    filter_type);
> @@ -4397,6 +4709,14 @@ i40e_flow_flush(struct rte_eth_dev *dev, struct
> rte_flow_error *error)
>  		return -rte_errno;
>  	}
> 
> +	ret = i40e_flow_flush_rss_filter(dev);
> +	if (ret) {
> +		rte_flow_error_set(error, -ret,
> +				   RTE_FLOW_ERROR_TYPE_HANDLE, NULL,
> +				   "Failed to flush rss flows.");
> +		return -rte_errno;
> +	}
> +
>  	return ret;
>  }
> 
> @@ -4487,3 +4807,19 @@ i40e_flow_flush_tunnel_filter(struct i40e_pf *pf)
> 
>  	return ret;
>  }
> +
> +/* remove the rss filter */
> +static int
> +i40e_flow_flush_rss_filter(struct rte_eth_dev *dev) {
> +	struct i40e_pf *pf = I40E_DEV_PRIVATE_TO_PF(dev->data->dev_private);
> +	struct i40e_rte_flow_rss_conf *rss_info = &pf->rss_info;
> +	struct i40e_hw *hw =
> I40E_DEV_PRIVATE_TO_HW(dev->data->dev_private);
> +	int32_t ret = -EINVAL;
> +
> +	ret = i40e_flush_queue_region_all_conf(dev, hw, pf, 0);
> +
> +	if (rss_info->num)
> +		ret = i40e_config_rss_filter(pf, rss_info, FALSE);
> +	return ret;
> +}
> --
> 2.9.3

  parent reply	other threads:[~2017-12-22  4:36 UTC|newest]

Thread overview: 17+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-11-24  8:43 Wei Zhao
2017-12-21  3:12 ` Zhang, Helin
2017-12-22  4:36 ` Zhang, Qi Z [this message]
2018-01-07 15:43   ` Zhang, Helin
2018-01-08  1:53     ` Zhao1, Wei
2018-01-08  8:30   ` Zhao1, Wei
2018-01-08  8:33   ` Zhao1, Wei
2018-01-08  8:35 ` [dpdk-dev] [PATCH v2] " Wei Zhao
2018-01-09  2:33   ` Zhang, Qi Z
2018-01-10  1:53     ` Zhao1, Wei
2018-01-09  9:18   ` [dpdk-dev] [PATCH v3] " Wei Zhao
2018-01-10  2:10     ` [dpdk-dev] [PATCH v4] " Wei Zhao
2018-01-10  2:58       ` Zhang, Qi Z
2018-01-10  3:36         ` Zhang, Helin
2018-01-10 13:28       ` Ferruh Yigit
2018-01-12  5:50         ` Zhao1, Wei
2018-01-12  6:23         ` Zhao1, Wei

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=039ED4275CED7440929022BC67E7061153123DE8@SHSMSX103.ccr.corp.intel.com \
    --to=qi.z.zhang@intel.com \
    --cc=dev@dpdk.org \
    --cc=wei.zhao1@intel.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).