Getting rid of falcon mode

Maxime Ripard maxime at cerno.tech
Tue Apr 13 16:28:32 CEST 2021


On Tue, Apr 13, 2021 at 10:13:50AM -0400, Tom Rini wrote:
> On Tue, Apr 13, 2021 at 09:08:01AM -0500, Alex G. wrote:
> > Hi Maxime,
> > 
> > On 4/13/21 3:56 AM, Maxime Ripard wrote:
> > > Hi,
> > > 
> > > On Mon, Apr 12, 2021 at 04:32:49PM -0500, Alex G. wrote:
> > > > ## Introduction
> > > > 
> > > > Today we use "falcon mode" to mean "boot linux straight from SPL". This
> > > > designation makes sense, since falcons "fly at high speed and change
> > > > direction rapidly" according to Wikipedia.
> > > > 
> > > > The way we implement falcon mode is to reserve two areas of storage:
> > > >    * kernel area/partition
> > > >    * dtb area/partition
> > > > By using some "special cases", and "spl export", SPL can more or less figure
> > > > out how to skip u-boot.
> > > > 
> > > > 
> > > > ## The plot twist
> > > > 
> > > > People familiar with FIT, will have recognized that the above is achievable
> > > > with a very basic FIT image. With some advantages:
> > > > 
> > > >      - No "special cases" in SPL code
> > > >      - Signed kernel images
> > > >      - Signed kernel devicetree
> > > >      - Devicetree overlays
> > > >      - Automatic selection of correct devicetree
> > > > 
> > > > 
> > > > ## The problems
> > > > 
> > > > The advantages of FIT are not obvious by looking at SPL code. A noticeable
> > > > amount of SPL code is hidden under #ifdef CONFIG_SPL_OS_BOOT, leading one to
> > > > believe that SPL_OS_BOOT is very important. It must be since it takes up so
> > > > much code.
> > > > 
> > > > Enabling falcon mode is not well documented, and requires a lot of trial and
> > > > error. I've had to define 7 macros, and one new function to get it working
> > > > on my board -- and vividly remember the grief. This is an antiquated way of
> > > > doing things, and completely ignores the u-boot devicetree -- we could just
> > > > as well have defined those seven values in the dtb.
> > > > 
> > > > SPL assumes that it must load u-boot, unless in instances under
> > > > CONFIG_SPL_OS_BOOT. This has cause me a huge amount of grief and confusion
> > > > over the past several months. I have no less than three patch series trying
> > > > to address shortfalls there. It's awful.
> > > > 
> > > > 
> > > > ## The proposal
> > > > 
> > > > I propose we drop falcon mode support for legacy images.
> > > > 
> > > >    - Drop CONFIG_SPL_OS_BOOT. Support for this is implied by SPL_FIT
> > > >    - Drop the "dtb area/partition". The dtb is derived from the FIT
> > > >    - Drop "spl export"
> > > > 
> > > > 
> > > > How do we deal with devicetrees in the FIT then? The options are to use a
> > > > modified devicetree which has the desired "/chosen" node, or use DTB
> > > > overlays.
> > > > 
> > > > What are the reasons why we shouldn't go this route?
> > > 
> > > I can see at least two, that are mainly due to a FIT image being
> > > essentially a compiled device tree:
> > > 
> > >    - Not all platforms have enough head-space in their SPL to have libfdt
> > >      in addition to what is already there.
> > 
> > Do we know which platforms fall in this category? We can investigate if it
> > might be possible to disable just enough of the legacy support to make room
> > for libfdt.
> 
> sunxi is both modern and small, so a good thing to benchmark.

Another issue with sunxi is that it implements PSCI in U-Boot, so you'll
need in the SPL as well if you want to do falcon boot. This is doable on
the later SoCs that have a bigger SRAM, but for that kind of test you'll
want to test on the A10 or A13

Maxime
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 228 bytes
Desc: not available
URL: <https://lists.denx.de/pipermail/u-boot/attachments/20210413/66058d5f/attachment.sig>


More information about the U-Boot mailing list