[PATCH v2 05/17] android: boot: kcomp: support andr_image_data

Mattijs Korpershoek mkorpershoek at baylibre.com
Wed Feb 1 09:35:49 CET 2023


On Thu, Jan 26, 2023 at 17:54, Simon Glass <sjg at chromium.org> wrote:

> 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.
>
> [..]

Reviewed-by: Mattijs Korpershoek <mkorpershoek at baylibre.com>

>
>> 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