]> Git Repo - J-u-boot.git/blobdiff - cmd/source.c
net: wget: integrate struct wget_info into legacy wget code
[J-u-boot.git] / cmd / source.c
index 81e015b64efc50328e4c08eb660325537f0db096..c9b5f8e400a615c055979270774cd9bde3183a79 100644 (file)
@@ -14,7 +14,6 @@
 
 /* #define DEBUG */
 
-#include <common.h>
 #include <command.h>
 #include <env.h>
 #include <image.h>
 #include <asm/byteorder.h>
 #include <asm/io.h>
 
-#if defined(CONFIG_FIT)
-/**
- * get_default_image() - Return default property from /images
- *
- * Return: Pointer to value of default property (or NULL)
- */
-static const char *get_default_image(const void *fit)
-{
-       int images_noffset;
-
-       images_noffset = fdt_path_offset(fit, FIT_IMAGES_PATH);
-       if (images_noffset < 0)
-               return NULL;
-
-       return fdt_getprop(fit, images_noffset, FIT_DEFAULT_PROP, NULL);
-}
-#endif
-
-int image_source_script(ulong addr, const char *fit_uname)
-{
-       ulong           len;
-#if defined(CONFIG_LEGACY_IMAGE_FORMAT)
-       const image_header_t *hdr;
-#endif
-       u32             *data;
-       int             verify;
-       void *buf;
-#if defined(CONFIG_FIT)
-       const void*     fit_hdr;
-       int             noffset;
-       const void      *fit_data;
-       size_t          fit_len;
-#endif
-
-       verify = env_get_yesno("verify");
-
-       buf = map_sysmem(addr, 0);
-       switch (genimg_get_format(buf)) {
-#if defined(CONFIG_LEGACY_IMAGE_FORMAT)
-       case IMAGE_FORMAT_LEGACY:
-               hdr = buf;
-
-               if (!image_check_magic (hdr)) {
-                       puts ("Bad magic number\n");
-                       return 1;
-               }
-
-               if (!image_check_hcrc (hdr)) {
-                       puts ("Bad header crc\n");
-                       return 1;
-               }
-
-               if (verify) {
-                       if (!image_check_dcrc (hdr)) {
-                               puts ("Bad data crc\n");
-                               return 1;
-                       }
-               }
-
-               if (!image_check_type (hdr, IH_TYPE_SCRIPT)) {
-                       puts ("Bad image type\n");
-                       return 1;
-               }
-
-               /* get length of script */
-               data = (u32 *)image_get_data (hdr);
-
-               if ((len = uimage_to_cpu (*data)) == 0) {
-                       puts ("Empty Script\n");
-                       return 1;
-               }
-
-               /*
-                * scripts are just multi-image files with one component, seek
-                * past the zero-terminated sequence of image lengths to get
-                * to the actual image data
-                */
-               while (*data++);
-               break;
-#endif
-#if defined(CONFIG_FIT)
-       case IMAGE_FORMAT_FIT:
-               fit_hdr = buf;
-               if (fit_check_format(fit_hdr, IMAGE_SIZE_INVAL)) {
-                       puts ("Bad FIT image format\n");
-                       return 1;
-               }
-
-               if (!fit_uname)
-                       fit_uname = get_default_image(fit_hdr);
-
-               if (!fit_uname) {
-                       puts("No FIT subimage unit name\n");
-                       return 1;
-               }
-
-               /* get script component image node offset */
-               noffset = fit_image_get_node (fit_hdr, fit_uname);
-               if (noffset < 0) {
-                       printf ("Can't find '%s' FIT subimage\n", fit_uname);
-                       return 1;
-               }
-
-               if (!fit_image_check_type (fit_hdr, noffset, IH_TYPE_SCRIPT)) {
-                       puts ("Not a image image\n");
-                       return 1;
-               }
-
-               /* verify integrity */
-               if (verify) {
-                       if (!fit_image_verify(fit_hdr, noffset)) {
-                               puts ("Bad Data Hash\n");
-                               return 1;
-                       }
-               }
-
-               /* get script subimage data address and length */
-               if (fit_image_get_data (fit_hdr, noffset, &fit_data, &fit_len)) {
-                       puts ("Could not find script subimage data\n");
-                       return 1;
-               }
-
-               data = (u32 *)fit_data;
-               len = (ulong)fit_len;
-               break;
-#endif
-       default:
-               puts ("Wrong image format for \"source\" command\n");
-               return 1;
-       }
-
-       debug("** Script length: %ld\n", len);
-       return run_command_list((char *)data, len, 0);
-}
-
-/**************************************************/
-#if defined(CONFIG_CMD_SOURCE)
 static int do_source(struct cmd_tbl *cmdtp, int flag, int argc,
                     char *const argv[])
 {
        ulong addr;
        int rcode;
-       const char *fit_uname = NULL;
+       const char *fit_uname = NULL, *confname = NULL;
 
        /* Find script image */
        if (argc < 2) {
@@ -177,6 +39,9 @@ static int do_source(struct cmd_tbl *cmdtp, int flag, int argc,
                                      &fit_uname)) {
                debug("*  source: subimage '%s' from FIT image at 0x%08lx\n",
                      fit_uname, addr);
+       } else if (fit_parse_conf(argv[1], image_load_addr, &addr, &confname)) {
+               debug("*  source: config '%s' from FIT image at 0x%08lx\n",
+                     confname, addr);
 #endif
        } else {
                addr = hextoul(argv[1], NULL);
@@ -184,25 +49,24 @@ static int do_source(struct cmd_tbl *cmdtp, int flag, int argc,
        }
 
        printf ("## Executing script at %08lx\n", addr);
-       rcode = image_source_script(addr, fit_uname);
+       rcode = cmd_source_script(addr, fit_uname, confname);
        return rcode;
 }
 
-#ifdef CONFIG_SYS_LONGHELP
-static char source_help_text[] =
-       "[addr]\n"
-       "\t- run script starting at addr\n"
-       "\t- A valid image header must be present"
+U_BOOT_LONGHELP(source,
 #if defined(CONFIG_FIT)
-       "\n"
-       "For FIT format uImage addr must include subimage\n"
-       "unit name in the form of addr:<subimg_uname>"
-#endif
-       "";
+       "[<addr>][:[<image>]|#[<config>]]\n"
+       "\t- Run script starting at addr\n"
+       "\t- A FIT config name or subimage name may be specified with : or #\n"
+       "\t  (like bootm). If the image or config name is omitted, the\n"
+       "\t  default is used."
+#else
+       "[<addr>]\n"
+       "\t- Run script starting at addr"
 #endif
+       );
 
 U_BOOT_CMD(
        source, 2, 0,   do_source,
        "run script from memory", source_help_text
 );
-#endif
This page took 0.02592 seconds and 4 git commands to generate.