提交 e715d745 编写于 作者: J Jose Abreu 提交者: David S. Miller

net: stmmac: selftests: Update status when disabling RSS

We are disabling RSS on HW but not updating the internal private status
to the 'disabled' state. This is needed for next tc commit that will
check if RSS is disabled before trying to apply filters.

Fixes: 4647e021 ("net: stmmac: selftests: Add selftest for L3/L4 Filters")
Signed-off-by: NJose Abreu <Jose.Abreu@synopsys.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 db885e66
...@@ -1323,16 +1323,19 @@ static int __stmmac_test_l3filt(struct stmmac_priv *priv, u32 dst, u32 src, ...@@ -1323,16 +1323,19 @@ static int __stmmac_test_l3filt(struct stmmac_priv *priv, u32 dst, u32 src,
struct stmmac_packet_attrs attr = { }; struct stmmac_packet_attrs attr = { };
struct flow_dissector *dissector; struct flow_dissector *dissector;
struct flow_cls_offload *cls; struct flow_cls_offload *cls;
int ret, old_enable = 0;
struct flow_rule *rule; struct flow_rule *rule;
int ret;
if (!tc_can_offload(priv->dev)) if (!tc_can_offload(priv->dev))
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (!priv->dma_cap.l3l4fnum) if (!priv->dma_cap.l3l4fnum)
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (priv->rss.enable) if (priv->rss.enable) {
old_enable = priv->rss.enable;
priv->rss.enable = false;
stmmac_rss_configure(priv, priv->hw, NULL, stmmac_rss_configure(priv, priv->hw, NULL,
priv->plat->rx_queues_to_use); priv->plat->rx_queues_to_use);
}
dissector = kzalloc(sizeof(*dissector), GFP_KERNEL); dissector = kzalloc(sizeof(*dissector), GFP_KERNEL);
if (!dissector) { if (!dissector) {
...@@ -1399,7 +1402,8 @@ static int __stmmac_test_l3filt(struct stmmac_priv *priv, u32 dst, u32 src, ...@@ -1399,7 +1402,8 @@ static int __stmmac_test_l3filt(struct stmmac_priv *priv, u32 dst, u32 src,
cleanup_dissector: cleanup_dissector:
kfree(dissector); kfree(dissector);
cleanup_rss: cleanup_rss:
if (priv->rss.enable) { if (old_enable) {
priv->rss.enable = old_enable;
stmmac_rss_configure(priv, priv->hw, &priv->rss, stmmac_rss_configure(priv, priv->hw, &priv->rss,
priv->plat->rx_queues_to_use); priv->plat->rx_queues_to_use);
} }
...@@ -1444,16 +1448,19 @@ static int __stmmac_test_l4filt(struct stmmac_priv *priv, u32 dst, u32 src, ...@@ -1444,16 +1448,19 @@ static int __stmmac_test_l4filt(struct stmmac_priv *priv, u32 dst, u32 src,
struct stmmac_packet_attrs attr = { }; struct stmmac_packet_attrs attr = { };
struct flow_dissector *dissector; struct flow_dissector *dissector;
struct flow_cls_offload *cls; struct flow_cls_offload *cls;
int ret, old_enable = 0;
struct flow_rule *rule; struct flow_rule *rule;
int ret;
if (!tc_can_offload(priv->dev)) if (!tc_can_offload(priv->dev))
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (!priv->dma_cap.l3l4fnum) if (!priv->dma_cap.l3l4fnum)
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (priv->rss.enable) if (priv->rss.enable) {
old_enable = priv->rss.enable;
priv->rss.enable = false;
stmmac_rss_configure(priv, priv->hw, NULL, stmmac_rss_configure(priv, priv->hw, NULL,
priv->plat->rx_queues_to_use); priv->plat->rx_queues_to_use);
}
dissector = kzalloc(sizeof(*dissector), GFP_KERNEL); dissector = kzalloc(sizeof(*dissector), GFP_KERNEL);
if (!dissector) { if (!dissector) {
...@@ -1525,7 +1532,8 @@ static int __stmmac_test_l4filt(struct stmmac_priv *priv, u32 dst, u32 src, ...@@ -1525,7 +1532,8 @@ static int __stmmac_test_l4filt(struct stmmac_priv *priv, u32 dst, u32 src,
cleanup_dissector: cleanup_dissector:
kfree(dissector); kfree(dissector);
cleanup_rss: cleanup_rss:
if (priv->rss.enable) { if (old_enable) {
priv->rss.enable = old_enable;
stmmac_rss_configure(priv, priv->hw, &priv->rss, stmmac_rss_configure(priv, priv->hw, &priv->rss,
priv->plat->rx_queues_to_use); priv->plat->rx_queues_to_use);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册