[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250924074602.266292-1-sakari.ailus@linux.intel.com>
Date: Wed, 24 Sep 2025 10:45:46 +0300
From: Sakari Ailus <sakari.ailus@...ux.intel.com>
To: linux-acpi@...r.kernel.org
Cc: linux-kernel@...r.kernel.org,
linux-input@...r.kernel.org,
linux-leds@...r.kernel.org,
linux-media@...r.kernel.org,
netdev@...r.kernel.org,
linux-spi@...r.kernel.org,
"Rafael J. Wysocki" <rafael@...nel.org>,
Len Brown <lenb@...nel.org>,
Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
Danilo Krummrich <dakr@...nel.org>,
Andy Shevchenko <andriy.shevchenko@...ux.intel.com>,
Daniel Scally <djrscally@...il.com>,
Heikki Krogerus <heikki.krogerus@...ux.intel.com>,
Javier Carrasco <javier.carrasco@...fvision.net>,
Dmitry Torokhov <dmitry.torokhov@...il.com>,
Lee Jones <lee@...nel.org>,
Pavel Machek <pavel@...nel.org>,
Matthias Fend <matthias.fend@...end.at>,
Chanwoo Choi <cw00.choi@...sung.com>,
Krzysztof Kozlowski <krzk@...nel.org>,
Laurent Pinchart <laurent.pinchart@...asonboard.com>,
Paul Elder <paul.elder@...asonboard.com>,
Mauro Carvalho Chehab <mchehab@...nel.org>,
Horatiu Vultur <horatiu.vultur@...rochip.com>,
UNGLinuxDriver@...rochip.com,
Andrew Lunn <andrew+netdev@...n.ch>,
"David S. Miller" <davem@...emloft.net>,
Eric Dumazet <edumazet@...gle.com>,
Jakub Kicinski <kuba@...nel.org>,
Paolo Abeni <pabeni@...hat.com>,
Mark Brown <broonie@...nel.org>,
Thomas Gleixner <tglx@...utronix.de>,
Ingo Molnar <mingo@...nel.org>,
Jonathan Cameron <Jonathan.Cameron@...wei.com>
Subject: [PATCH v2 00/16] Align availability checks on fwnode child node enumeration
Hello everyone,
Historically the fwnode property API has enumerated only available device
nodes on OF whereas on ACPI, also nodes that haven't been present in the
system have been provided. Both OF and ACPI have similar concepts of node
availbility, on OF it's the "status" property present on device nodes and
on ACPI the _STA object evaluates to device present, enabled and
functional bits, of which the present and functional bits are currently
being used to determine whether to enumerate a device.
Two additional functions, fwnode_get_next_available_child_node() and
fwnode_for_each_available_child_node(), have been provided to enumerate
the available nodes only on ACPI, whereas on OF the implementation has
been the same on the non-available variants. The motivation for providing
these has very likely been to provide fwnode variants of the similarly
named functions but the difference isn't justifiable from API consistency
viewpoint.
This set switches the users away from the "available" fwnode API functions
and later on removes them, aligning the functionality on all fwnode
backends.
since v1:
- Move patch "ACPI: property: Make acpi_get_next_subnode() static" as
first.
- Add missing parentheses and kernel-doc Return: section in
acpi_get_next_present_subnode() documentation and move the Return
section: of fwnode_graph_get_endpoint_by_id() to the end of the
documentation section (new patch for the latter).
- Use device_get_next_child_node() instead of fwnode_get_next_child_node()
in flash LED driver drivers.
- Rework iterating port nodes in acpi_graph_get_next_endpoint() as
suggested by Andy (new patch).
Sakari Ailus (16):
ACPI: property: Make acpi_get_next_subnode() static
ACPI: property: Use ACPI functions in acpi_graph_get_next_endpoint()
only
ACPI: property: Rework acpi_graph_get_next_endpoint()
ACPI: property: Return present device nodes only on fwnode interface
property: Move Return: section of fwnode_graph_get_endpoint_by_id()
down
property: Drop DEVICE_DISABLED flag in
fwnode_graph_get_endpoint_by_id()
property: Drop DEVICE_DISABLED flag in
fwnode_graph_get_endpoint_count()
property: Document that fwnode API returns available nodes
driver core: Use fwnode_for_each_child_node() instead
net: lan966x: Use fwnode_for_each_child_node() instead
Input: touch-overlay - Use fwnode_for_each_child_node() instead
media: thp7312: Use fwnode_for_each_child_node() instead
leds: Use fwnode_for_each_child_node() instead
leds: Use fwnode_get_next_child_node() instead
property: Drop functions operating on "available" child nodes
spi: cadence: Remove explicit device node availability check
drivers/acpi/property.c | 42 +++++++++----
drivers/base/core.c | 10 ++--
drivers/base/property.c | 60 ++++---------------
drivers/input/touch-overlay.c | 2 +-
drivers/leds/flash/leds-rt4505.c | 2 +-
drivers/leds/flash/leds-rt8515.c | 2 +-
drivers/leds/flash/leds-sgm3140.c | 3 +-
drivers/leds/flash/leds-tps6131x.c | 2 +-
drivers/leds/leds-max5970.c | 2 +-
drivers/leds/leds-max77705.c | 2 +-
drivers/leds/rgb/leds-ktd202x.c | 4 +-
drivers/leds/rgb/leds-ncp5623.c | 2 +-
drivers/media/i2c/thp7312.c | 2 +-
.../ethernet/microchip/lan966x/lan966x_main.c | 2 +-
drivers/spi/spi-cadence-xspi.c | 3 -
include/linux/acpi.h | 10 ----
include/linux/property.h | 14 +----
17 files changed, 61 insertions(+), 103 deletions(-)
--
2.47.3
Powered by blists - more mailing lists