[PATCH] arm64: booting: Require placement within 48-bit addressable memory
Mark Rutland
mark.rutland at arm.com
Mon Nov 14 04:10:23 PST 2022
On Mon, Nov 14, 2022 at 12:58:10PM +0100, Ard Biesheuvel wrote:
> Some configurations (i.e., 64k + LVA/LPA) can tolerate a physical
> placement of the kernel image outside of the 48-bit addressable region,
> but given that the loader has no way of knowing whether or not the image
> in question supports LVA/LPA, it currently has no choice but to place it
> below the 48-bit mark.
>
> Once we add support for LPA2, which allows 52-bit physical and virtual
> addressing when using 4k or 16k pages, but in way that relies on
> increasing the number of paging levels, there will be more variety in
> the configurations that may or may not support this.
>
> So repaint bit #3 in the Image header as 'must be placed within 48-bit
> addressable memory', as this is the current de facto meaning, and add
> bits that we may set later to allow placement outside of that.
Could we just clean up the definition of bit 3 for now, then add the other bits
when we actually set them?
>
> Signed-off-by: Ard Biesheuvel <ardb at kernel.org>
> ---
> Documentation/arm64/booting.rst | 9 +++++++--
> 1 file changed, 7 insertions(+), 2 deletions(-)
>
> diff --git a/Documentation/arm64/booting.rst b/Documentation/arm64/booting.rst
> index 8c324ad638de2b27..9919e1a107add655 100644
> --- a/Documentation/arm64/booting.rst
> +++ b/Documentation/arm64/booting.rst
> @@ -114,16 +114,21 @@ Header notes:
> * 1 - 4K
> * 2 - 16K
> * 3 - 64K
> - Bit 3 Kernel physical placement
> + Bit 3-4 Kernel physical placement
>
> 0
> 2MB aligned base should be as close as possible
> to the base of DRAM, since memory below it is not
> accessible via the linear mapping
> 1
> + 2MB aligned base such that base plus image_size is
> + entirely within the 48-bit addressable range
This seems to assume text_offset is zero (which is the case today, but this is
the first part of booting.txt that assumes that); as a matter of policy are we
sure that we'll never use a non-zero offset again? If so, we probably want to
mention that in the "header notes" section, or come up with some wording to
include it here.
Otherwise, this looks good; I'm certainly in favour of explicitly mentioning
the 48-bit restriction.
Thanks,
Mark.
> + 2
> + Reserved
> + 3
> 2MB aligned base may be anywhere in physical
> memory
> - Bits 4-63 Reserved.
> + Bits 5-63 Reserved.
> ============= ===============================================================
>
> - When image_size is zero, a bootloader should attempt to keep as much
> --
> 2.35.1
>
More information about the linux-arm-kernel
mailing list