[PATCH v1 3/3] pinctrl: pinconf-generic: Convert ..._parse_dt_pinmux() to fwnode API

From: Andy Shevchenko

Date: Tue Mar 17 2026 - 06:48:11 EST


Convert pinconf_generic_parse_dt_pinmux() to fwnode API. This makes code
cleaner and potentially reusable for some other types of fwnodes, such as
software nodes.

Signed-off-by: Andy Shevchenko <andriy.shevchenko@xxxxxxxxxxxxxxx>
---
drivers/pinctrl/pinconf-generic.c | 27 ++++++++++++++-------------
1 file changed, 14 insertions(+), 13 deletions(-)

diff --git a/drivers/pinctrl/pinconf-generic.c b/drivers/pinctrl/pinconf-generic.c
index 0ed57720ae61..88eacd1aa2de 100644
--- a/drivers/pinctrl/pinconf-generic.c
+++ b/drivers/pinctrl/pinconf-generic.c
@@ -312,20 +312,19 @@ int pinconf_generic_parse_dt_pinmux(struct device_node *np, struct device *dev,
unsigned int **pid, unsigned int **pmux,
unsigned int *npins)
{
+ struct fwnode_handle *fwnode = of_fwnode_handle(np);
unsigned int *pid_t;
unsigned int *pmux_t;
- struct property *prop;
unsigned int npins_t, i;
- u32 value;
int ret;

- prop = of_find_property(np, "pinmux", NULL);
- if (!prop) {
+ ret = fwnode_property_count_u32(fwnode, "pinmux");
+ if (ret < 0) {
dev_info(dev, "Missing pinmux property\n");
- return -ENOENT;
+ return ret;
}

- npins_t = prop->length / sizeof(u32);
+ npins_t = ret;
if (npins_t == 0) {
dev_info(dev, "pinmux property doesn't have entries\n");
return -ENODATA;
@@ -342,14 +341,16 @@ int pinconf_generic_parse_dt_pinmux(struct device_node *np, struct device *dev,
dev_err(dev, "kalloc memory fail\n");
return -ENOMEM;
}
+
+ ret = fwnode_property_read_u32_array(fwnode, "pinmux", pmux_t, npins_t);
+ if (ret) {
+ dev_err(dev, "get pinmux value fail\n");
+ goto exit;
+ }
+
for (i = 0; i < npins_t; i++) {
- ret = of_property_read_u32_index(np, "pinmux", i, &value);
- if (ret) {
- dev_err(dev, "get pinmux value fail\n");
- goto exit;
- }
- pmux_t[i] = value & 0xff;
- pid_t[i] = (value >> 8) & 0xffffff;
+ pid_t[i] = pmux_t[i] >> 8;
+ pmux_t[i] = pmux_t[i] & 0xff;
}
*pid = pid_t;
*pmux = pmux_t;
--
2.50.1