]> git.baikalelectronics.ru Git - uboot.git/commitdiff
net: fm: Support loading firmware from a filesystem
authorSean Anderson <sean.anderson@seco.com>
Thu, 29 Dec 2022 16:53:01 +0000 (11:53 -0500)
committerTom Rini <trini@konsulko.com>
Thu, 12 Jan 2023 19:06:16 +0000 (14:06 -0500)
This adds a new method to load Fman firmware from a filesystem. This
allows users to use regular files instead of hard-coded offsets for the
firmware.

Signed-off-by: Sean Anderson <sean.anderson@seco.com>
Reviewed-by: Ramon Fried <rfried.dev@gmail.com>
drivers/net/fm/fm.c
drivers/qe/Kconfig

index 457200e7666944d92c1ef9f82b4b33d23237ad44..e1fba24471c00d0ccaf575460ba94d433726cd30 100644 (file)
@@ -5,6 +5,7 @@
  */
 #include <common.h>
 #include <env.h>
+#include <fs_loader.h>
 #include <image.h>
 #include <malloc.h>
 #include <asm/io.h>
@@ -452,7 +453,29 @@ int fm_init_common(int index, struct ccsr_fman *reg, const char *firmware_name)
 int fm_init_common(int index, struct ccsr_fman *reg, const char *firmware_name)
 {
        int rc;
-#if defined(CONFIG_SYS_QE_FMAN_FW_IN_NOR)
+#if defined(CONFIG_SYS_QE_FMAN_FW_IN_FS)
+       struct udevice *fs_loader;
+       void *addr = malloc(CONFIG_SYS_QE_FMAN_FW_LENGTH);
+
+       if (!addr)
+               return -ENOMEM;
+
+       rc = get_fs_loader(&fs_loader);
+       if (rc) {
+               debug("could not get fs loader: %d\n", rc);
+               return rc;
+       }
+
+       if (!firmware_name)
+               firmware_name = "fman.itb";
+
+       rc = request_firmware_into_buf(fs_loader, firmware_name, addr,
+                                      CONFIG_SYS_QE_FMAN_FW_LENGTH, 0);
+       if (rc < 0) {
+               debug("could not request %s: %d\n", firmware_name, rc);
+               return rc;
+       }
+#elif defined(CONFIG_SYS_QE_FMAN_FW_IN_NOR)
        void *addr = (void *)CONFIG_SYS_FMAN_FW_ADDR;
 #elif defined(CONFIG_SYS_QE_FMAN_FW_IN_NAND)
        size_t fw_length = CONFIG_SYS_QE_FMAN_FW_LENGTH;
index c44a81f69a55276c7d0ec68515abccd3f9a8cb56..89a75c175b00275a98d83ffee0123cfcd7dce3f9 100644 (file)
@@ -27,6 +27,10 @@ choice
        depends on FMAN_ENET || QE
        default SYS_QE_FMAN_FW_IN_ROM
 
+config SYS_QE_FMAN_FW_IN_FS
+       depends on FS_LOADER && FMAN_ENET
+       bool "Filesystem"
+
 config SYS_QE_FMAN_FW_IN_NOR
        bool "NOR flash"