[U-Boot] [PATCH v2 1/2] fastboot: sparse: fix block addressing for don't care chunk type
Steve Rae
steve.rae at broadcom.com
Mon Feb 29 23:37:29 CET 2016
please, can this be accepted?
On Tue, Feb 9, 2016 at 11:19 AM, Steve Rae <srae at broadcom.com> wrote:
> When 7bfc3b1 (sparse: Refactor chunk parsing function) was implemented,
> it dropped 9981945 (aboot: fix block addressing for don't care chunk type).
>
> This re-implements the required fix for the "don't care chunk type"...
>
> Signed-off-by: Steve Rae <srae at broadcom.com>
> ---
>
> Changes in v2:
> Handle MMC device differently than the NAND device.
>
> common/image-sparse.c | 12 ++++++++----
> 1 file changed, 8 insertions(+), 4 deletions(-)
>
> diff --git a/common/image-sparse.c b/common/image-sparse.c
> index dffe844..ef0d232 100644
> --- a/common/image-sparse.c
> +++ b/common/image-sparse.c
> @@ -330,9 +330,13 @@ int store_sparse_image(sparse_storage_t *storage,
> void *storage_priv,
> * and go on parsing the rest of the chunks
> */
> if (chunk_header->chunk_type == CHUNK_TYPE_DONT_CARE) {
> - skipped +=
> sparse_block_size_to_storage(chunk_header->chunk_sz,
> - storage,
> -
> sparse_header);
> + blkcnt =
> sparse_block_size_to_storage(chunk_header->chunk_sz,
> + storage,
> +
> sparse_header);
> +#ifdef CONFIG_FASTBOOT_FLASH_MMC_DEV
> + total_blocks += blkcnt;
> +#endif
> + skipped += blkcnt;
> continue;
> }
>
> @@ -380,7 +384,7 @@ int store_sparse_image(sparse_storage_t *storage, void
> *storage_priv,
> printf("........ wrote %d blocks to '%s'\n", total_blocks,
> storage->name);
>
> - if ((total_blocks + skipped) !=
> + if (total_blocks !=
> sparse_block_size_to_storage(sparse_header->total_blks,
> storage, sparse_header)) {
> printf("sparse image write failure\n");
> --
> 1.8.5
>
>
More information about the U-Boot
mailing list