[PATCH v2 05/17] android: boot: kcomp: support andr_image_data
Simon Glass
sjg at chromium.org
Fri Jan 27 01:54:49 CET 2023
On Thu, 26 Jan 2023 at 09:05, Safae Ouajih <souajih at baylibre.com> wrote:
>
> andr_image_data structure is used as a global representation of
> boot image header structure. This new structure is introduced to
> support all boot header versions : v0,v1.v2.v3.v4 and will be used
> to support v3 and v4 while maitaining support for v0,v1,v2. The need
> of using andr_image_data comes from the change of header structure in
> both version 3 and 4.
>
> android_image_get_kcomp() is reworked to support this new struct.
nit: Your commit messages should be in imperative tense. See [1] for
some thoughts on this.
>
> Signed-off-by: Safae Ouajih <souajih at baylibre.com>
> ---
> boot/image-android.c | 75 ++++++++++++++++++++++++++++++++++++++++-
> include/android_image.h | 27 +++++++++++++++
> include/image.h | 2 ++
> 3 files changed, 103 insertions(+), 1 deletion(-)
>
Reviewed-by: Simon Glass <sjg at chromium.org>
But please comment struct andr_image_data.
[..]
> diff --git a/include/android_image.h b/include/android_image.h
> index 4fce363ff7..5b36f96d7b 100644
> --- a/include/android_image.h
> +++ b/include/android_image.h
> @@ -317,4 +317,31 @@ struct andr_boot_img_hdr_v0 {
> * contained outside boot and vendor boot partitions), otherwise
> * jump to kernel_addr
> */
> +
> +/* Private struct */
> +struct andr_image_data {
> + ulong kernel_ptr;
> + u32 kernel_size;
> + u32 ramdisk_size;
> + u32 boot_ramdisk_size;
> + ulong second_ptr;
> + u32 second_size;
> + ulong dtb_ptr;
> + u32 dtb_size;
> + ulong recovery_dtbo_ptr;
> + u32 recovery_dtbo_size;
> +
> + const char *kcmdline;
> + const char *kcmdline_extra;
> + const char *image_name;
> +
> + u32 kernel_addr;
> + ulong ramdisk_addr;
> + ulong ramdisk_ptr;
> + ulong dtb_load_addr;
> + ulong tags_addr;
> + u32 header_version;
> + u32 boot_img_total_size;
> +};
> +
> #endif
> diff --git a/include/image.h b/include/image.h
> index c1594ee169..9a0bd9d8f2 100644
> --- a/include/image.h
> +++ b/include/image.h
> @@ -1733,7 +1733,9 @@ struct cipher_algo {
> int fit_image_cipher_get_algo(const void *fit, int noffset, char **algo);
>
> struct cipher_algo *image_get_cipher_algo(const char *full_name);
> +struct andr_image_data;
>
> +bool android_image_get_data(const void *boot_hdr, struct andr_image_data *data);
> struct andr_boot_img_hdr_v0;
> int android_image_get_kernel(const struct andr_boot_img_hdr_v0 *hdr, int verify,
> ulong *os_data, ulong *os_len);
> --
> 2.34.1
>
[1] https://chromium.googlesource.com/chromiumos/docs/+/HEAD/contributing.md#commit-messages
More information about the U-Boot
mailing list