Skip to content

Commit

Permalink
ethdev: fix RSS update when RSS is disabled
Browse files Browse the repository at this point in the history
[ upstream commit 93e1ea6 ]

The RTE_ETH_MQ_RX_RSS_FLAG flag is a switch to enable RSS. If the flag
is not set in dev_configure, RSS will be not configured and enabled.
However, RSS hash and reta can still be configured by ethdev ops to
enable RSS if the flag isn't set. The behavior is inconsistent.

Fixes: 99a2dd9 ("lib: remove librte_ prefix from directory names")

Signed-off-by: Huisong Li <lihuisong@huawei.com>
Signed-off-by: Min Hu (Connor) <humin29@huawei.com>
Reviewed-by: Ferruh Yigit <ferruh.yigit@xilinx.com>
  • Loading branch information
LiHuiSong1 authored and kevintraynor committed May 24, 2022
1 parent 0cec1c9 commit 15b794b
Showing 1 changed file with 15 additions and 0 deletions.
15 changes: 15 additions & 0 deletions lib/ethdev/rte_ethdev.c
Expand Up @@ -4081,6 +4081,7 @@ rte_eth_dev_rss_reta_update(uint16_t port_id,
struct rte_eth_rss_reta_entry64 *reta_conf,
uint16_t reta_size)
{
enum rte_eth_rx_mq_mode mq_mode;
struct rte_eth_dev *dev;
int ret;

Expand Down Expand Up @@ -4112,6 +4113,12 @@ rte_eth_dev_rss_reta_update(uint16_t port_id,
if (ret < 0)
return ret;

mq_mode = dev->data->dev_conf.rxmode.mq_mode;
if (!(mq_mode & RTE_ETH_MQ_RX_RSS_FLAG)) {
RTE_ETHDEV_LOG(ERR, "Multi-queue RSS mode isn't enabled.\n");
return -ENOTSUP;
}

RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->reta_update, -ENOTSUP);
return eth_err(port_id, (*dev->dev_ops->reta_update)(dev, reta_conf,
reta_size));
Expand Down Expand Up @@ -4151,6 +4158,7 @@ rte_eth_dev_rss_hash_update(uint16_t port_id,
{
struct rte_eth_dev *dev;
struct rte_eth_dev_info dev_info = { .flow_type_rss_offloads = 0, };
enum rte_eth_rx_mq_mode mq_mode;
int ret;

RTE_ETH_VALID_PORTID_OR_ERR_RET(port_id, -ENODEV);
Expand All @@ -4176,6 +4184,13 @@ rte_eth_dev_rss_hash_update(uint16_t port_id,
dev_info.flow_type_rss_offloads);
return -EINVAL;
}

mq_mode = dev->data->dev_conf.rxmode.mq_mode;
if (!(mq_mode & RTE_ETH_MQ_RX_RSS_FLAG)) {
RTE_ETHDEV_LOG(ERR, "Multi-queue RSS mode isn't enabled.\n");
return -ENOTSUP;
}

RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->rss_hash_update, -ENOTSUP);
return eth_err(port_id, (*dev->dev_ops->rss_hash_update)(dev,
rss_conf));
Expand Down

0 comments on commit 15b794b

Please sign in to comment.