Ver Fonte

net: ethernet: aurora: nb8800: fix fixed-link phydev leaks

Make sure to deregister and free any fixed-link PHY registered using
of_phy_register_fixed_link() on probe errors and on driver unbind.

Fixes: c7dfe3abf40e ("net: ethernet: nb8800: support fixed-link DT
node")
Signed-off-by: Johan Hovold <johan@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Johan Hovold há 8 anos atrás
pai
commit
9e08103130
1 ficheiros alterados com 7 adições e 2 exclusões
  1. 7 2
      drivers/net/ethernet/aurora/nb8800.c

+ 7 - 2
drivers/net/ethernet/aurora/nb8800.c

@@ -1466,12 +1466,12 @@ static int nb8800_probe(struct platform_device *pdev)
 
 
 	ret = nb8800_hw_init(dev);
 	ret = nb8800_hw_init(dev);
 	if (ret)
 	if (ret)
-		goto err_free_bus;
+		goto err_deregister_fixed_link;
 
 
 	if (ops && ops->init) {
 	if (ops && ops->init) {
 		ret = ops->init(dev);
 		ret = ops->init(dev);
 		if (ret)
 		if (ret)
-			goto err_free_bus;
+			goto err_deregister_fixed_link;
 	}
 	}
 
 
 	dev->netdev_ops = &nb8800_netdev_ops;
 	dev->netdev_ops = &nb8800_netdev_ops;
@@ -1504,6 +1504,9 @@ static int nb8800_probe(struct platform_device *pdev)
 
 
 err_free_dma:
 err_free_dma:
 	nb8800_dma_free(dev);
 	nb8800_dma_free(dev);
+err_deregister_fixed_link:
+	if (of_phy_is_fixed_link(pdev->dev.of_node))
+		of_phy_deregister_fixed_link(pdev->dev.of_node);
 err_free_bus:
 err_free_bus:
 	of_node_put(priv->phy_node);
 	of_node_put(priv->phy_node);
 	mdiobus_unregister(bus);
 	mdiobus_unregister(bus);
@@ -1521,6 +1524,8 @@ static int nb8800_remove(struct platform_device *pdev)
 	struct nb8800_priv *priv = netdev_priv(ndev);
 	struct nb8800_priv *priv = netdev_priv(ndev);
 
 
 	unregister_netdev(ndev);
 	unregister_netdev(ndev);
+	if (of_phy_is_fixed_link(pdev->dev.of_node))
+		of_phy_deregister_fixed_link(pdev->dev.of_node);
 	of_node_put(priv->phy_node);
 	of_node_put(priv->phy_node);
 
 
 	mdiobus_unregister(priv->mii_bus);
 	mdiobus_unregister(priv->mii_bus);