Hi Quentin, On 2025-02-05 16:40, Quentin Schulz wrote: > Hi Jonas, > > On 1/29/25 11:36 PM, Jonas Karlman wrote: >> Split 32-bit size_and_off and size_and_nimage fields of the v2 image >> format header into their own 16-bit size, offset and num_images fields. >> >> Set num_images based on number of images passed by the datafile >> parameter and size based on the offset to the hash field to fix using a >> single init data file and no boot data file for the v2 image format. >> >> Signed-off-by: Jonas Karlman <jo...@kwiboo.se> >> --- >> tools/rkcommon.c | 44 ++++++++++++++++++++++++-------------------- >> 1 file changed, 24 insertions(+), 20 deletions(-) >> >> diff --git a/tools/rkcommon.c b/tools/rkcommon.c >> index 3e52236b15a8..de3fd2d3f3c2 100644 >> --- a/tools/rkcommon.c >> +++ b/tools/rkcommon.c >> @@ -34,15 +34,16 @@ enum hash_type { >> /** >> * struct image_entry >> * >> - * @size_and_off: [31:16]image size;[15:0]image offset >> - * @address: default as 0xFFFFFFFF >> + * @offset: image offset (unit as 512 byte blocks) >> + * @size: image size (unit as 512 byte blocks) >> + * @address: load address (default as 0xFFFFFFFF) >> * @flag: no use >> * @counter: no use >> * @hash: hash of image >> - * >> */ >> struct image_entry { >> - uint32_t size_and_off; >> + uint16_t offset; >> + uint16_t size; >> uint32_t address; >> uint32_t flag; >> uint32_t counter; >> @@ -56,16 +57,17 @@ struct image_entry { >> * This is stored at SD card block 64 (where each block is 512 bytes) >> * >> * @magic: Magic (must be RK_MAGIC_V2) >> - * @size_and_nimage: [31:16]number of images;[15:0] >> - * offset to hash field of header(unit as 4Byte) >> - * @boot_flag: [3:0]hash type(0:none,1:sha256,2:sha512) >> - * @signature: hash or signature for header info >> - * >> + * @size: offset to hash field of header (unit as 4 bytes) >> + * @num_images: number of images >> + * @boot_flag: [3:0] hash type (0:none, 1:sha256, 2:sha512) >> + * @images: images >> + * @hash: hash or signature for header info >> */ >> struct header0_info_v2 { >> uint32_t magic; >> uint8_t reserved[4]; >> - uint32_t size_and_nimage; >> + uint16_t size; >> + uint16_t num_images; >> uint32_t boot_flag; >> uint8_t reserved1[104]; >> struct image_entry images[4]; >> @@ -332,17 +334,18 @@ static void rkcommon_set_header0_v2(void *buf, struct >> image_tool_params *params) >> printf("Image Type: Rockchip %s boot image\n", >> rkcommon_get_spl_hdr(params)); >> memset(buf, '\0', RK_INIT_OFFSET * RK_BLK_SIZE); >> - hdr->magic = cpu_to_le32(RK_MAGIC_V2); >> - hdr->size_and_nimage = cpu_to_le32((2 << 16) + 384); >> + hdr->magic = cpu_to_le32(RK_MAGIC_V2); >> hdr->boot_flag = cpu_to_le32(HASH_SHA256); >> sector_offset = 4; >> image_size_array[0] = spl_params.init_size; >> image_size_array[1] = spl_params.boot_size; >> >> for (i = 0; i < 2; i++) { >> + if (!image_size_array[i]) >> + break; > > This isn't related to this change I believe, can you please make it its > own commit so it doesn't get lost in the diff and has its own individual > commit log?
Yeah, I mostly wanted/needed a test to stop the loop on the "last" supplied input file/image in a later patch. Adding it here made the later diff little bit smaller :-) > >> image_sector_count = image_size_array[i] / RK_BLK_SIZE; >> - hdr->images[i].size_and_off = cpu_to_le32((image_sector_count >> - << 16) + sector_offset); >> + hdr->images[i].offset = cpu_to_le16(sector_offset); >> + hdr->images[i].size = cpu_to_le16(image_sector_count); >> hdr->images[i].address = 0xFFFFFFFF; >> hdr->images[i].counter = cpu_to_le32(i + 1); >> image_ptr = buf + sector_offset * RK_BLK_SIZE; >> @@ -351,6 +354,8 @@ static void rkcommon_set_header0_v2(void *buf, struct >> image_tool_params *params) >> sector_offset = sector_offset + image_sector_count; >> } >> >> + hdr->num_images = cpu_to_le16(i); >> + hdr->size = cpu_to_le16(offsetof(typeof(*hdr), hash) / >> sizeof(uint32_t)); > > Same here. Just do a migration commit (possibly one for struct > image_entry and another one for struct header0_info_v2) first and then > adapt so it handles image_size_array[1] = 0. We don't today so a > separate patch explaining the usecase would be nice. I was trying to avoid having to create too many commits, and mostly cared about the end result, guess I can split this even further in a v2. All in-tree use from binman will always supply two input files/images for v2 image format, so has not really been an issue or need to handle image_size_array[1] = 0, not sure what would happen if you try to run mkimage manually without the second boot image. > >> do_sha256_hash(buf, (void *)hdr->hash - buf, hdr->hash); >> } >> >> @@ -497,10 +502,8 @@ void rkcommon_print_header(const void *buf, struct >> image_tool_params *params) >> return; >> } >> >> - init_size = header0_v2.images[0].size_and_off >> 16; >> - init_size = init_size * RK_BLK_SIZE; >> - boot_size = header0_v2.images[1].size_and_off >> 16; >> - boot_size = boot_size * RK_BLK_SIZE; >> + init_size = le16_to_cpu(header0_v2.images[0].size) * >> RK_BLK_SIZE; >> + boot_size = le16_to_cpu(header0_v2.images[1].size) * >> RK_BLK_SIZE; > > Ditto. Separate patch for the le16_to_cpu would be nice as I assume this > is not a side-effect of switching to two u16 instead of one u32. This > likely fixes a bug :) I have no idea if any of this was or is really working on big-endian prior to (or after), there was some bit manipulation and change to use leXX_to_cpu seemed appropriate, will try to split it out in v2. Could possible try to use qemu for some big-endian testing. > > I was wondering if we shouldn't have CI to generate a handful of > Rockchip dummy binaries with the header on different endianness so we > can catch those. I remember we had someone fix those for v1 already. Sound like a nice task for someone else :-) > >> } else { >> ret = rkcommon_parse_header(buf, &header0, &spl_info); >> >> @@ -514,8 +517,9 @@ void rkcommon_print_header(const void *buf, struct >> image_tool_params *params) >> } >> >> image_type = ret; >> - init_size = header0.init_size * RK_BLK_SIZE; >> - boot_size = header0.init_boot_size * RK_BLK_SIZE - init_size; >> + init_size = le16_to_cpu(header0.init_size) * RK_BLK_SIZE; >> + boot_size = le16_to_cpu(header0.init_boot_size) * RK_BLK_SIZE - >> + init_size; >> > > Ditto, separate patch for le16_to_cpu. Sure, will split out to a few more patches for v2. Regards, Jonas > > Looks good otherwise! > > Cheers, > Quentin