提交 be565ec7 编写于 作者: W Wang Qing 提交者: David S. Miller

net: ethernet: ti: add missing of_node_put before return

Fix following coccicheck warning:
WARNING: Function "for_each_child_of_node"
should have of_node_put() before return.

Early exits from for_each_child_of_node should decrement the
node reference counter.
Signed-off-by: NWang Qing <wangqing@vivo.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 71da1aec
...@@ -1844,13 +1844,14 @@ static int am65_cpsw_nuss_init_slave_ports(struct am65_cpsw_common *common) ...@@ -1844,13 +1844,14 @@ static int am65_cpsw_nuss_init_slave_ports(struct am65_cpsw_common *common)
if (ret < 0) { if (ret < 0) {
dev_err(dev, "%pOF error reading port_id %d\n", dev_err(dev, "%pOF error reading port_id %d\n",
port_np, ret); port_np, ret);
return ret; goto of_node_put;
} }
if (!port_id || port_id > common->port_num) { if (!port_id || port_id > common->port_num) {
dev_err(dev, "%pOF has invalid port_id %u %s\n", dev_err(dev, "%pOF has invalid port_id %u %s\n",
port_np, port_id, port_np->name); port_np, port_id, port_np->name);
return -EINVAL; ret = -EINVAL;
goto of_node_put;
} }
port = am65_common_get_port(common, port_id); port = am65_common_get_port(common, port_id);
...@@ -1866,8 +1867,10 @@ static int am65_cpsw_nuss_init_slave_ports(struct am65_cpsw_common *common) ...@@ -1866,8 +1867,10 @@ static int am65_cpsw_nuss_init_slave_ports(struct am65_cpsw_common *common)
(AM65_CPSW_NU_FRAM_PORT_OFFSET * (port_id - 1)); (AM65_CPSW_NU_FRAM_PORT_OFFSET * (port_id - 1));
port->slave.mac_sl = cpsw_sl_get("am65", dev, port->port_base); port->slave.mac_sl = cpsw_sl_get("am65", dev, port->port_base);
if (IS_ERR(port->slave.mac_sl)) if (IS_ERR(port->slave.mac_sl)) {
return PTR_ERR(port->slave.mac_sl); ret = PTR_ERR(port->slave.mac_sl);
goto of_node_put;
}
port->disabled = !of_device_is_available(port_np); port->disabled = !of_device_is_available(port_np);
if (port->disabled) { if (port->disabled) {
...@@ -1880,7 +1883,7 @@ static int am65_cpsw_nuss_init_slave_ports(struct am65_cpsw_common *common) ...@@ -1880,7 +1883,7 @@ static int am65_cpsw_nuss_init_slave_ports(struct am65_cpsw_common *common)
ret = PTR_ERR(port->slave.ifphy); ret = PTR_ERR(port->slave.ifphy);
dev_err(dev, "%pOF error retrieving port phy: %d\n", dev_err(dev, "%pOF error retrieving port phy: %d\n",
port_np, ret); port_np, ret);
return ret; goto of_node_put;
} }
port->slave.mac_only = port->slave.mac_only =
...@@ -1889,10 +1892,12 @@ static int am65_cpsw_nuss_init_slave_ports(struct am65_cpsw_common *common) ...@@ -1889,10 +1892,12 @@ static int am65_cpsw_nuss_init_slave_ports(struct am65_cpsw_common *common)
/* get phy/link info */ /* get phy/link info */
if (of_phy_is_fixed_link(port_np)) { if (of_phy_is_fixed_link(port_np)) {
ret = of_phy_register_fixed_link(port_np); ret = of_phy_register_fixed_link(port_np);
if (ret) if (ret) {
return dev_err_probe(dev, ret, ret = dev_err_probe(dev, ret,
"failed to register fixed-link phy %pOF\n", "failed to register fixed-link phy %pOF\n",
port_np); port_np);
goto of_node_put;
}
port->slave.phy_node = of_node_get(port_np); port->slave.phy_node = of_node_get(port_np);
} else { } else {
port->slave.phy_node = port->slave.phy_node =
...@@ -1902,14 +1907,15 @@ static int am65_cpsw_nuss_init_slave_ports(struct am65_cpsw_common *common) ...@@ -1902,14 +1907,15 @@ static int am65_cpsw_nuss_init_slave_ports(struct am65_cpsw_common *common)
if (!port->slave.phy_node) { if (!port->slave.phy_node) {
dev_err(dev, dev_err(dev,
"slave[%d] no phy found\n", port_id); "slave[%d] no phy found\n", port_id);
return -ENODEV; ret = -ENODEV;
goto of_node_put;
} }
ret = of_get_phy_mode(port_np, &port->slave.phy_if); ret = of_get_phy_mode(port_np, &port->slave.phy_if);
if (ret) { if (ret) {
dev_err(dev, "%pOF read phy-mode err %d\n", dev_err(dev, "%pOF read phy-mode err %d\n",
port_np, ret); port_np, ret);
return ret; goto of_node_put;
} }
ret = of_get_mac_address(port_np, port->slave.mac_addr); ret = of_get_mac_address(port_np, port->slave.mac_addr);
...@@ -1932,6 +1938,11 @@ static int am65_cpsw_nuss_init_slave_ports(struct am65_cpsw_common *common) ...@@ -1932,6 +1938,11 @@ static int am65_cpsw_nuss_init_slave_ports(struct am65_cpsw_common *common)
} }
return 0; return 0;
of_node_put:
of_node_put(port_np);
of_node_put(node);
return ret;
} }
static void am65_cpsw_pcpu_stats_free(void *data) static void am65_cpsw_pcpu_stats_free(void *data)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册