boot: Handle running out of labels
authorSimon Glass <sjg@chromium.org>
Sat, 15 Mar 2025 14:25:59 +0000 (14:25 +0000)
committerTom Rini <trini@konsulko.com>
Thu, 3 Apr 2025 17:43:22 +0000 (11:43 -0600)
If only a single label is provided in the list, bootdev_next_label()
does not operate correctly and reads beyond the end of the pointer list.

Fix this by adding a new check. Also add a note to convert this array
to an alist

Signed-off-by: Simon Glass <sjg@chromium.org>
boot/bootdev-uclass.c
include/bootstd.h

index 9e4c3db..3791ebf 100644 (file)
@@ -579,6 +579,9 @@ int bootdev_next_label(struct bootflow_iter *iter, struct udevice **devp,
        struct udevice *dev;
 
        log_debug("next\n");
+       if (iter->cur_label >= 0 && !iter->labels[iter->cur_label])
+               return log_msg_ret("fil", -ENODEV);
+
        for (dev = NULL; !dev && iter->labels[++iter->cur_label];) {
                const char *label = iter->labels[iter->cur_label];
                int ret;
index 3398e48..2bc4647 100644 (file)
@@ -22,6 +22,9 @@ struct udevice;
  * This is attached to the (only) bootstd device, so there is only one instance
  * of this struct. It provides overall information about bootdevs and bootflows.
  *
+ * TODO(sjg@chromium.org): Convert prefixes, bootdev_order and env_order to use
+ *     alist
+ *
  * @prefixes: NULL-terminated list of prefixes to use for bootflow filenames,
  *     e.g. "/", "/boot/"; NULL if none
  * @bootdev_order: Order to use for bootdevs (or NULL if none), with each item