]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
net: hns: hisilicon: hns_dsaf_mac: switch to scoped device_for_each_child_node()
authorJavier Carrasco <javier.carrasco.cruz@gmail.com>
Mon, 30 Sep 2024 20:38:26 +0000 (22:38 +0200)
committerJakub Kicinski <kuba@kernel.org>
Fri, 4 Oct 2024 16:28:26 +0000 (09:28 -0700)
Use device_for_each_child_node_scoped() to simplify the code by removing
the need for explicit calls to fwnode_handle_put() in every error path.
This approach also accounts for any error path that could be added.

Signed-off-by: Javier Carrasco <javier.carrasco.cruz@gmail.com>
Link: https://patch.msgid.link/20240930-net-device_for_each_child_node_scoped-v2-2-35f09333c1d7@gmail.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/hisilicon/hns/hns_dsaf_mac.c

index 58baac7103b3805bb16ce46045b206bf6566497c..5fa9b2eeb929c13dbaa00677227e966a303662be 100644 (file)
@@ -1090,28 +1090,24 @@ int hns_mac_init(struct dsaf_device *dsaf_dev)
        u32 port_id;
        int max_port_num = hns_mac_get_max_port_num(dsaf_dev);
        struct hns_mac_cb *mac_cb;
-       struct fwnode_handle *child;
 
-       device_for_each_child_node(dsaf_dev->dev, child) {
+       device_for_each_child_node_scoped(dsaf_dev->dev, child) {
                ret = fwnode_property_read_u32(child, "reg", &port_id);
                if (ret) {
-                       fwnode_handle_put(child);
                        dev_err(dsaf_dev->dev,
                                "get reg fail, ret=%d!\n", ret);
                        return ret;
                }
                if (port_id >= max_port_num) {
-                       fwnode_handle_put(child);
                        dev_err(dsaf_dev->dev,
                                "reg(%u) out of range!\n", port_id);
                        return -EINVAL;
                }
                mac_cb = devm_kzalloc(dsaf_dev->dev, sizeof(*mac_cb),
                                      GFP_KERNEL);
-               if (!mac_cb) {
-                       fwnode_handle_put(child);
+               if (!mac_cb)
                        return -ENOMEM;
-               }
+
                mac_cb->fw_port = child;
                mac_cb->mac_id = (u8)port_id;
                dsaf_dev->mac_cb[port_id] = mac_cb;