Commit f111606b authored by Zhengchao Shao's avatar Zhengchao Shao Committed by Paolo Abeni

net: mv643xx_eth: disable napi when init rxq or txq failed in mv643xx_eth_open()

When failed to init rxq or txq in mv643xx_eth_open() for opening device,
napi isn't disabled. When open mv643xx_eth device next time, it will
trigger a BUG_ON() in napi_enable(). Compile tested only.

Fixes: 2257e05c ("mv643xx_eth: get rid of receive-side locking")
Signed-off-by: default avatarZhengchao Shao <shaozhengchao@huawei.com>
Link: https://lore.kernel.org/r/20221109025432.80900-1-shaozhengchao@huawei.comSigned-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
parent 0348c1ab
...@@ -2481,6 +2481,7 @@ static int mv643xx_eth_open(struct net_device *dev) ...@@ -2481,6 +2481,7 @@ static int mv643xx_eth_open(struct net_device *dev)
for (i = 0; i < mp->rxq_count; i++) for (i = 0; i < mp->rxq_count; i++)
rxq_deinit(mp->rxq + i); rxq_deinit(mp->rxq + i);
out: out:
napi_disable(&mp->napi);
free_irq(dev->irq, dev); free_irq(dev->irq, dev);
return err; return err;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment