mirror of https://gitee.com/openkylin/linux.git
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
|
@ -1906,6 +1906,14 @@ static int mtk_probe(struct platform_device *pdev)
|
||||||
static int mtk_remove(struct platform_device *pdev)
|
static int mtk_remove(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
struct mtk_eth *eth = platform_get_drvdata(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_ETHIF]);
|
||||||
clk_disable_unprepare(eth->clks[MTK_CLK_ESW]);
|
clk_disable_unprepare(eth->clks[MTK_CLK_ESW]);
|
||||||
|
|
Loading…
Reference in New Issue