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

Michal Simek michal.simek at xilinx.com
Thu Jan 31 10:14:15 UTC 2019


On 31. 01. 19 11:04, Simon Glass wrote:
> 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?

let's see how this can be done.

M


More information about the U-Boot mailing list