[PATCH] sysinfo: gpio: fix loop over DT "revisions" array
Sean Anderson
sean.anderson at seco.com
Mon Mar 13 16:23:02 CET 2023
On 3/10/23 05:58, Rasmus Villemoes wrote:
> There can certainly be a lot more elements in the "revisions" (and
> "names") arrays than there are gpios used to form the trinary number
> we're searching for; we simply don't know the array size up-front.
>
> Nor do we need to, because the loop body already knows to recognize
> -EOVERFLOW as "not that many elements present" (and we have a test
> that specifically ensures that dev_read_u32_index() returns exactly
> that). So just drop the i < priv->gpio_num condition.
>
> While in here, fix the weird placement of the default: keyword.
>
> Signed-off-by: Rasmus Villemoes <rasmus.villemoes at prevas.dk>
> ---
> drivers/sysinfo/gpio.c | 5 +++--
> 1 file changed, 3 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/sysinfo/gpio.c b/drivers/sysinfo/gpio.c
> index 1d7f050998..82f90303bb 100644
> --- a/drivers/sysinfo/gpio.c
> +++ b/drivers/sysinfo/gpio.c
> @@ -57,7 +57,7 @@ static int sysinfo_gpio_get_str(struct udevice *dev, int id, size_t size, char *
> int i, ret;
> u32 revision;
>
> - for (i = 0; i < priv->gpio_num; i++) {
> + for (i = 0; ; i++) {
> ret = dev_read_u32_index(dev, "revisions", i,
> &revision);
> if (ret) {
> @@ -80,7 +80,8 @@ static int sysinfo_gpio_get_str(struct udevice *dev, int id, size_t size, char *
> strncpy(val, name, size);
> val[size - 1] = '\0';
> return 0;
> - } default:
> + }
> + default:
> return -EINVAL;
> };
> }
Reviewed-by: Sean Anderson <sean.anderson at seco.com>
More information about the U-Boot
mailing list