On Tue, 13 Dec 2016 22:45:20 +0100 Andrew Jones <drjo...@redhat.com> wrote:
> We can get to VirtMachineState without the need for saving a pointer > on AcpiBuildState. This is the mach-virt equivalent to "acpi: Don't save > PcGuestInfo on AcpiBuildState" > > Signed-off-by: Andrew Jones <drjo...@redhat.com> > --- > hw/arm/virt-acpi-build.c | 7 +++---- > 1 file changed, 3 insertions(+), 4 deletions(-) > > diff --git a/hw/arm/virt-acpi-build.c b/hw/arm/virt-acpi-build.c > index 7a1efd0dc538..137781646bec 100644 > --- a/hw/arm/virt-acpi-build.c > +++ b/hw/arm/virt-acpi-build.c > @@ -706,7 +706,6 @@ struct AcpiBuildState { > MemoryRegion *linker_mr; > /* Is table patched? */ > bool patched; > - VirtGuestInfo *guest_info; > } AcpiBuildState; > > static > @@ -779,6 +778,8 @@ static void acpi_ram_update(MemoryRegion *mr, GArray > *data) > > static void virt_acpi_build_update(void *build_opaque) > { > + MachineState *machine = MACHINE(qdev_get_machine()); > + VirtMachineState *vms = VIRT_MACHINE(machine); > AcpiBuildState *build_state = build_opaque; > AcpiBuildTables tables; > > @@ -790,8 +791,7 @@ static void virt_acpi_build_update(void *build_opaque) > > acpi_build_tables_init(&tables); > > - virt_acpi_build(container_of(build_state->guest_info, > - VirtMachineState, acpi_guest_info), > &tables); > + virt_acpi_build(vms, &tables); virt_acpi_build(VIRT_MACHINE(qdev_get_machine()), &tables); or even better do it inside of virt_acpi_build(&tables); > > acpi_ram_update(build_state->table_mr, tables.table_data); > acpi_ram_update(build_state->rsdp_mr, tables.rsdp); > @@ -841,7 +841,6 @@ void virt_acpi_setup(VirtMachineState *vms) > } > > build_state = g_malloc0(sizeof *build_state); > - build_state->guest_info = guest_info; > > acpi_build_tables_init(&tables); > virt_acpi_build(vms, &tables);