From: Tim Deegan <tim@xen.org>
To: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
Cc: Anthony Perard <anthony.perard@citrix.com>,
"xen-devel@lists.xensource.com" <xen-devel@lists.xensource.com>,
Ian Campbell <Ian.Campbell@citrix.com>
Subject: Re: [PATCH v2] xen/arm: build as zImage
Date: Tue, 27 Nov 2012 13:58:42 +0000 [thread overview]
Message-ID: <20121127135842.GA51942@ocelot.phlegethon.org> (raw)
In-Reply-To: <alpine.DEB.2.02.1211271208420.5310@kaball.uk.xensource.com>
At 12:11 +0000 on 27 Nov (1354018273), Stefano Stabellini wrote:
> On Fri, 23 Nov 2012, Ian Campbell wrote:
> > On Fri, 2012-11-23 at 18:04 +0000, Stefano Stabellini wrote:
> > > The zImage format is extremely simple: it only consists of a magic
> > > number and 2 addresses in a specific position (see
> > > http://www.simtec.co.uk/products/SWLINUX/files/booting_article.html#d0e309).
> > >
> > > Some bootloaders expect a zImage; considering that it doesn't cost us
> > > much to build Xen compatible with the format, make it so.
> > >
> > > Changes in v2:
> > > - code style;
> > > - pass 0 a start address.
> > >
> > > Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
> > >
> > > diff --git a/xen/arch/arm/head.S b/xen/arch/arm/head.S
> > > index 25c4cfe..347ddcf 100644
> > > --- a/xen/arch/arm/head.S
> > > +++ b/xen/arch/arm/head.S
> > > @@ -22,6 +22,8 @@
> > > #include <asm/processor-ca15.h>
> > > #include <asm/asm_defns.h>
> > >
> > > +#define ZIMAGE_MAGIC_NUMBER 0x016f2818
> > > +
> > > #define PT_PT 0xe7f /* nG=1, AF=1, SH=10, AP=01, NS=1, ATTR=111, T=1, P=1 */
> > > #define PT_MEM 0xe7d /* nG=1, AF=1, SH=10, AP=01, NS=1, ATTR=111, T=0, P=1 */
> > > #define PT_DEV 0xe71 /* nG=1, AF=1, SH=10, AP=01, NS=1, ATTR=100, T=0, P=1 */
> > > @@ -52,6 +54,18 @@
> > > * or the initial pagetable code below will need adjustment. */
> > > .global start
> > > start:
> > > +
> > > + /* zImage magic header, see:
> > > + * http://www.simtec.co.uk/products/SWLINUX/files/booting_article.html#d0e309
> > > + */
> > > + .skip 0x20
> >
> > This was better as the explicit repeated nops, as it stands it's not at
> > all clear that you can start executing at start. It might even rely on
> > the specific assemblers behaviour?
> >
> > Also this wasn't what Tim suggested, which was branch then skip, not
> > skip then branch. I think the nops are better for consistency with Linux
> > though.
>
> You are right. Thinking twice about it, I would rather keep the code as
> it was originally, for consistency with Linux.
Does consistency with linux buy us anything (beyond untidy code)?
I very much prefer the other way. And if we do need to fill with nops,
why 7 repeated and one standalone?
Tim.
next prev parent reply other threads:[~2012-11-27 13:58 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-11-23 18:04 [PATCH v2] xen/arm: build as zImage Stefano Stabellini
2012-11-23 18:48 ` Ian Campbell
2012-11-27 12:11 ` Stefano Stabellini
2012-11-27 13:58 ` Tim Deegan [this message]
2012-11-27 14:08 ` Ian Campbell
2012-11-23 18:58 ` Tim Deegan
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20121127135842.GA51942@ocelot.phlegethon.org \
--to=tim@xen.org \
--cc=Ian.Campbell@citrix.com \
--cc=anthony.perard@citrix.com \
--cc=stefano.stabellini@eu.citrix.com \
--cc=xen-devel@lists.xensource.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).