From: Paul Durrant <xadimgnik@gmail.com>
To: David Woodhouse <dwmw2@infradead.org>,
seabios <seabios@seabios.org>,
xen-devel <xen-devel@lists.xenproject.org>,
qemu-devel <qemu-devel@nongnu.org>
Subject: Re: [SeaBIOS PATCH] xen: require Xen info structure at 0x1000 to detect Xen
Date: Thu, 26 Jan 2023 17:49:22 +0000 [thread overview]
Message-ID: <46ea1f4e-2061-d5f8-2b44-5d24a3a3e7ca@xen.org> (raw)
In-Reply-To: <feef99dd2e1a5dce004d22baf07d716d6ea1344c.camel@infradead.org>
On 20/01/2023 11:33, David Woodhouse wrote:
> From: David Woodhouse <dwmw@amazon.co.uk>
>
> When running under Xen, hvmloader places a table at 0x1000 with the e820
> information and BIOS tables. If this isn't present, SeaBIOS will
> currently panic.
>
> We now have support for running Xen guests natively in QEMU/KVM, which
> boots SeaBIOS directly instead of via hvmloader, and does not provide
> the same structure.
>
> As it happens, this doesn't matter on first boot. because although we
> set PlatformRunningOn to PF_QEMU|PF_XEN, reading it back again still
> gives zero. Presumably because in true Xen, this is all already RAM. But
> in QEMU with a faithfully-emulated PAM config in the host bridge, it's
> still in ROM mode at this point so we don't see what we've just written.
>
> On reboot, however, the region *is* set to RAM mode and we do see the
> updated value of PlatformRunningOn, do manage to remember that we've
> detected Xen in CPUID, and hit the panic.
>
> It's not trivial to detect QEMU vs. real Xen at the time xen_preinit()
> runs, because it's so early. We can't even make a XENVER_extraversion
> hypercall to look for hints, because we haven't set up the hypercall
> page (and don't have an allocator to give us a page in which to do so).
>
> So just make Xen detection contingent on the info structure being
> present. If it wasn't, we were going to panic anyway. That leaves us
> taking the standard QEMU init path for Xen guests in native QEMU,
> which is just fine.
>
> Untested on actual Xen but ObviouslyCorrect™.
Works for me...
Tested-by: Paul Durrant <paul@xen.org>
>
> Signed-off-by: David Woodhouse <dwmw@amazon.co.uk>
> ---
> src/fw/xen.c | 45 ++++++++++++++++++++++++++++++++-------------
> 1 file changed, 32 insertions(+), 13 deletions(-)
>
Also...
Reviewed-by: Paul Durrant <paul@xen.org>
next prev parent reply other threads:[~2023-01-26 17:50 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-01-20 11:33 [SeaBIOS PATCH] xen: require Xen info structure at 0x1000 to detect Xen David Woodhouse
2023-01-26 17:49 ` Paul Durrant [this message]
2023-01-26 23:52 ` [SeaBIOS] " Kevin O'Connor
2023-02-02 2:13 ` Kevin O'Connor
2023-02-02 8:05 ` David Woodhouse
2023-02-02 9:10 ` [SeaBIOS] " Gerd Hoffmann
2023-03-07 8:42 ` David Woodhouse
2023-03-09 11:27 ` Gerd Hoffmann
2023-03-16 13:02 ` seabios 1.16.2 release tagged (was: Re: [SeaBIOS] Re: [SeaBIOS PATCH] xen: require Xen info structure at). " Gerd Hoffmann
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=46ea1f4e-2061-d5f8-2b44-5d24a3a3e7ca@xen.org \
--to=xadimgnik@gmail.com \
--cc=dwmw2@infradead.org \
--cc=paul@xen.org \
--cc=qemu-devel@nongnu.org \
--cc=seabios@seabios.org \
--cc=xen-devel@lists.xenproject.org \
/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).