[U-Boot] [PATCH] sysreset: syscon: update regmap access to syscon

Simon Glass sjg at chromium.org
Tue Jul 10 20:49:38 UTC 2018


Hi Patrick,

On 9 July 2018 at 06:59, Patrick Delaunay <patrick.delaunay at st.com> wrote:
> Use new API syscon_node_to_regmap in sysreset_syscon driver
> for compatible "syscon-reboot"; that's avoid the need of explicit
> syscon binding for "regmap" handle.
>
> Signed-off-by: Patrick Delaunay <patrick.delaunay at st.com>
> ---
>
>  drivers/sysreset/sysreset_syscon.c | 16 +++++++++-------
>  1 file changed, 9 insertions(+), 7 deletions(-)
>
> diff --git a/drivers/sysreset/sysreset_syscon.c b/drivers/sysreset/sysreset_syscon.c
> index f19e80e..3450640 100644
> --- a/drivers/sysreset/sysreset_syscon.c
> +++ b/drivers/sysreset/sysreset_syscon.c
> @@ -35,18 +35,20 @@ static struct sysreset_ops syscon_reboot_ops = {
>
>  int syscon_reboot_probe(struct udevice *dev)
>  {
> -       struct udevice *syscon;
>         struct syscon_reboot_priv *priv = dev_get_priv(dev);
>         int err;
> +       u32 phandle;
> +       ofnode node;
>
> -       err = uclass_get_device_by_phandle(UCLASS_SYSCON, dev,
> -                                          "regmap", &syscon);
> -       if (err) {
> -               pr_err("unable to find syscon device\n");
> +       err = ofnode_read_u32(dev_ofnode(dev), "regmap", &phandle);
> +       if (err)
>                 return err;
> -       }
>
> -       priv->regmap = syscon_get_regmap(syscon);
> +       node = ofnode_get_by_phandle(phandle);
> +       if (!ofnode_valid(node))
> +               return -EINVAL;
> +
> +       priv->regmap = syscon_node_to_regmap(node);
>         if (!priv->regmap) {
>                 pr_err("unable to find regmap\n");
>                 return -ENODEV;

Aren't you just re-implementing uclass_get_device_by_phandle() here?

Regards,
Simon


More information about the U-Boot mailing list