[PATCH 1/2] tools: mkimage: Add StarFive SPL image support
Chanho Park
chanho61.park at samsung.com
Wed Sep 6 12:47:30 CEST 2023
Hi,
> -----Original Message-----
> From: Heinrich Schuchardt <heinrich.schuchardt at canonical.com>
> Sent: Wednesday, September 6, 2023 7:08 PM
> To: Rick Chen <rick at andestech.com>; Leo <ycliang at andestech.com>; Yanhong
> Wang <yanhong.wang at starfivetech.com>
> Cc: Simon Glass <sjg at chromium.org>; Marc Kleine-Budde
<mkl at pengutronix.de>;
> Chanho Park <chanho61.park at samsung.com>; u-boot at lists.denx.de; Heinrich
> Schuchardt <heinrich.schuchardt at canonical.com>
> Subject: [PATCH 1/2] tools: mkimage: Add StarFive SPL image support
>
> The StarFive JH7110 base boards require a header to be prefixed to the SPL
> binary image. This has previously done with a vendor tool 'spl_tool'
> published under a GPL-2-or-later license. Integrate this capability into
> mkimage.
>
> Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt at canonical.com>
> ---
> boot/image.c | 1 +
> include/image.h | 1 +
> tools/Makefile | 1 +
> tools/sfspl.c | 174 ++++++++++++++++++++++++++++++++++++++++++++++++
> 4 files changed, 177 insertions(+)
> create mode 100644 tools/sfspl.c
>
> diff --git a/boot/image.c b/boot/image.c
> index 5c4f9b807d..3a99d2e897 100644
> --- a/boot/image.c
> +++ b/boot/image.c
> @@ -182,6 +182,7 @@ static const table_entry_t uimage_type[] = {
> { IH_TYPE_SUNXI_TOC0, "sunxi_toc0", "Allwinner TOC0 Boot
> Image" },
> { IH_TYPE_FDT_LEGACY, "fdt_legacy", "legacy Image with Flat
> Device Tree ", },
> { IH_TYPE_RENESAS_SPKG, "spkgimage", "Renesas SPKG Image" },
> + { IH_TYPE_STARFIVE_SPL, "sfspl", "StarFive SPL Image" },
> { -1, "", "", },
> };
>
> diff --git a/include/image.h b/include/image.h
> index 01a6787d21..5f85bf84a2 100644
> --- a/include/image.h
> +++ b/include/image.h
> @@ -231,6 +231,7 @@ enum image_type_t {
> IH_TYPE_SUNXI_TOC0, /* Allwinner TOC0 Boot Image */
> IH_TYPE_FDT_LEGACY, /* Binary Flat Device Tree Blob in a
> Legacy Image */
> IH_TYPE_RENESAS_SPKG, /* Renesas SPKG image */
> + IH_TYPE_STARFIVE_SPL, /* StarFive SPL image */
>
> IH_TYPE_COUNT, /* Number of image types */
> };
> diff --git a/tools/Makefile b/tools/Makefile
> index 3d0c4b0dd6..1aa1e36137 100644
> --- a/tools/Makefile
> +++ b/tools/Makefile
> @@ -123,6 +123,7 @@ dumpimage-mkimage-objs := aisimage.o \
> pblimage.o \
> pbl_crc32.o \
> renesas_spkgimage.o \
> + sfspl.o \
> vybridimage.o \
> stm32image.o \
> $(ROCKCHIP_OBS) \
> diff --git a/tools/sfspl.c b/tools/sfspl.c
> new file mode 100644
> index 0000000000..428542d885
> --- /dev/null
> +++ b/tools/sfspl.c
> @@ -0,0 +1,174 @@
> +// SPDX-License-Identifier: GPL-2.0-or-later
> +/*
> + * Copyright Heinrich Schuchardt <heinrich.schuchardt at canonical.com>
> + *
> + * The StarFive JH710 requires to prepend a header to u-boot-spl.bin
> describing
Nit: JH7110 or JH7100? If you'd like to indicate both, JH71x0?
Tested-by: Chanho Park <chanho61.park at samsung.com>
Best Regards,
Chanho Park
> + * the payload length and CRC32.
> + *
> + * This module implements support in mkimage and dumpimage for this file
> format.
> + *
> + * StarFive's spl_tool available under GPL-2.0-and-later at
> + * https://protect2.fireeye.com/v1/url?k=d38f2235-b204371a-d38ea97a-
> 74fe485cbfe7-db3f73ac8e80b9ed&q=1&e=f143c01a-a53d-425d-a99e-
> dab4877e8097&u=https%3A%2F%2Fgithub.com%2Fstarfive-tech%2FTools implements
> writing the same file
> + * format and served as a reference.
> + */
> +
> +#include <compiler.h>
> +#include <fcntl.h>
> +#include <u-boot/crc.h>
> +#include <unistd.h>
> +#include "imagetool.h"
> +
> +#define DEFAULT_VERSION 0x01010101
> +#define DEFAULT_BACKUP 0x200000U
> +#define DEFAULT_OFFSET 0x240
> +
> +/**
> + * struct spl_hdr - header for SPL on JH7110
> + *
> + * All fields are low-endian.
> + */
> +struct spl_hdr {
> + /** @offset: offset to SPL header (0x240) */
> + unsigned int offset;
> + /** @bkp_offs: address of backup SPL, defaults to
> DEFAULT_BACKUP */
> + unsigned int bkp_offs;
> + /** @zero1: set to zero */
> + unsigned int zero1[159];
> + /** @version: header version, defaults to DEFAULT_VERSION */
> + unsigned int version;
> + /** @file_size: file size */
> + unsigned int file_size;
> + /** @hdr_size: size of the file header (0x400) */
> + unsigned int hdr_size;
> + /** @crc32: CRC32 */
> + unsigned int crc32;
> + /** @zero2: set to zero */
> + unsigned int zero2[91];
> +};
> +
> +static int sfspl_check_params(struct image_tool_params *params)
> +{
> + /* Only the RISC-V architecture is supported */
> + if (params->Aflag && params->arch != IH_ARCH_RISCV)
> + return EXIT_FAILURE;
> +
> + return EXIT_SUCCESS;
> +}
> +
> +static int sfspl_verify_header(unsigned char *buf, int size,
> + struct image_tool_params *params)
> +{
> + struct spl_hdr *hdr = (void *)buf;
> + unsigned int hdr_size = le32_to_cpu(hdr->hdr_size);
> + unsigned int file_size = le32_to_cpu(hdr->file_size);
> + unsigned int crc = le32_to_cpu(hdr->crc32);
> + unsigned int crc_check;
> +
> + if (size < 0 ||
> + (size_t)size < sizeof(struct spl_hdr) ||
> + (size_t)size < hdr_size + file_size) {
> + printf("Truncated file\n");
> + return EXIT_FAILURE;
> + }
> + if (hdr->version != DEFAULT_VERSION) {
> + printf("Unknown file format version\n");
> + return EXIT_FAILURE;
> + }
> + crc_check = crc32(0, &buf[hdr_size], size - hdr_size);
> + if (crc_check != crc) {
> + printf("Incorrect CRC32\n");
> + return EXIT_FAILURE;
> + }
> +
> + return EXIT_SUCCESS;
> +}
> +
> +static void sfspl_print_header(const void *buf,
> + struct image_tool_params *params)
> +{
> + struct spl_hdr *hdr = (void *)buf;
> + unsigned int hdr_size = le32_to_cpu(hdr->hdr_size);
> + unsigned int file_size = le32_to_cpu(hdr->file_size);
> +
> + printf("Header size: %u\n", hdr_size);
> + printf("Payload size: %u\n", file_size);
> +}
> +
> +static int sfspl_image_extract_subimage(void *ptr,
> + struct image_tool_params *params)
> +{
> + struct spl_hdr *hdr = (void *)ptr;
> + unsigned char *buf = ptr;
> + int fd;
> + unsigned int hdr_size = le32_to_cpu(hdr->hdr_size);
> + unsigned int file_size = le32_to_cpu(hdr->file_size);
> +
> + if (params->pflag) {
> + printf("Invalid image index %d\n", params->pflag);
> + return EXIT_FAILURE;
> + }
> +
> + fd = open(params->outfile, O_WRONLY | O_CREAT | O_TRUNC, 0644);
> + if (fd == -1) {
> + perror("Can write file");
> + return EXIT_FAILURE;
> + }
> + if (write(fd, &buf[hdr_size], file_size) != file_size) {
> + perror("Cannot write file");
> + return EXIT_FAILURE;
> + }
> + close(fd);
> +
> + return EXIT_SUCCESS;
> +}
> +
> +static int sfspl_check_image_type(uint8_t type)
> +{
> + if (type == IH_TYPE_STARFIVE_SPL)
> + return EXIT_SUCCESS;
> +
> + return EXIT_FAILURE;
> +}
> +
> +static void sfspl_set_header(void *buf, struct stat *sbuf, int infd,
> + struct image_tool_params *params)
> +{
> + struct spl_hdr *hdr = buf;
> + unsigned int file_size;
> + unsigned int crc;
> +
> + file_size = params->file_size - sizeof(struct spl_hdr);
> + crc = crc32(0, &((unsigned char *)buf)[sizeof(struct spl_hdr)],
> + file_size);
> +
> + hdr->offset = cpu_to_le32(DEFAULT_OFFSET);
> + hdr->bkp_offs = cpu_to_le32(DEFAULT_BACKUP);
> + hdr->version = cpu_to_le32(DEFAULT_VERSION);
> + hdr->file_size = cpu_to_le32(file_size);
> + hdr->hdr_size = cpu_to_le32(sizeof(struct spl_hdr));
> + hdr->crc32 = cpu_to_le32(crc);
> +}
> +
> +static int sfspl_vrec_header(struct image_tool_params *params,
> + struct image_type_params *tparams)
> +{
> + tparams->hdr = calloc(sizeof(struct spl_hdr), 1);
> +
> + /* No padding */
> + return 0;
> +}
> +
> +U_BOOT_IMAGE_TYPE(
> + sfspl, /* id */
> + "StarFive SPL Image", /* name */
> + sizeof(struct spl_hdr), /* header_size */
> + NULL, /* header */
> + sfspl_check_params, /* check_params */
> + sfspl_verify_header, /* verify header */
> + sfspl_print_header, /* print header */
> + sfspl_set_header, /* set header */
> + sfspl_image_extract_subimage, /* extract_subimage */
> + sfspl_check_image_type, /* check_image_type */
> + NULL, /* fflag_handle */
> + sfspl_vrec_header /* vrec_header */
> +);
> --
> 2.40.1
More information about the U-Boot
mailing list