Commit 70c50265 authored by Robert Hancock's avatar Robert Hancock Committed by David S. Miller

net: axienet: stop interface during shutdown

On some platforms, such as iMX6 with PCIe devices, crashes or hangs can
occur if the axienet device continues to perform DMA transfers after
parent devices/busses have been shut down. Shut down the axienet
interface during its shutdown callback in order to avoid this.
Signed-off-by: default avatarRobert Hancock <hancock@sedsystems.ca>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent d05a9ed5
...@@ -1797,9 +1797,23 @@ static int axienet_remove(struct platform_device *pdev) ...@@ -1797,9 +1797,23 @@ static int axienet_remove(struct platform_device *pdev)
return 0; return 0;
} }
static void axienet_shutdown(struct platform_device *pdev)
{
struct net_device *ndev = platform_get_drvdata(pdev);
rtnl_lock();
netif_device_detach(ndev);
if (netif_running(ndev))
dev_close(ndev);
rtnl_unlock();
}
static struct platform_driver axienet_driver = { static struct platform_driver axienet_driver = {
.probe = axienet_probe, .probe = axienet_probe,
.remove = axienet_remove, .remove = axienet_remove,
.shutdown = axienet_shutdown,
.driver = { .driver = {
.name = "xilinx_axienet", .name = "xilinx_axienet",
.of_match_table = axienet_of_match, .of_match_table = axienet_of_match,
......
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