Generic U-Boot

Caleb Connolly caleb.connolly at linaro.org
Thu Feb 13 16:10:36 CET 2025



On 2/13/25 15:03, Caleb Connolly wrote:
> Hi all,
> 
> On 2/12/25 17:41, Simon Glass wrote:
>> Hi Tom,
>>
>> On Wed, 12 Feb 2025 at 09:40, Tom Rini <trini at konsulko.com> wrote:
>>>
>>> On Tue, Feb 11, 2025 at 03:54:21PM -0700, Simon Glass wrote:
>>>>
>>>> The way I see it, both schemes remove the ambiguity. Mine retains a
>>>> single deconfig file and a single 'make menuconfig' for each board.
>>>> Yours feels more like building independent U-Boot images.
>>>
>>> It is explicitly building independent U-Boot images, yes. With a wrapper
>>> around "make all of the images for a given platform". So much of our
>>> confusing and messy code is because we aren't doing that. And since most
>>> modern SoCs can work as (mostly )generic SPL selects correct DTB for PPL
>>> we really could have fewer overall build configurations.
> 
> Big +1 for this. Most Qualcomm platforms in the wild today that would 
> benefit from chainloading U-Boot will NEVER be able to run any stage 
> except PPL due to codesigning. For these I would ideally never like to 
> even think about non-PPL stages since they only added confusion.
> 
> At the same time, it would be great to eventually have U-Boot SPL for 
> Qualcomm platforms that can replace Qualcomm's proprietary sbl1, and 
> maybe event some even smaller/earlier secure TPL(?) stage that replaces 
> their xbl_sec.
> 
> I would very much prefer that these be distinct, since they vary in how 
> board specific they need to be (see below).
> 
> Folks who are just contributing support for their device/soc (a few 
> quirks or simple driver ports from Linux in most cases) are going to 
> have the best experience when the learning curve from Linux to U-Boot is 
> minimal. Mixing up various boot stages into a single defconfig and 
> having custom kbuild infrastructure is the opposite of that, and seems 
> unnecessary.
> 
>>
>> I'd really like to see a generic aarch64 U-Boot for PPL, although it
>> would be quite large with all the drivers. Perhaps we could start by
>> having a generic Rockchip one, for example.
> 
> We already have this for Qualcomm. Some small QoL things still need to 
> go upstream but you can build a single U-Boot binary and boot it on a 
> bunch of differences devices just by using the right DTB. See this build 
> script for example which builds for just a few devices:
> 
> https://gitlab.com/sdm845-mainline/validation/-/blob/main/build_uboot.sh
> 
> I think a bunch of things in mach-snapdragon could be moved to a generic 
> mach-aarch64 that could also target other SoCs like Rockchip or 
> Mediatek. I'd be super interested in helping to make this happen.
> 
> Probably would even want to put more things into common code so other 
> architectures can adopt it (and make themselves smaller), then mach- 
> aarch64 can just be a stub for devices that are fully generic.
> 
> The other potential concern with a generic aarch64 target is that we 
> then lose track of what devices are actually supported. It would be nice 
> to have something like a list of DTBs either in U-Boot or in some 
> associated infrastructure we use to build reference images.
> 
> Which all ties back to the goal of providing distro-agnostic U-Boot 
> images to make Qualcomm (and other?) Android phones capable of running 
> more Linux distros.

This has been very successful for older Qualcomm SoC's using lk2nd which 
supports a frankly ridiculous number of phones

https://github.com/msm8916-mainline/lk2nd/blob/main/Documentation/devices.md

notably with just a binary per soc: 
https://github.com/msm8916-mainline/lk2nd/releases/tag/20.0

They also do some fun things with DT that we might find some inspiration in.
> 
> Sorry for the big thought-dump, this has been on my mind for a while and 
> since it seems like something you're both also interested in I just 
> wanted to offer my perspective as a device and distro maintainer as well.
> 
> Kind regards,
> 
>>
>> Regards,
>> Simon
>>
>>>
>>> -- 
>>> Tom
> 
> 

-- 
Caleb (they/them)



More information about the U-Boot mailing list