[U-Boot] [PATCH 2/4] fdt: Introduce fdtdec_get_alias_highest_id()

Simon Glass sjg at chromium.org
Thu Jan 31 10:04:15 UTC 2019


Hi Michal,

On Fri, 18 Jan 2019 at 08:13, Michal Simek <michal.simek at xilinx.com> wrote:
>
> Find out the highest alias ID used for certain subsystem.
> This call will be used for alocating IDs for i2c buses which are not
> described in DT.
>
> Signed-off-by: Michal Simek <michal.simek at xilinx.com>
> ---
>
>  include/fdtdec.h | 13 +++++++++++++
>  lib/fdtdec.c     | 33 +++++++++++++++++++++++++++++++++
>  2 files changed, 46 insertions(+)
>
> diff --git a/include/fdtdec.h b/include/fdtdec.h
> index f1bcbf837ffb..c2dd87ede226 100644
> --- a/include/fdtdec.h
> +++ b/include/fdtdec.h
> @@ -626,6 +626,19 @@ int fdtdec_get_alias_seq(const void *blob, const char *base, int node,
>                          int *seqp);
>
>  /**
> + * Get the highest alias number for susbystem.
> + *
> + * It parses all aliases and find out highest recorded alias for subsystem.
> + * Aliases are of the form <base><num> where <num> is the sequence number.
> + *
> + * @param blob         Device tree blob (if NULL, then error is returned)
> + * @param base         Base name for alias susbystem (before the number)
> + *
> + * @return 0 highest alias ID, -1 if not found
> + */
> +int fdtdec_get_alias_highest_id(const void *blob, const char *base);
> +
> +/**
>   * Get a property from the /chosen node
>   *
>   * @param blob         Device tree blob (if NULL, then NULL is returned)
> diff --git a/lib/fdtdec.c b/lib/fdtdec.c
> index 18663ce6bdac..55811975ef54 100644
> --- a/lib/fdtdec.c
> +++ b/lib/fdtdec.c
> @@ -549,6 +549,39 @@ int fdtdec_get_alias_seq(const void *blob, const char *base, int offset,
>         return -ENOENT;
>  }
>
> +int fdtdec_get_alias_highest_id(const void *blob, const char *base)
> +{
> +       int base_len = strlen(base);
> +       int prop_offset;
> +       int aliases;
> +       int max = -1;
> +
> +       debug("Looking for highest alias id for '%s'\n", base);
> +
> +       aliases = fdt_path_offset(blob, "/aliases");
> +       for (prop_offset = fdt_first_property_offset(blob, aliases);
> +            prop_offset > 0;
> +            prop_offset = fdt_next_property_offset(blob, prop_offset)) {
> +               const char *prop;
> +               const char *name;
> +               int len, val;
> +
> +               prop = fdt_getprop_by_offset(blob, prop_offset, &name, &len);
> +               debug("   - %s, %s\n", name, prop);
> +               if (*prop != '/' || prop[len - 1] ||
> +                   strncmp(name, base, base_len))
> +                       continue;
> +
> +               val = trailing_strtol(name);
> +               if (val > max) {
> +                       debug("Found seq %d\n", val);
> +                       max = val;
> +               }
> +       }
> +
> +       return max;

This looks right to me. Can you please add a test that calls this for
a few sandbox aliases?

> +}
> +
>  const char *fdtdec_get_chosen_prop(const void *blob, const char *name)
>  {
>         int chosen_node;
> --
> 1.9.1
>

Regards,
Simon


On Fri, 18 Jan 2019 at 08:13, Michal Simek <michal.simek at xilinx.com> wrote:
>
> Find out the highest alias ID used for certain subsystem.
> This call will be used for alocating IDs for i2c buses which are not
> described in DT.
>
> Signed-off-by: Michal Simek <michal.simek at xilinx.com>
> ---
>
>  include/fdtdec.h | 13 +++++++++++++
>  lib/fdtdec.c     | 33 +++++++++++++++++++++++++++++++++
>  2 files changed, 46 insertions(+)
>
> diff --git a/include/fdtdec.h b/include/fdtdec.h
> index f1bcbf837ffb..c2dd87ede226 100644
> --- a/include/fdtdec.h
> +++ b/include/fdtdec.h
> @@ -626,6 +626,19 @@ int fdtdec_get_alias_seq(const void *blob, const char *base, int node,
>                          int *seqp);
>
>  /**
> + * Get the highest alias number for susbystem.
> + *
> + * It parses all aliases and find out highest recorded alias for subsystem.
> + * Aliases are of the form <base><num> where <num> is the sequence number.
> + *
> + * @param blob         Device tree blob (if NULL, then error is returned)
> + * @param base         Base name for alias susbystem (before the number)
> + *
> + * @return 0 highest alias ID, -1 if not found
> + */
> +int fdtdec_get_alias_highest_id(const void *blob, const char *base);
> +
> +/**
>   * Get a property from the /chosen node
>   *
>   * @param blob         Device tree blob (if NULL, then NULL is returned)
> diff --git a/lib/fdtdec.c b/lib/fdtdec.c
> index 18663ce6bdac..55811975ef54 100644
> --- a/lib/fdtdec.c
> +++ b/lib/fdtdec.c
> @@ -549,6 +549,39 @@ int fdtdec_get_alias_seq(const void *blob, const char *base, int offset,
>         return -ENOENT;
>  }
>
> +int fdtdec_get_alias_highest_id(const void *blob, const char *base)
> +{
> +       int base_len = strlen(base);
> +       int prop_offset;
> +       int aliases;
> +       int max = -1;
> +
> +       debug("Looking for highest alias id for '%s'\n", base);
> +
> +       aliases = fdt_path_offset(blob, "/aliases");
> +       for (prop_offset = fdt_first_property_offset(blob, aliases);
> +            prop_offset > 0;
> +            prop_offset = fdt_next_property_offset(blob, prop_offset)) {
> +               const char *prop;
> +               const char *name;
> +               int len, val;
> +
> +               prop = fdt_getprop_by_offset(blob, prop_offset, &name, &len);
> +               debug("   - %s, %s\n", name, prop);
> +               if (*prop != '/' || prop[len - 1] ||
> +                   strncmp(name, base, base_len))
> +                       continue;
> +
> +               val = trailing_strtol(name);
> +               if (val > max) {
> +                       debug("Found seq %d\n", val);
> +                       max = val;
> +               }
> +       }
> +
> +       return max;
> +}
> +
>  const char *fdtdec_get_chosen_prop(const void *blob, const char *name)
>  {
>         int chosen_node;
> --
> 1.9.1
>


More information about the U-Boot mailing list