[U-Boot] [PATCH v6 5/6] sandbox: Use md5sum and fatwrite to enable testing of fs commands
    Simon Glass 
    sjg at chromium.org
       
    Wed Nov  5 02:05:15 CET 2014
    
    
  
On 3 November 2014 18:50, Suriyan Ramasami <suriyan.r at gmail.com> wrote:
> Enable md5sum to check the MD5 of the read and written files to check
> their contents for validity.
> Use map_sysmem() to map buffer in a sandbox environment.
>
> Signed-off-by: Suriyan Ramasami <suriyan.r at gmail.com>
Acked-by: Simon Glass <sjg at chromium.org>
>
> ---
>
> Changes in v6:
> * Simon - Split this into a separate patch
>
> Changes in v5: None
>
>  common/cmd_md5sum.c       | 12 ++++++++++--
>  include/configs/sandbox.h |  2 ++
>  2 files changed, 12 insertions(+), 2 deletions(-)
>
> diff --git a/common/cmd_md5sum.c b/common/cmd_md5sum.c
> index 3ac8cc4..d22ace5 100644
> --- a/common/cmd_md5sum.c
> +++ b/common/cmd_md5sum.c
> @@ -11,6 +11,7 @@
>  #include <common.h>
>  #include <command.h>
>  #include <u-boot/md5.h>
> +#include <asm/io.h>
>
>  /*
>   * Store the resulting sum to an address or variable
> @@ -79,6 +80,7 @@ int do_md5sum(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
>         int verify = 0;
>         int ac;
>         char * const *av;
> +       void *buf;
>
>         if (argc < 3)
>                 return CMD_RET_USAGE;
> @@ -96,7 +98,9 @@ int do_md5sum(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
>         addr = simple_strtoul(*av++, NULL, 16);
>         len = simple_strtoul(*av++, NULL, 16);
>
> -       md5_wd((unsigned char *) addr, len, output, CHUNKSZ_MD5);
> +       buf = map_sysmem(addr, len);
> +       md5_wd(buf, len, output, CHUNKSZ_MD5);
> +       unmap_sysmem(buf);
>
>         if (!verify) {
>                 printf("md5 for %08lx ... %08lx ==> ", addr, addr + len - 1);
> @@ -135,6 +139,7 @@ static int do_md5sum(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
>         unsigned long addr, len;
>         unsigned int i;
>         u8 output[16];
> +       void *buf;
>
>         if (argc < 3)
>                 return CMD_RET_USAGE;
> @@ -142,7 +147,10 @@ static int do_md5sum(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
>         addr = simple_strtoul(argv[1], NULL, 16);
>         len = simple_strtoul(argv[2], NULL, 16);
>
> -       md5_wd((unsigned char *) addr, len, output, CHUNKSZ_MD5);
> +       buf = map_sysmem(addr, len);
> +       md5_wd(buf, len, output, CHUNKSZ_MD5);
> +       unmap_sysmem(buf);
> +
>         printf("md5 for %08lx ... %08lx ==> ", addr, addr + len - 1);
>         for (i = 0; i < 16; i++)
>                 printf("%02x", output[i]);
> diff --git a/include/configs/sandbox.h b/include/configs/sandbox.h
> index ee4b244..2b03841 100644
> --- a/include/configs/sandbox.h
> +++ b/include/configs/sandbox.h
> @@ -48,6 +48,7 @@
>  #define CONFIG_ANDROID_BOOT_IMAGE
>
>  #define CONFIG_FS_FAT
> +#define CONFIG_FAT_WRITE
>  #define CONFIG_FS_EXT4
>  #define CONFIG_EXT4_WRITE
>  #define CONFIG_CMD_FAT
> @@ -57,6 +58,7 @@
>  #define CONFIG_DOS_PARTITION
>  #define CONFIG_HOST_MAX_DEVICES 4
>  #define CONFIG_CMD_FS_GENERIC
> +#define CONFIG_CMD_MD5SUM
>
>  #define CONFIG_SYS_VSNPRINTF
>
> --
> 1.9.1
>
    
    
More information about the U-Boot
mailing list