]> git.baikalelectronics.ru Git - uboot.git/commitdiff
sysinfo: gpio: fix loop over DT "revisions" array
authorRasmus Villemoes <rasmus.villemoes@prevas.dk>
Fri, 10 Mar 2023 10:58:03 +0000 (11:58 +0100)
committerTom Rini <trini@konsulko.com>
Thu, 30 Mar 2023 19:09:59 +0000 (15:09 -0400)
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@prevas.dk>
Reviewed-by: Simon Glass <sjg@chromium.org>
Reviewed-by: Sean Anderson <sean.anderson@seco.com>
drivers/sysinfo/gpio.c

index 1d7f050998afa589f0db4f855202a16311927f63..82f90303bb7094a57ccd88f3b49ae02bc8b2c47f 100644 (file)
@@ -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;
        };
 }