[U-Boot] [PATCH 04/57] dm: syscon: Allow finding devices by driver data

Bin Meng bmeng.cn at gmail.com
Sun Dec 13 13:52:20 CET 2015


Hi Simon,

On Tue, Dec 8, 2015 at 11:38 AM, Simon Glass <sjg at chromium.org> wrote:
> We have a way to find a regmap by its syscon driver data value. Add the same
> for syscon itself.
>
> Signed-off-by: Simon Glass <sjg at chromium.org>
> ---
>
>  drivers/core/syscon-uclass.c | 31 +++++++++++++++++++------------
>  include/syscon.h             | 14 ++++++++++++++
>  test/dm/syscon.c             | 17 +++++++++++++++++
>  3 files changed, 50 insertions(+), 12 deletions(-)
>
> diff --git a/drivers/core/syscon-uclass.c b/drivers/core/syscon-uclass.c
> index 686c320..a0666d0 100644
> --- a/drivers/core/syscon-uclass.c
> +++ b/drivers/core/syscon-uclass.c
> @@ -32,7 +32,7 @@ static int syscon_pre_probe(struct udevice *dev)
>         return regmap_init_mem(dev, &priv->regmap);
>  }
>
> -struct regmap *syscon_get_regmap_by_driver_data(ulong driver_data)
> +int syscon_get_by_driver_data(ulong driver_data, struct udevice **devp)
>  {
>         struct udevice *dev;
>         struct uclass *uc;
> @@ -40,22 +40,29 @@ struct regmap *syscon_get_regmap_by_driver_data(ulong driver_data)
>
>         ret = uclass_get(UCLASS_SYSCON, &uc);
>         if (ret)
> -               return ERR_PTR(ret);
> +               return ret;
>         uclass_foreach_dev(dev, uc) {
>                 if (dev->driver_data == driver_data) {
> -                       struct syscon_uc_info *priv;
> -                       int ret;
> -
> -                       ret = device_probe(dev);
> -                       if (ret)
> -                               return ERR_PTR(ret);
> -                       priv = dev_get_uclass_priv(dev);
> -
> -                       return priv->regmap;
> +                       *devp = dev;
> +                       return device_probe(dev);
>                 }
>         }
>
> -       return ERR_PTR(-ENODEV);
> +       return -ENODEV;
> +}
> +
> +struct regmap *syscon_get_regmap_by_driver_data(ulong driver_data)
> +{
> +       struct syscon_uc_info *priv;
> +       struct udevice *dev;
> +       int ret;
> +
> +       ret = syscon_get_by_driver_data(driver_data, &dev);
> +       if (ret)
> +               return ERR_PTR(ret);
> +       priv = dev_get_uclass_priv(dev);
> +
> +       return priv->regmap;
>  }
>
>  void *syscon_get_first_range(ulong driver_data)
> diff --git a/include/syscon.h b/include/syscon.h
> index c62ccd6..4e96fcc 100644
> --- a/include/syscon.h
> +++ b/include/syscon.h
> @@ -37,6 +37,20 @@ struct regmap *syscon_get_regmap(struct udevice *dev);
>   *
>   * Each system controller can be accessed by its driver data, which is
>   * assumed to be unique through the scope of all system controllers that
> + * are in use. This function looks up the controller this driver data.

Missing 'given' before 'this driver data'?

> + *
> + * @driver_data:       Driver data value to look up
> + * @devp:              Returns the controller correponding to @driver_data
> + * @return 0 on success, -ENODEV if the ID was not found, or other -ve error
> + *        code
> + */
> +int syscon_get_by_driver_data(ulong driver_data, struct udevice **devp);
> +
> +/**
> + * syscon_get_regmap_by_driver_data() - Look up a controller by its ID
> + *
> + * Each system controller can be accessed by its driver data, which is
> + * assumed to be unique through the scope of all system controllers that
>   * are in use. This function looks up the regmap given this driver data.
>   *
>   * @driver_data:       Driver data value to look up
> diff --git a/test/dm/syscon.c b/test/dm/syscon.c
> index 3642481..c40f5fc 100644
> --- a/test/dm/syscon.c
> +++ b/test/dm/syscon.c
> @@ -29,3 +29,20 @@ static int dm_test_syscon_base(struct unit_test_state *uts)
>         return 0;
>  }
>  DM_TEST(dm_test_syscon_base, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
> +
> +/* Test system controller finding */
> +static int dm_test_syscon_by_driver_data(struct unit_test_state *uts)
> +{
> +       struct udevice *dev;
> +
> +       ut_assertok(syscon_get_by_driver_data(SYSCON0, &dev));
> +       ut_asserteq(SYSCON0, dev->driver_data);
> +
> +       ut_assertok(syscon_get_by_driver_data(SYSCON1, &dev));
> +       ut_asserteq(SYSCON1, dev->driver_data);
> +
> +       ut_asserteq(-ENODEV, syscon_get_by_driver_data(2, &dev));
> +
> +       return 0;
> +}
> +DM_TEST(dm_test_syscon_by_driver_data, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
> --

Regards,
Bin


More information about the U-Boot mailing list