Message ID | 20241023202855.1571188-2-tharvey@gateworks.com |
---|---|
State | Accepted |
Commit | d279f5d3a8ddff5db38d321d892f876350a8bf24 |
Delegated to: | Fabio Estevam |
Headers | show |
Series | [1/4] pinctrl: imx: Convert to use livetree API for fdt access | expand |
> -----Original Message----- > From: Tim Harvey <tharvey@gateworks.com> > Sent: Thursday, October 24, 2024 5:29 AM > To: Heiko Schocher <hs@denx.de>; Tom Rini <trini@konsulko.com>; Peng Fan <peng.fan@nxp.com>; Jaehoon > Chung <jh80.chung@samsung.com>; u-boot@lists.denx.de > Cc: linux-kernel@vger.kernel.org; Tim Harvey <tharvey@gateworks.com> > Subject: [PATCH 2/4] imx: power-domain: Convert to use livetree API for fdt access > > Convert to using livetree API functions. > > Without this if livetree is enabled (OF_LIVE) the imx8m-power-domain > driver will (silently) fail to probe its children leaving you with > no power domain support causing issues with certain devices. > > Signed-off-by: Tim Harvey <tharvey@gateworks.com> Reviewed-by: Jaehoon Chung <jh80.chung@samsung.com> Best Regards, Jaehoon Chung > --- > drivers/power/domain/imx8m-power-domain.c | 18 +++++++----------- > 1 file changed, 7 insertions(+), 11 deletions(-) > > diff --git a/drivers/power/domain/imx8m-power-domain.c b/drivers/power/domain/imx8m-power-domain.c > index 8b6870c86463..c22fbe60675e 100644 > --- a/drivers/power/domain/imx8m-power-domain.c > +++ b/drivers/power/domain/imx8m-power-domain.c > @@ -456,25 +456,22 @@ static int imx8m_power_domain_of_xlate(struct power_domain *power_domain, > > static int imx8m_power_domain_bind(struct udevice *dev) > { > - int offset; > + ofnode subnode; > const char *name; > int ret = 0; > > - offset = dev_of_offset(dev); > - for (offset = fdt_first_subnode(gd->fdt_blob, offset); offset > 0; > - offset = fdt_next_subnode(gd->fdt_blob, offset)) { > + ofnode_for_each_subnode(subnode, dev_ofnode(dev)) { > /* Bind the subnode to this driver */ > - name = fdt_get_name(gd->fdt_blob, offset, NULL); > + name = ofnode_get_name(subnode); > > /* Descend into 'pgc' subnode */ > if (!strstr(name, "power-domain")) { > - offset = fdt_first_subnode(gd->fdt_blob, offset); > - name = fdt_get_name(gd->fdt_blob, offset, NULL); > + subnode = ofnode_first_subnode(subnode); > + name = ofnode_get_name(subnode); > } > - > ret = device_bind_with_driver_data(dev, dev->driver, name, > dev->driver_data, > - offset_to_ofnode(offset), > + subnode, > NULL); > > if (ret == -ENODEV) > @@ -514,8 +511,7 @@ static int imx8m_power_domain_of_to_plat(struct udevice *dev) > struct imx_pgc_domain_data *domain_data = > (struct imx_pgc_domain_data *)dev_get_driver_data(dev); > > - pdata->resource_id = fdtdec_get_int(gd->fdt_blob, dev_of_offset(dev), > - "reg", -1); > + pdata->resource_id = ofnode_read_u32_default(dev_ofnode(dev), "reg", -1); > pdata->domain = &domain_data->domains[pdata->resource_id]; > pdata->regs = domain_data->pgc_regs; > pdata->base = dev_read_addr_ptr(dev->parent); > -- > 2.25.1 >
diff --git a/drivers/power/domain/imx8m-power-domain.c b/drivers/power/domain/imx8m-power-domain.c index 8b6870c86463..c22fbe60675e 100644 --- a/drivers/power/domain/imx8m-power-domain.c +++ b/drivers/power/domain/imx8m-power-domain.c @@ -456,25 +456,22 @@ static int imx8m_power_domain_of_xlate(struct power_domain *power_domain, static int imx8m_power_domain_bind(struct udevice *dev) { - int offset; + ofnode subnode; const char *name; int ret = 0; - offset = dev_of_offset(dev); - for (offset = fdt_first_subnode(gd->fdt_blob, offset); offset > 0; - offset = fdt_next_subnode(gd->fdt_blob, offset)) { + ofnode_for_each_subnode(subnode, dev_ofnode(dev)) { /* Bind the subnode to this driver */ - name = fdt_get_name(gd->fdt_blob, offset, NULL); + name = ofnode_get_name(subnode); /* Descend into 'pgc' subnode */ if (!strstr(name, "power-domain")) { - offset = fdt_first_subnode(gd->fdt_blob, offset); - name = fdt_get_name(gd->fdt_blob, offset, NULL); + subnode = ofnode_first_subnode(subnode); + name = ofnode_get_name(subnode); } - ret = device_bind_with_driver_data(dev, dev->driver, name, dev->driver_data, - offset_to_ofnode(offset), + subnode, NULL); if (ret == -ENODEV) @@ -514,8 +511,7 @@ static int imx8m_power_domain_of_to_plat(struct udevice *dev) struct imx_pgc_domain_data *domain_data = (struct imx_pgc_domain_data *)dev_get_driver_data(dev); - pdata->resource_id = fdtdec_get_int(gd->fdt_blob, dev_of_offset(dev), - "reg", -1); + pdata->resource_id = ofnode_read_u32_default(dev_ofnode(dev), "reg", -1); pdata->domain = &domain_data->domains[pdata->resource_id]; pdata->regs = domain_data->pgc_regs; pdata->base = dev_read_addr_ptr(dev->parent);
Convert to using livetree API functions. Without this if livetree is enabled (OF_LIVE) the imx8m-power-domain driver will (silently) fail to probe its children leaving you with no power domain support causing issues with certain devices. Signed-off-by: Tim Harvey <tharvey@gateworks.com> --- drivers/power/domain/imx8m-power-domain.c | 18 +++++++----------- 1 file changed, 7 insertions(+), 11 deletions(-)