All of lore.kernel.org
 help / color / mirror / Atom feed
From: Samuel Ortiz <sameo@linux.intel.com>
To: Andrew Jones <drjones@redhat.com>
Cc: Laurent Vivier <lvivier@redhat.com>,
	Peter Maydell <peter.maydell@linaro.org>,
	Thomas Huth <thuth@redhat.com>,
	Eduardo Habkost <ehabkost@redhat.com>,
	Ben Warren <ben@skyportsystems.com>,
	"Michael S. Tsirkin" <mst@redhat.com>,
	qemu-devel@nongnu.org, Shannon Zhao <shannon.zhaosl@gmail.com>,
	qemu-arm@nongnu.org, Paolo Bonzini <pbonzini@redhat.com>,
	Igor Mammedov <imammedo@redhat.com>,
	Richard Henderson <rth@twiddle.net>
Subject: Re: [Qemu-arm] [Qemu-devel] [PATCH v2 6/8] hw: arm: Support both legacy and current RSDP build
Date: Thu, 29 Nov 2018 15:59:42 +0100	[thread overview]
Message-ID: <20181129145942.GB4691@caravaggio> (raw)
In-Reply-To: <20181129144243.so22d2igis7a24xp@kamzik.brq.redhat.com>

On Thu, Nov 29, 2018 at 03:42:43PM +0100, Andrew Jones wrote:
> On Thu, Nov 29, 2018 at 02:24:26PM +0100, Samuel Ortiz wrote:
> > We add the ability to build legacy or current RSDP tables, based on the
> > AcpiRsdpData revision field passed to build_rsdp().
> > Although arm/virt only uses RSDP v2, adding that capability to
> > build_rsdp will allow us to share the RSDP build code between ARM and x86.
> > 
> > Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
> > ---
> >  hw/arm/virt-acpi-build.c | 37 ++++++++++++++++++++++++++-----------
> >  1 file changed, 26 insertions(+), 11 deletions(-)
> > 
> > diff --git a/hw/arm/virt-acpi-build.c b/hw/arm/virt-acpi-build.c
> > index 4782aea4fe..e1338b6f5a 100644
> > --- a/hw/arm/virt-acpi-build.c
> > +++ b/hw/arm/virt-acpi-build.c
> > @@ -378,23 +378,38 @@ build_rsdp(GArray *tbl, BIOSLinker *linker, AcpiRsdpData *rsdp_data)
> >      g_array_append_vals(tbl, rsdp_data->oem_id, 6); /* OEMID */
> >      build_append_int_noprefix(tbl, rsdp_data->revision, 1); /* Revision */
> >      build_append_int_noprefix(tbl, 0, 4); /* RsdtAddress */
> > -    build_append_int_noprefix(tbl, 36, 4); /* Length */
> > -
> > -    /* XSDT address to be filled by guest linker */
> > -    build_append_int_noprefix(tbl, 0, 8); /* XsdtAddress */
> > -    bios_linker_loader_add_pointer(linker, ACPI_BUILD_RSDP_FILE,
> > -                                   24, 8,
> > -                                   ACPI_BUILD_TABLE_FILE,
> > -                                   *rsdp_data->xsdt_tbl_offset);
> > -
> > -    build_append_int_noprefix(tbl, 0, 1); /* Extended Checksum */
> > -    build_append_int_noprefix(tbl, 0, 3); /* Reserved */
> > +    if (rsdp_data->rsdt_tbl_offset) {
> 
> I see why a pointer was used now. Using a pointer ensures a zero
> offset won't fail this test. However the test could be replaced with
> rsdp_data->revision == 0.
> 
> > +        /* RSDT address to be filled by guest linker */
> > +        bios_linker_loader_add_pointer(linker,
> > +                                       ACPI_BUILD_RSDP_FILE, 16, 4,
> > +                                       ACPI_BUILD_TABLE_FILE,
> > +                                       *rsdp_data->rsdt_tbl_offset);
> > +    }
> >  
> >      /* Checksum to be filled by guest linker */
> >      bios_linker_loader_add_checksum(linker, ACPI_BUILD_RSDP_FILE,
> >                                      0, 20, /* ACPI rev 1.0 RSDP size */
> >                                      8);
> >  
> > +    if (rsdp_data->revision == 0) {
> > +        /* ACPI 1.0 RSDP, we're done */
> > +        return;
> > +    }
> > +
> > +    /* The RSDP revision is 2 and later, we must have an XSDT pointer */
> > +    g_assert(rsdp_data->xsdt_tbl_offset != NULL);
> 
> So here's the justification for the pointers. We sanity check the callers.
We could sanity check the callers without pointers as well, I don't
think there's a strong advantage for pointers here, except consistence.


