[U-Boot] [PATCH 2/2] arm64: booti: allow to place kernel image anywhere in physical memory
Tom Rini
trini at konsulko.com
Thu Feb 23 15:31:17 UTC 2017
On Thu, Feb 23, 2017 at 06:17:38PM +0900, Masahiro Yamada wrote:
> Hi Tom,
>
>
> 2017-02-23 1:19 GMT+09:00 Tom Rini <trini at konsulko.com>:
> > On Wed, Feb 22, 2017 at 11:34:26AM +0900, Masahiro Yamada wrote:
> >
> >> At first, the ARM64 Linux booting requirement recommended that the
> >> kernel image be placed text_offset bytes from 2MB aligned base near
> >> the start of usable system RAM because memory below that base address
> >> was unusable at that time.
> >>
> >> This requirement was relaxed by Linux commit a7f8de168ace ("arm64:
> >> allow kernel Image to be loaded anywhere in physical memory").
> >> Since then, the bit 3 of the flags field indicates the tolerance
> >> of the kernel physical placement. If this bit is set, the 2MB
> >> aligned base may be anywhere in physical memory. For details, see
> >> Documentation/arm64/booting.txt of Linux.
> >>
> >> The booti command should be also relaxed to not expect the kernel
> >> image at the start of the system RAM. Even when booting older
> >> kernel versions, it still makes sense to have some space below the
> >> kernel. For example, some firmware may sit at the start of the
> >> system RAM.
> >>
> >> After all, the most flexible way for booting the kernel is to respect
> >> the original images->ep instead of gd->bd->bi_dram[0].start. If
> >> image->ep (which is the address given to the booti command) already
> >> meets the address requirement, just use it. If not, relocate the
> >> kernel to the next 2MB aligned address.
> >>
> >> Signed-off-by: Masahiro Yamada <yamada.masahiro at socionext.com>
> >> ---
> >>
> >> cmd/booti.c | 6 +++++-
> >> 1 file changed, 5 insertions(+), 1 deletion(-)
> >>
> >> diff --git a/cmd/booti.c b/cmd/booti.c
> >> index f65f0e7..9408c34 100644
> >> --- a/cmd/booti.c
> >> +++ b/cmd/booti.c
> >> @@ -11,6 +11,8 @@
> >> #include <image.h>
> >> #include <lmb.h>
> >> #include <mapmem.h>
> >> +#include <linux/kernel.h>
> >> +#include <linux/sizes.h>
> >>
> >> DECLARE_GLOBAL_DATA_PTR;
> >>
> >> @@ -54,7 +56,9 @@ static int booti_setup(bootm_headers_t *images)
> >> * If we are not at the correct run-time location, set the new
> >> * correct location and then move the image there.
> >> */
> >> - dst = gd->bd->bi_dram[0].start + le64_to_cpu(ih->text_offset);
> >> + dst = images->ep - ih->text_offset;
> >> + dst = ALIGN(dst, SZ_2M);
> >> + dst += ih->text_offset;
> >
> > I think the code will be slightly more complex here but I would rather
> > see us check for the presence of the flag which allows for us to
> > relocate things rather than assume that we can always use the address
> > provided, or round it up. The 'contract' wwith the kernel previously
> > said it must be from start of memory and I'd rather not change that.
>
>
> At first, I tried this approach.
>
> The problem (at least for me) is
> commit a7f8de168ace is quite new; this is only included in Linux 4.5 and later.
> Linux 4.4 LTS will be used on Socionext's products for a while.
> However, I need to avoid the relocation of the kernel image.
>
> The gd->bd->bi_dram[0].start points to the start of the DRAM.
> Here, some firmware is sitting at the start of the DRAM.
> To hide the head of the memory from Linux,
> the memory node in the device tree is carved out.
>
> If CONFIG_ARCH_FIXUP_FDT_MEMORY is not set,
> U-Boot passes the memory node as-is to Linux.
> As a result, the Image is placed out of the available memory region
> specified by DT,
> then Linux fails to boot.
>
>
> Somehow I want to achieve,
> "Even when booting older kernel versions, it still makes sense to have
> some space below the
> kernel. For example, some firmware may sit at the start of the system RAM."
>
>
> Perhaps, can we introduce a CONFIG
> to enable/disable the relocation?
> Or, any other good idea?
I guess the answer is that I need to find some time to re-read the
history on Documentation/arm64/booting.txt to see when various
restrictions changed / were introduced. I'm also willing to say that
perhaps my initial implementation (or the follow up when text_offset was
introduced) was incorrectly too strict.
--
Tom
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 819 bytes
Desc: Digital signature
URL: <http://lists.denx.de/pipermail/u-boot/attachments/20170223/3320194f/attachment.sig>
More information about the U-Boot
mailing list