* [PATCH] device property: Add scoped fwnode child node iterators
@ 2025-08-29 2:17 Jean-François Lessard
2025-08-29 4:23 ` Greg Kroah-Hartman
0 siblings, 1 reply; 5+ messages in thread
From: Jean-François Lessard @ 2025-08-29 2:17 UTC (permalink / raw)
To: Greg Kroah-Hartman, Rafael J. Wysocki, Danilo Krummrich,
Andy Shevchenko, Daniel Scally, Heikki Krogerus, Sakari Ailus
Cc: linux-acpi, linux-kernel
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_named_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>
---
Notes:
checkpatch reports false positives that are intentionally ignored:
COMPLEX_MACRO, MACRO_ARG_REUSE, MACRO_ARG_PRECEDENCE
This is a standard iterator pattern following kernel conventions.
include/linux/property.h | 14 ++++++++++++++
1 file changed, 14 insertions(+)
diff --git a/include/linux/property.h b/include/linux/property.h
index 82f0cb3ab..279c244db 100644
--- a/include/linux/property.h
+++ b/include/linux/property.h
@@ -176,6 +176,20 @@ 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_named_child_node_scoped(fwnode, child, name) \
+ fwnode_for_each_child_node_scoped(fwnode, child) \
+ for_each_if(fwnode_name_eq(child, name))
+
+#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);
--
2.43.0
^ permalink raw reply related [flat|nested] 5+ messages in thread* Re: [PATCH] device property: Add scoped fwnode child node iterators 2025-08-29 2:17 [PATCH] device property: Add scoped fwnode child node iterators Jean-François Lessard @ 2025-08-29 4:23 ` Greg Kroah-Hartman 2025-08-29 11:34 ` Jean-François Lessard 0 siblings, 1 reply; 5+ messages in thread From: Greg Kroah-Hartman @ 2025-08-29 4:23 UTC (permalink / raw) To: Jean-François Lessard Cc: Rafael J. Wysocki, Danilo Krummrich, Andy Shevchenko, Daniel Scally, Heikki Krogerus, Sakari Ailus, linux-acpi, linux-kernel On Thu, Aug 28, 2025 at 10:17:59PM -0400, Jean-François Lessard wrote: > 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_named_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> > --- > > Notes: > checkpatch reports false positives that are intentionally ignored: > COMPLEX_MACRO, MACRO_ARG_REUSE, MACRO_ARG_PRECEDENCE > This is a standard iterator pattern following kernel conventions. > > include/linux/property.h | 14 ++++++++++++++ > 1 file changed, 14 insertions(+) > > diff --git a/include/linux/property.h b/include/linux/property.h > index 82f0cb3ab..279c244db 100644 > --- a/include/linux/property.h > +++ b/include/linux/property.h > @@ -176,6 +176,20 @@ 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_named_child_node_scoped(fwnode, child, name) \ > + fwnode_for_each_child_node_scoped(fwnode, child) \ > + for_each_if(fwnode_name_eq(child, name)) > + > +#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); > We need a real user of this before we can add them, so please do that as part of a patch series. thanks greg k-h ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] device property: Add scoped fwnode child node iterators 2025-08-29 4:23 ` Greg Kroah-Hartman @ 2025-08-29 11:34 ` Jean-François Lessard 2025-08-29 11:39 ` Greg Kroah-Hartman 2025-09-01 6:11 ` Andy Shevchenko 0 siblings, 2 replies; 5+ messages in thread From: Jean-François Lessard @ 2025-08-29 11:34 UTC (permalink / raw) To: Greg Kroah-Hartman Cc: Rafael J. Wysocki, Danilo Krummrich, Andy Shevchenko, Daniel Scally, Heikki Krogerus, Sakari Ailus, linux-acpi, linux-kernel Le 29 août 2025 00 h 23 min 22 s HAE, Greg Kroah-Hartman <gregkh@linuxfoundation.org> a écrit : >On Thu, Aug 28, 2025 at 10:17:59PM -0400, Jean-François Lessard wrote: >> 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_named_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> >> --- >> >> Notes: >> checkpatch reports false positives that are intentionally ignored: >> COMPLEX_MACRO, MACRO_ARG_REUSE, MACRO_ARG_PRECEDENCE >> This is a standard iterator pattern following kernel conventions. >> >> include/linux/property.h | 14 ++++++++++++++ >> 1 file changed, 14 insertions(+) >> >> diff --git a/include/linux/property.h b/include/linux/property.h >> index 82f0cb3ab..279c244db 100644 >> --- a/include/linux/property.h >> +++ b/include/linux/property.h >> @@ -176,6 +176,20 @@ 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_named_child_node_scoped(fwnode, child, name) \ >> + fwnode_for_each_child_node_scoped(fwnode, child) \ >> + for_each_if(fwnode_name_eq(child, name)) >> + >> +#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); >> > >We need a real user of this before we can add them, so please do that as >part of a patch series. > I understand the "no dead code" policy, but I found existing manual implementations of this exact pattern in the current kernel. For example, drivers/i2c/i2c-core-slave.c already does: struct fwnode_handle *child __free(fwnode_handle) = NULL; ... fwnode_for_each_child_node(fwnode, child) { ... } This suggests developers are already wanting this functionality but implementing it manually. If included with my driver series, I would only add the fwnode_for_each_available_child_node_scoped() variant that I actually use, avoiding any dead code. Best Regards Jean-François Lessard ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] device property: Add scoped fwnode child node iterators 2025-08-29 11:34 ` Jean-François Lessard @ 2025-08-29 11:39 ` Greg Kroah-Hartman 2025-09-01 6:11 ` Andy Shevchenko 1 sibling, 0 replies; 5+ messages in thread From: Greg Kroah-Hartman @ 2025-08-29 11:39 UTC (permalink / raw) To: Jean-François Lessard Cc: Rafael J. Wysocki, Danilo Krummrich, Andy Shevchenko, Daniel Scally, Heikki Krogerus, Sakari Ailus, linux-acpi, linux-kernel On Fri, Aug 29, 2025 at 07:34:17AM -0400, Jean-François Lessard wrote: > Le 29 août 2025 00 h 23 min 22 s HAE, Greg Kroah-Hartman <gregkh@linuxfoundation.org> a écrit : > >On Thu, Aug 28, 2025 at 10:17:59PM -0400, Jean-François Lessard wrote: > >> 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_named_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> > >> --- > >> > >> Notes: > >> checkpatch reports false positives that are intentionally ignored: > >> COMPLEX_MACRO, MACRO_ARG_REUSE, MACRO_ARG_PRECEDENCE > >> This is a standard iterator pattern following kernel conventions. > >> > >> include/linux/property.h | 14 ++++++++++++++ > >> 1 file changed, 14 insertions(+) > >> > >> diff --git a/include/linux/property.h b/include/linux/property.h > >> index 82f0cb3ab..279c244db 100644 > >> --- a/include/linux/property.h > >> +++ b/include/linux/property.h > >> @@ -176,6 +176,20 @@ 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_named_child_node_scoped(fwnode, child, name) \ > >> + fwnode_for_each_child_node_scoped(fwnode, child) \ > >> + for_each_if(fwnode_name_eq(child, name)) > >> + > >> +#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); > >> > > > >We need a real user of this before we can add them, so please do that as > >part of a patch series. > > > > I understand the "no dead code" policy, but I found existing manual > implementations of this exact pattern in the current kernel. > > For example, drivers/i2c/i2c-core-slave.c already does: > > struct fwnode_handle *child __free(fwnode_handle) = NULL; > ... > fwnode_for_each_child_node(fwnode, child) { > ... > } > > This suggests developers are already wanting this functionality but > implementing it manually. Great, then add it here and fix up drivers/i2c/i2c-core-slave.c to use it! thanks, greg k-h ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] device property: Add scoped fwnode child node iterators 2025-08-29 11:34 ` Jean-François Lessard 2025-08-29 11:39 ` Greg Kroah-Hartman @ 2025-09-01 6:11 ` Andy Shevchenko 1 sibling, 0 replies; 5+ messages in thread From: Andy Shevchenko @ 2025-09-01 6:11 UTC (permalink / raw) To: Jean-François Lessard Cc: Greg Kroah-Hartman, Rafael J. Wysocki, Danilo Krummrich, Daniel Scally, Heikki Krogerus, Sakari Ailus, linux-acpi, linux-kernel On Fri, Aug 29, 2025 at 07:34:17AM -0400, Jean-François Lessard wrote: > Le 29 août 2025 00 h 23 min 22 s HAE, Greg Kroah-Hartman <gregkh@linuxfoundation.org> a écrit : > >On Thu, Aug 28, 2025 at 10:17:59PM -0400, Jean-François Lessard wrote: ... > >We need a real user of this before we can add them, so please do that as > >part of a patch series. > > > > I understand the "no dead code" policy, but I found existing manual > implementations of this exact pattern in the current kernel. > > For example, drivers/i2c/i2c-core-slave.c already does: > > struct fwnode_handle *child __free(fwnode_handle) = NULL; > ... > fwnode_for_each_child_node(fwnode, child) { > ... > } > > This suggests developers are already wanting this functionality but > implementing it manually. > > If included with my driver series, I would only add the > fwnode_for_each_available_child_node_scoped() variant that I actually use, I fully agree with Greg, please make it series out of two, I will review both as soon as it appears in my mailbox. -- With Best Regards, Andy Shevchenko ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2025-09-01 6:11 UTC | newest] Thread overview: 5+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2025-08-29 2:17 [PATCH] device property: Add scoped fwnode child node iterators Jean-François Lessard 2025-08-29 4:23 ` Greg Kroah-Hartman 2025-08-29 11:34 ` Jean-François Lessard 2025-08-29 11:39 ` Greg Kroah-Hartman 2025-09-01 6:11 ` Andy Shevchenko
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox