On Fri, Apr 12, 2019 at 07:59:51AM +0200, Heinrich Schuchardt wrote:
> On 3/27/19 5:40 AM, AKASHI Takahiro wrote:
> >This is a preparatory patch for reworking do_bootefi() in later patch.
> >All the non-boot-manager-based (that is, bootefi <addr>) code is put
> >into one function, do_boot_efi().
> >
> >Signed-off-by: AKASHI Takahiro <takahiro.aka...@linaro.org>
> >---
> >  cmd/bootefi.c | 122 ++++++++++++++++++++++++++++----------------------
> >  1 file changed, 68 insertions(+), 54 deletions(-)
> >
> >diff --git a/cmd/bootefi.c b/cmd/bootefi.c
> >index 94b5bdeed3f1..39a0712af6ad 100644
> >--- a/cmd/bootefi.c
> >+++ b/cmd/bootefi.c
> >@@ -355,6 +355,73 @@ static int do_efibootmgr(const char *fdt_opt)
> >     return 0;
> >  }
> >
> >+/*
> >+ * do_boot_efi() - execute EFI binary from command line
> >+ *
> >+ * @image_opt:      string of image start address
> >+ * @fdt_opt:        string of fdt start address
> >+ * Return:  status code
> >+ *
> >+ * Set up memory image for the binary to be loaded, prepare
> >+ * device path and then call do_bootefi_exec() to execute it.
> >+ */
> >+static int do_boot_efi(const char *image_opt, const char *fdt_opt)
> >+{
> >+    unsigned long addr;
> >+    char *saddr;
> >+    efi_status_t ret;
> >+    unsigned long fdt_addr;
> >+
> >+    /* Allow unaligned memory access */
> >+    allow_unaligned();
> >+
> >+    switch_to_non_secure_mode();
> 
> The two call above should be moved to efi_init_obj_list().

Same comment as in patch#8/11

> >+
> >+    /* Initialize EFI drivers */
> >+    ret = efi_init_obj_list();
> >+    if (ret != EFI_SUCCESS) {
> >+            printf("Error: Cannot initialize UEFI sub-system, r = %lu\n",
> >+                   ret & ~EFI_ERROR_MASK);
> >+            return CMD_RET_FAILURE;
> >+    }
> >+
> >+    ret = efi_install_fdt(fdt_opt);
> >+    if (ret != EFI_SUCCESS)
> >+            return CMD_RET_FAILURE;
> >+
> >+#ifdef CONFIG_CMD_BOOTEFI_HELLO
> >+    if (!strcmp(argv[1], "hello")) {
> >+            ulong size = __efi_helloworld_end - __efi_helloworld_begin;
> >+
> >+            saddr = env_get("loadaddr");
> >+            if (saddr)
> >+                    addr = simple_strtoul(saddr, NULL, 16);
> >+            else
> >+                    addr = CONFIG_SYS_LOAD_ADDR;
> >+            memcpy(map_sysmem(addr, size), __efi_helloworld_begin, size);
> >+    } else
> >+#endif
> >+    {
> >+            saddr = argv[1];
> >+
> >+            addr = simple_strtoul(saddr, NULL, 16);
> >+            /* Check that a numeric value was passed */
> >+            if (!addr && *saddr != '0')
> >+                    return CMD_RET_USAGE;
> >+    }
> >+
> >+    printf("## Starting EFI application at %08lx ...\n", addr);
> 
> Shouldn't this be debug() in efi_start_image()?

Okay, and application -> image
# but I'm not sure that this information is useful.

-Takahiro Akashi


> Best regards
> 
> Heinrich
> 
> >+    ret = do_bootefi_exec(map_sysmem(addr, 0), bootefi_device_path,
> >+                          bootefi_image_path);
> >+    printf("## Application terminated, r = %lu\n",
> >+           ret & ~EFI_ERROR_MASK);
> >+
> >+    if (ret != EFI_SUCCESS)
> >+            return CMD_RET_FAILURE;
> >+    else
> >+            return CMD_RET_SUCCESS;
> >+}
> >+
> >  #ifdef CONFIG_CMD_BOOTEFI_SELFTEST
> >  static efi_status_t bootefi_run_prepare(const char *load_options_path,
> >             struct efi_device_path *device_path,
> >@@ -481,11 +548,6 @@ static int do_efi_selftest(const char *fdt_opt)
> >  /* Interpreter command to boot an arbitrary EFI image from memory */
> >  static int do_bootefi(cmd_tbl_t *cmdtp, int flag, int argc, char * const 
> > argv[])
> >  {
> >-    unsigned long addr;
> >-    char *saddr;
> >-    efi_status_t r;
> >-    unsigned long fdt_addr;
> >-
> >     if (argc < 2)
> >             return CMD_RET_USAGE;
> >
> >@@ -496,55 +558,7 @@ static int do_bootefi(cmd_tbl_t *cmdtp, int flag, int 
> >argc, char * const argv[])
> >             return do_efi_selftest(argc > 2 ? argv[2] : NULL);
> >  #endif
> >
> >-    /* Allow unaligned memory access */
> >-    allow_unaligned();
> >-
> >-    switch_to_non_secure_mode();
> >-
> >-    /* Initialize EFI drivers */
> >-    r = efi_init_obj_list();
> >-    if (r != EFI_SUCCESS) {
> >-            printf("Error: Cannot set up EFI drivers, r = %lu\n",
> >-                   r & ~EFI_ERROR_MASK);
> >-            return CMD_RET_FAILURE;
> >-    }
> >-
> >-    r = fdt_install_fdt(argc > 2 ? argv[2] : NULL);
> >-    if (r != EFI_SUCCESS)
> >-            return r;
> >-
> >-#ifdef CONFIG_CMD_BOOTEFI_HELLO
> >-    if (!strcmp(argv[1], "hello")) {
> >-            ulong size = __efi_helloworld_end - __efi_helloworld_begin;
> >-
> >-            saddr = env_get("loadaddr");
> >-            if (saddr)
> >-                    addr = simple_strtoul(saddr, NULL, 16);
> >-            else
> >-                    addr = CONFIG_SYS_LOAD_ADDR;
> >-            memcpy(map_sysmem(addr, size), __efi_helloworld_begin, size);
> >-    } else
> >-#endif
> >-    {
> >-            saddr = argv[1];
> >-
> >-            addr = simple_strtoul(saddr, NULL, 16);
> >-            /* Check that a numeric value was passed */
> >-            if (!addr && *saddr != '0')
> >-                    return CMD_RET_USAGE;
> >-
> >-    }
> >-
> >-    printf("## Starting EFI application at %08lx ...\n", addr);
> >-    r = do_bootefi_exec(map_sysmem(addr, 0), bootefi_device_path,
> >-                        bootefi_image_path);
> >-    printf("## Application terminated, r = %lu\n",
> >-           r & ~EFI_ERROR_MASK);
> >-
> >-    if (r != EFI_SUCCESS)
> >-            return 1;
> >-    else
> >-            return 0;
> >+    return do_boot_efi(argv[1], argc > 2 ? argv[2] : NULL);
> >  }
> >
> >  #ifdef CONFIG_SYS_LONGHELP
> >
> 
_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
https://lists.denx.de/listinfo/u-boot

Reply via email to