提交 49dd48da 编写于 作者: S Sergei Shtylyov 提交者: David S. Miller

sh_eth: re-enable-E-MAC interrupts in sh_eth_set_ringparam()

The E-MAC interrupts are left disabled when the ring parameters are changed
via 'ethtool'. In order to fix this, it's enough to call sh_eth_dev_init()
with 'true' instead of 'false' for the second argument (which conveniently
allows us to remove the following code re-enabling E-DMAC interrupts and
reception).
Signed-off-by: NSergei Shtylyov <sergei.shtylyov@cogentembedded.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 183c948a
...@@ -2194,17 +2194,13 @@ static int sh_eth_set_ringparam(struct net_device *ndev, ...@@ -2194,17 +2194,13 @@ static int sh_eth_set_ringparam(struct net_device *ndev,
__func__); __func__);
return ret; return ret;
} }
ret = sh_eth_dev_init(ndev, false); ret = sh_eth_dev_init(ndev, true);
if (ret < 0) { if (ret < 0) {
netdev_err(ndev, "%s: sh_eth_dev_init failed.\n", netdev_err(ndev, "%s: sh_eth_dev_init failed.\n",
__func__); __func__);
return ret; return ret;
} }
mdp->irq_enabled = true;
sh_eth_write(ndev, mdp->cd->eesipr_value, EESIPR);
/* Setting the Rx mode will start the Rx process. */
sh_eth_write(ndev, EDRRR_R, EDRRR);
netif_device_attach(ndev); netif_device_attach(ndev);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册