> We're missing the (rsdp_data->revision == 0 && rsdp_data->rsdt_tbl_offset)
> sanity check though.
I think there's nothing preventing a caller to include both rsdt and
xsdt if it wants to be able to run on both < 2.0 and 2.0+ platforms with
the same table. So if rsdt is set we should add it, regardless of the revision.

Cheers,
Samuel.

  reply	other threads:[~2018-11-29 15:00 UTC|newest]

Thread overview: 30+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-11-29 13:24 [Qemu-devel] [PATCH v2 0/8] hw: acpi: RSDP fixes and refactoring Samuel Ortiz
2018-11-29 13:24 ` [Qemu-devel] [PATCH v2 1/8] hw: acpi: The RSDP build API can return void Samuel Ortiz
2018-11-29 14:02   ` [Qemu-arm] " Andrew Jones
2018-11-29 13:24 ` [Qemu-devel] [PATCH v2 2/8] hw: arm: acpi: Fix incorrect checksums in RSDP Samuel Ortiz
2018-11-29 14:02   ` Andrew Jones
2018-11-29 13:24 ` [Qemu-devel] [PATCH v2 3/8] hw: i386: Use correct RSDT length for checksum Samuel Ortiz
2018-11-29 13:24 ` [Qemu-arm] [PATCH v2 4/8] hw: arm: Carry RSDP specific data through AcpiRsdpData Samuel Ortiz
2018-11-29 14:09   ` [Qemu-arm] [Qemu-devel] " Andrew Jones
2018-11-29 14:26     ` Samuel Ortiz
2018-11-30  7:26       ` [Qemu-arm] " Igor Mammedov
2018-11-30 14:34         ` Andrew Jones
2018-11-30  7:27   ` Igor Mammedov
2018-11-29 13:24 ` [Qemu-devel] [PATCH v2 5/8] hw: arm: Convert the RSDP build to the buid_append_foo() API Samuel Ortiz
2018-11-29 14:28   ` [Qemu-arm] " Andrew Jones
2018-11-30  9:25   ` Igor Mammedov
2018-11-29 13:24 ` [Qemu-arm] [PATCH v2 6/8] hw: arm: Support both legacy and current RSDP build Samuel Ortiz
2018-11-29 14:42   ` [Qemu-devel] " Andrew Jones
2018-11-29 14:59     ` Samuel Ortiz [this message]
2018-11-29 15:09       ` Andrew Jones
2018-11-29 17:48         ` [Qemu-arm] " Samuel Ortiz
2018-11-30  9:57       ` Igor Mammedov
2018-11-30  9:38   ` [Qemu-arm] " Igor Mammedov
2018-11-29 13:24 ` [Qemu-devel] [PATCH v2 7/8] hw: acpi: Export and share the ARM " Samuel Ortiz
2018-11-29 14:51   ` [Qemu-arm] " Andrew Jones
2018-11-30 10:03   ` Igor Mammedov
2018-11-29 13:24 ` [Qemu-devel] [PATCH v2 8/8] hw: acpi: Remove AcpiRsdpDescriptor and fix tests Samuel Ortiz
2018-11-29 15:07   ` Andrew Jones
2018-11-30  9:35     ` [Qemu-arm] " Samuel Ortiz
2018-11-30 10:26   ` Igor Mammedov
2018-11-30 10:29 ` [Qemu-arm] [Qemu-devel] [PATCH v2 0/8] hw: acpi: RSDP fixes and refactoring Igor Mammedov

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=20181129145942.GB4691@caravaggio \
    --to=sameo@linux.intel.com \
    --cc=ben@skyportsystems.com \
    --cc=drjones@redhat.com \
    --cc=ehabkost@redhat.com \
    --cc=imammedo@redhat.com \
    --cc=lvivier@redhat.com \
    --cc=mst@redhat.com \
    --cc=pbonzini@redhat.com \
    --cc=peter.maydell@linaro.org \
    --cc=qemu-arm@nongnu.org \
    --cc=qemu-devel@nongnu.org \
    --cc=rth@twiddle.net \
    --cc=shannon.zhaosl@gmail.com \
    --cc=thuth@redhat.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.