[PATCH 0/3] u-boot chain-loading LineageOS bootimg
Mattijs Korpershoek
mkorpershoek at kernel.org
Tue Apr 29 10:30:07 CEST 2025
Hi George,
Thank you for contributing.
On lun., avril 28, 2025 at 15:53, Casey Connolly <casey.connolly at linaro.org> wrote:
> Hi George,
>
> Thanks a lot for the series, it's super exciting to see support for
> booting Android on top of U-Boot :D
>
> On 4/27/25 13:25, George Chan via B4 Relay wrote:
>> This is a series of patches to enable chainloading LineageOS on qcom SOC.
>>
>> First patch is to workaround kernel/ramdisk invalid addr by identify
>> its physical memory address out-of-range. Since qcom SOC usually have
>> 0x80000000 as start/base/real memory address but androidboot img
>> specified to around 0x0. If other vendor bootloader behave similar then
>> this patch can also workaround it as well.
>
> I'm curious to know what values are there, tbh I think U-Boot should
> entirely ignore the values in the boot image but I guess that could
> break some other platforms.
Yes, some platforms actually use the values from the boot.img.
We had some breakage on Khadas VIM3 in this area. See:
https://lore.kernel.org/all/20241003-android-fix-boot-v2-v1-1-13e8e44af4b7@baylibre.com/
The above thread also mentions how to repack a boot.img, where we can
specify a different ramdisk address.
It's a bit unclear to me why it's impractical to repack the boot.img and
specify the appropriate address. Could you elaborate ?
>
> How about adding a config option CONFIG_ANDROID_BOOTIMG_IGNORE_ADDRS and
> just ORing it in all the places that have checks like
> "img_data->kernel_addr == 0". Then you can enable this for
> mach-snapdragon by selecting it in the ARCH_SNAPDRAGON config definition.
If we need to add this in U-Boot, I'd prefer this option as suggested by Casey.
>
>>
>> Second patch is enable bootmeth-android to have chance for extra mem block.
>> Usually the fastboot mem block, to hold androidboot img, and loadaddr for
>> unzipped kernel. If other SOC have extra mem block available but
>> fastboot block, we can add extra logic to take care of it.
>
> There is a small hack in mach-snapdragon that we put kernel_addr_r and
> loadaddr at the same address to avoid using up too much memory on
> devices that only have 1GB which explains this crash because we try to
> decompress the kernel to the same address it got loaded too.
>
> I think we can get away with giving loadaddr its own allocation of 64M
> or so, maybe 96. This would make your second patch redundant (and feels
> like the right fix to me)
I was not aware of this hack, but I agree with Casey.
>
>>
>> Third patch is optional to enable snapdragon board to have extra cmdline
>> found from original bootloader that is required for LineageOS boot init.
>> An alternate method is to put the append string into a dummy device-tree
>> file, as /chosen/bootarg ofnode porperty, that also contain msm-id. Then
>> encapsulate as androidboot img and let u-boot as kernel binary. Below is
>> an example for Xiaomi Miatoll device.
>
> I assume you're chainloading U-Boot on this device? If so, isn't it
> enough to just copy the boot args that ABL gives us and maybe tweak a few?
>
> I'd also rather keep this constrained, maybe an android specific board
> callback to set boot args (if there isn't one already) and have the FDT
> fixup code be alongside some other generic FDT fixup stuff. I'd rather
> not have this stuff in board specific code.
I also agree with Casey here. Looking at patch: "[PATCH 3/3]
mach-snapdragon: Add support to append string to kernel cmdline", the
android bootmethod already takes care of some androidboot.* arguments.
See:
https://source.denx.de/u-boot/u-boot/-/blob/master/boot/bootmeth_android.c?ref_type=heads#L504
For androidboot.verifiedbootstate=orange, this is done via
avb_append_commandline_arg() when AVB is enabled in U-Boot.
>
> I hope this makes sense, feel free to ask for clarifications on anything.
>
> Thanks and kind regards,
>
>>
>> /dts-v1/;
>>
>> / {
>> qcom,msm-id = <443 0x0>;
>> qcom,board-id = <0 0>,
>> <0x10022 1>,
>> <0x20022 1>,
>> <0x30022 1>,
>> <0x40022 1>,
>> <0x50022 1>;
>>
>> #address-cells = <2>;
>> #size-cells = <2>;
>>
>> memory {
>> ddr_device_type = <0x07>;
>> /* We expect the bootloader to fill in the size */
>> reg = <0 0 0 0>;
>> };
>>
>> chosen {
>> bootargs = "";
>> };
>> };
>>
>> Signed-off-by: George Chan <gchan9527 at gmail.com>
>> ---
>> George Chan (3):
>> boot/image-android.c: Workaround androidboot kernel/ramdisk addr
>> boot/bootmeth-android.c: Reuse fastboot memory block for unzip kernel
>> mach-snapdragon: Add support to append string to kernel cmdline
>>
>> arch/arm/mach-snapdragon/Kconfig | 11 +++++
>> arch/arm/mach-snapdragon/board.c | 97 ++++++++++++++++++++++++++++++++++++++++
>> boot/bootmeth_android.c | 12 +++++
>> boot/image-android.c | 10 +++++
>> 4 files changed, 130 insertions(+)
>> ---
>> base-commit: 5a0a93a768487e55ebe50a34cc90d751bf99cc56
>> change-id: 20250427-android-boot-ecbb768cda72
>>
>> Best regards,
> --
> Casey (she/they)
More information about the U-Boot
mailing list