]> git.ipfire.org Git - thirdparty/u-boot.git/commitdiff
bootstd: Move bootflow-adding to bootstd
authorSimon Glass <sjg@chromium.org>
Fri, 15 Nov 2024 23:19:08 +0000 (16:19 -0700)
committerTom Rini <trini@konsulko.com>
Wed, 15 Jan 2025 14:48:42 +0000 (08:48 -0600)
This relates to more than just the bootdev, since there is a global list
of bootflows. Move the function to the bootstd file and rename it.

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

index 64ec4fde493f4cfaa12d610beaf1ebdba644242e..eddbf60600c3a243cdacaf2de7fc73f16ab9d736 100644 (file)
@@ -32,31 +32,6 @@ enum {
        BOOT_TARGETS_MAX_LEN    = 100,
 };
 
-int bootdev_add_bootflow(struct bootflow *bflow)
-{
-       struct bootstd_priv *std;
-       struct bootflow *new;
-       int ret;
-
-       ret = bootstd_get_priv(&std);
-       if (ret)
-               return ret;
-
-       new = malloc(sizeof(*bflow));
-       if (!new)
-               return log_msg_ret("bflow", -ENOMEM);
-       memcpy(new, bflow, sizeof(*bflow));
-
-       list_add_tail(&new->glob_node, &std->glob_head);
-       if (bflow->dev) {
-               struct bootdev_uc_plat *ucp = dev_get_uclass_plat(bflow->dev);
-
-               list_add_tail(&new->bm_node, &ucp->bootflow_head);
-       }
-
-       return 0;
-}
-
 int bootdev_first_bootflow(struct udevice *dev, struct bootflow **bflowp)
 {
        struct bootdev_uc_plat *ucp = dev_get_uclass_plat(dev);
index fdb8d69e3209a3980670d5547eb4871c3266aa68..bf6e49ad97a9401e8b23d2d35960859f652639aa 100644 (file)
@@ -61,6 +61,31 @@ void bootstd_clear_glob(void)
        bootstd_clear_glob_(std);
 }
 
+int bootstd_add_bootflow(struct bootflow *bflow)
+{
+       struct bootstd_priv *std;
+       struct bootflow *new;
+       int ret;
+
+       ret = bootstd_get_priv(&std);
+       if (ret)
+               return ret;
+
+       new = malloc(sizeof(*bflow));
+       if (!new)
+               return log_msg_ret("bflow", -ENOMEM);
+       memcpy(new, bflow, sizeof(*bflow));
+
+       list_add_tail(&new->glob_node, &std->glob_head);
+       if (bflow->dev) {
+               struct bootdev_uc_plat *ucp = dev_get_uclass_plat(bflow->dev);
+
+               list_add_tail(&new->bm_node, &ucp->bootflow_head);
+       }
+
+       return 0;
+}
+
 static int bootstd_remove(struct udevice *dev)
 {
        struct bootstd_priv *priv = dev_get_priv(dev);
index f67948d73688a4fb0d3a2a30a2ca2b4c665e04bd..8962464bbf8e970987d58bfcb74746e9da6fc782 100644 (file)
@@ -207,7 +207,7 @@ static int do_bootflow_scan(struct cmd_tbl *cmdtp, int flag, int argc,
                bflow.err = ret;
                if (!ret)
                        num_valid++;
-               ret = bootdev_add_bootflow(&bflow);
+               ret = bootstd_add_bootflow(&bflow);
                if (ret) {
                        printf("Out of memory\n");
                        return CMD_RET_FAILURE;
index ad4af0d13101d28028288c167109bdfd9a41e936..8db198dd56b8ee3e0bf5e4bab61972584f0f4b9e 100644 (file)
@@ -195,21 +195,6 @@ void bootdev_list(bool probe);
  */
 void bootdev_clear_bootflows(struct udevice *dev);
 
-/**
- * bootdev_add_bootflow() - Add a bootflow to the bootdev's list
- *
- * All fields in @bflow must be set up. Note that @bflow->dev is used to add the
- * bootflow to that device.
- *
- * @dev: Bootdev device to add to
- * @bflow: Bootflow to add. Note that fields within bflow must be allocated
- *     since this function takes over ownership of these. This functions makes
- *     a copy of @bflow itself (without allocating its fields again), so the
- *     caller must dispose of the memory used by the @bflow pointer itself
- * Return: 0 if OK, -ENOMEM if out of memory
- */
-int bootdev_add_bootflow(struct bootflow *bflow);
-
 /**
  * bootdev_first_bootflow() - Get the first bootflow from a bootdev
  *
index ac756e98d84a892de26eb27b50dba61c4c65488c..3fc93a4ec2e83124ad9093b2c5ec3510f14ea84c 100644 (file)
@@ -105,4 +105,21 @@ void bootstd_clear_glob(void);
  */
 int bootstd_prog_boot(void);
 
+/**
+ * bootstd_add_bootflow() - Add a bootflow to the bootdev's and global list
+ *
+ * All fields in @bflow must be set up. Note that @bflow->dev is used to add the
+ * bootflow to that device.
+ *
+ * The bootflow is also added to the global list of all bootflows
+ *
+ * @dev: Bootdev device to add to
+ * @bflow: Bootflow to add. Note that fields within bflow must be allocated
+ *     since this function takes over ownership of these. This functions makes
+ *     a copy of @bflow itself (without allocating its fields again), so the
+ *     caller must dispose of the memory used by the @bflow pointer itself
+ * Return: 0 if OK, -ENOMEM if out of memory
+ */
+int bootstd_add_bootflow(struct bootflow *bflow);
+
 #endif