]> git.ipfire.org Git - thirdparty/u-boot.git/commitdiff
fw_loader: Prefix the FW loader variables with the script prefix
authorMarek Vasut <marek.vasut+renesas@mailbox.org>
Mon, 22 Sep 2025 11:48:28 +0000 (13:48 +0200)
committerTom Rini <trini@konsulko.com>
Thu, 9 Oct 2025 19:50:40 +0000 (13:50 -0600)
Add the script name as a prefix to fw_addr and fw_size variables
to make sure they are always unique and won't easily conflict with
user variables.

Signed-off-by: Marek Vasut <marek.vasut+renesas@mailbox.org>
lib/fw_loader.c

index 207f5fadd1ee841f34470b2fcd14cb16187e290f..f776e09523a8bb514e05a38f3e20d6ef8930e844 100644 (file)
@@ -13,6 +13,8 @@ int request_firmware_into_buf_via_script(void *buf, size_t max_size,
                                         const char *script_name,
                                         size_t *retsize)
 {
+       char env_addr[CONFIG_SYS_CBSIZE] = { 0 };
+       char env_size[CONFIG_SYS_CBSIZE] = { 0 };
        char *args[2] = { "run", (char *)script_name };
        int ret, repeatable;
        ulong addr, size;
@@ -28,13 +30,17 @@ int request_firmware_into_buf_via_script(void *buf, size_t max_size,
                return -EINVAL;
        }
 
+       /* Prefix the FW loader variables with the script prefix */
+       snprintf(env_addr, sizeof(env_addr), "%s_addr", script_name);
+       snprintf(env_size, sizeof(env_size), "%s_size", script_name);
+
        /* Find out where the firmware got loaded and how long it is */
-       addr = env_get_hex("fw_addr", 0);
-       size = env_get_hex("fw_size", 0);
+       addr = env_get_hex(env_addr, 0);
+       size = env_get_hex(env_size, 0);
 
        /* Clear the variables set by the firmware loading script */
-       env_set("fw_addr", NULL);
-       env_set("fw_size", NULL);
+       env_set(env_addr, NULL);
+       env_set(env_size, NULL);
 
        if (!addr || !size) {
                log_err("Firmware address (0x%lx) or size (0x%lx) are invalid.\n",