]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
device property: Add scoped fwnode child node iterators
authorJean-François Lessard <jefflessard3@gmail.com>
Tue, 2 Sep 2025 19:04:39 +0000 (15:04 -0400)
committerWolfram Sang <wsa+renesas@sang-engineering.com>
Wed, 10 Sep 2025 12:48:03 +0000 (14:48 +0200)
Add scoped versions of fwnode child node iterators that automatically
handle reference counting cleanup using the __free() attribute:

- fwnode_for_each_child_node_scoped()
- fwnode_for_each_available_child_node_scoped()

These macros follow the same pattern as existing scoped iterators in the
kernel, ensuring fwnode references are automatically released when the
iterator variable goes out of scope. This prevents resource leaks and
eliminates the need for manual cleanup in error paths.

The implementation mirrors the non-scoped variants but uses
__free(fwnode_handle) for automatic resource management, providing a
safer and more convenient interface for drivers iterating over firmware
node children.

Signed-off-by: Jean-François Lessard <jefflessard3@gmail.com>
Acked-by: Danilo Krummrich <dakr@kernel.org>
Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Reviewed-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: Wolfram Sang <wsa+renesas@sang-engineering.com>
include/linux/property.h

index 82f0cb3abd1e229f7fc009f3ee2f211e6d003e51..862e208133f360af64708fc5260f60490f1ab355 100644 (file)
@@ -176,6 +176,16 @@ struct fwnode_handle *fwnode_get_next_available_child_node(
        for (child = fwnode_get_next_available_child_node(fwnode, NULL); child;\
             child = fwnode_get_next_available_child_node(fwnode, child))
 
+#define fwnode_for_each_child_node_scoped(fwnode, child)               \
+       for (struct fwnode_handle *child __free(fwnode_handle) =        \
+               fwnode_get_next_child_node(fwnode, NULL);               \
+            child; child = fwnode_get_next_child_node(fwnode, child))
+
+#define fwnode_for_each_available_child_node_scoped(fwnode, child)     \
+       for (struct fwnode_handle *child __free(fwnode_handle) =        \
+               fwnode_get_next_available_child_node(fwnode, NULL);     \
+            child; child = fwnode_get_next_available_child_node(fwnode, child))
+
 struct fwnode_handle *device_get_next_child_node(const struct device *dev,
                                                 struct fwnode_handle *child);