net: dsa: qca8k: put MDIO controller OF node if unavailable
authorVladimir Oltean <vladimir.oltean@nxp.com>
Fri, 2 Feb 2024 16:36:25 +0000 (18:36 +0200)
committerDavid S. Miller <davem@davemloft.net>
Mon, 5 Feb 2024 12:39:27 +0000 (12:39 +0000)
It was pointed out during the review [1] of commit e66bf63a7f67 ("net:
dsa: qca8k: skip MDIO bus creation if its OF node has status =
"disabled"") that we now leak a reference to the "mdio" OF node if it is
disabled.

This is only a concern when using dynamic OF as far as I can tell (like
probing on an overlay), since OF nodes are never freed in the regular
case. Additionally, I'm unaware of any actual device trees (in
production or elsewhere) which have status = "disabled" for the MDIO OF
node. So handling this as a simple enhancement.

[1] https://lore.kernel.org/netdev/CAJq09z4--Ug+3FAmp=EimQ8HTQYOWOuVon-PUMGB5a1N=RPv4g@mail.gmail.com/

Suggested-by: Luiz Angelo Daros de Luca <luizluca@gmail.com>
Signed-off-by: Vladimir Oltean <vladimir.oltean@nxp.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/dsa/qca/qca8k-8xxx.c

index 7a864329cb7267a9431a181a183c94b6f791f91e..95d78b3181d1c612d3b45cc93b87081902a3b6b7 100644 (file)
@@ -954,7 +954,7 @@ qca8k_mdio_register(struct qca8k_priv *priv)
 
        mdio = of_get_child_by_name(dev->of_node, "mdio");
        if (mdio && !of_device_is_available(mdio))
-               goto out;
+               goto out_put_node;
 
        bus = devm_mdiobus_alloc(dev);
        if (!bus) {
@@ -988,7 +988,6 @@ qca8k_mdio_register(struct qca8k_priv *priv)
 
 out_put_node:
        of_node_put(mdio);
-out:
        return err;
 }