[PATCH v2 02/31] arm64: Kernel booting and initialisation
Arnd Bergmann
arnd at arndb.de
Fri Aug 17 07:20:40 EDT 2012
On Thursday 16 August 2012, Nicolas Pitre wrote:
> > +3. Decompress the kernel image
> > +------------------------------
> > +
> > +Requirement: OPTIONAL
> > +
> > +The AArch64 kernel does not provide a decompressor and therefore
> > +requires gzip decompression to be performed by the boot loader if the
> > +default Image.gz target is used. For bootloaders that do not implement
> > +this requirement, the larger Image target is available instead.
>
> Some people will want to use bzip2 or whatever other decompressor du
> jour. Maybe this shouldn't be gzip specific, or just presented as a
> possible option?
Good point. Whether this should be part of this document depends on
what assumptions we make about the boot loader getting the image
in the first place.
In the strict sense, we are documenting the interface between the boot
loader and the kernel here, which already specifies that the kernel
must be uncompressed by the time we enter it. If the boot loader wants
to add its own encryption or compression methods, or its own headers
in front of the binary, the boot protocol isn't really impacted.
That said, I think it's a good idea to also specify what kind of
format we want to be used, e.g. a stripped ELF Image compressed
with one of gzip/bzip2/lzo/xz and with no other headers added,
on a vfat/ext4/btrfs formatted file system. There are probably a
lot of other things one might want to specify if we go down this
route. Or we could refer to the UEFI spec and mandate that the
same format that UEFI uses should be used here independent of
what boot loader is used. I think we can still allow other ways to
get to the image for deeply embedded systems, e.g. linking the
kernel into the boot loader as a blob on tightly constrained
systems. For that case, we'd only specify the interface between
boot loader and kernel as described above.
Arnd
More information about the linux-arm-kernel
mailing list