[U-Boot] [PATCH 2/2] arm64: booti: allow to place kernel image anywhere in physical memory
Tom Rini
trini at konsulko.com
Tue Mar 7 12:16:56 UTC 2017
On Tue, Mar 07, 2017 at 11:43:52AM +0000, Mark Rutland wrote:
> On Tue, Feb 28, 2017 at 12:15:09PM -0500, Tom Rini wrote:
> > On Wed, Mar 01, 2017 at 02:03:58AM +0900, Masahiro Yamada wrote:
> > > 2017-02-27 7:41 GMT+09:00 Tom Rini <trini at konsulko.com>:
> > > > On Thu, Feb 23, 2017 at 10:31:17AM -0500, Tom Rini wrote:
>
> > > > c) I'm not convinced your math above is correct. images->ep is where we
> > > > were put in memory. This is what we should make sure is 2MiB aligned,
> > > > and then add to it the text_offset. And some quick testing with
> > > > CONFIG_ARM64_RANDOMIZE_TEXT_OFFSET enabled Images :)
> > >
> > > My intention is
> > >
> > > images->ep = (2MiB aligned base) + text_offset
> > >
> > > If this equation is met, the image is already placed at the bootable position.
> > > We can skip the relocation.
> > >
> > > Theoretically, we can not know the value of text_offset in advance
> > > (especially for CONFIG_ARM64_RANDOMIZE_TEXT_OFFSET).
> > > However, in practice, we know text_offset is 0x80000.
>
> Per the arm64 Image header, no particular value of text_offset should
> be assumed. Please do not assume a particular value
>
> It has always been the intent that bootloaders should read this, though
> this evidently wasn't very clear (and the bootwrapper set a bad
> example). I tried to clear this up with documentation updates (and the
> addition of ARM64_RANDOMIZE_TEXT_OFFSET).
>
> > > If we put the image at 2MiB aligned base, the relocation would
> > > always happen.
> >
> > Correct. But I honestly don't know if non-randomized text offset is the
> > common case people will optimize for or randomized for added security will be
> > the more common case.
>
> FWIW, the randomized text_offset is a bootloader debugging/testing
> feature, and there's no security aspect to it.
>
> It was added [1] as an additional to hint to bootloader authors that
> they must respect the text_offset field.
Right, and we do this today. But since this doubles as a kind of cheap
KASLR I would also expect to see it used, even if not intended, in this
way.
--
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/20170307/a1e1099b/attachment.sig>
More information about the U-Boot
mailing list