net: ethernet: mediatek: fix issue of driver removal with interface is up
mtk_stop() must be called to stop for freeing DMA resources acquired and restoring state changed by mtk_open() firstly when module removal. Signed-off-by: Sean Wang <sean.wang@mediatek.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
7c6b0d76fa
commit
79e9a41438
1 changed files with 8 additions and 0 deletions
|
@ -1906,6 +1906,14 @@ err_free_dev:
|
|||
static int mtk_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct mtk_eth *eth = platform_get_drvdata(pdev);
|
||||
int i;
|
||||
|
||||
/* stop all devices to make sure that dma is properly shut down */
|
||||
for (i = 0; i < MTK_MAC_COUNT; i++) {
|
||||
if (!eth->netdev[i])
|
||||
continue;
|
||||
mtk_stop(eth->netdev[i]);
|
||||
}
|
||||
|
||||
clk_disable_unprepare(eth->clks[MTK_CLK_ETHIF]);
|
||||
clk_disable_unprepare(eth->clks[MTK_CLK_ESW]);
|
||||
|
|
Loading…
Reference in a new issue