On Wed, 4 Feb 2015 10:51:17 +0800 Zhu Guihua <zhugh.f...@cn.fujitsu.com> wrote:
> From: Tang Chen <tangc...@cn.fujitsu.com> > > Add a new API named acpi_memory_hotplug_sci() to send memory hotplug SCI. > Doing this is because this procedure will be used by other functions in the > next coming patches. Commit subj/message should be amended to reflect changes in patch. i.e. acpi_memory_hotplug_sci doesn't exist anymore > > Signed-off-by: Tang Chen <tangc...@cn.fujitsu.com> > Signed-off-by: Zhu Guihua <zhugh.f...@cn.fujitsu.com> > --- > hw/acpi/core.c | 7 +++++++ > hw/acpi/memory_hotplug.c | 6 ++---- > include/hw/acpi/acpi.h | 3 +++ > 3 files changed, 12 insertions(+), 4 deletions(-) > > diff --git a/hw/acpi/core.c b/hw/acpi/core.c > index 51913d6..98ca994 100644 > --- a/hw/acpi/core.c > +++ b/hw/acpi/core.c > @@ -666,6 +666,13 @@ uint32_t acpi_gpe_ioport_readb(ACPIREGS *ar, uint32_t > addr) > return val; > } > > +void acpi_send_gpe_event(ACPIREGS *ar, qemu_irq irq, > + unsigned int hotplug_status) > +{ > + ar->gpe.sts[0] |= hotplug_status; > + acpi_update_sci(ar, irq); > +} > + > void acpi_update_sci(ACPIREGS *regs, qemu_irq irq) > { > int sci_level, pm1a_sts; > diff --git a/hw/acpi/memory_hotplug.c b/hw/acpi/memory_hotplug.c > index ddbe01b..f30d8f9 100644 > --- a/hw/acpi/memory_hotplug.c > +++ b/hw/acpi/memory_hotplug.c > @@ -201,10 +201,8 @@ void acpi_memory_plug_cb(ACPIREGS *ar, qemu_irq irq, > MemHotplugState *mem_st, > mdev->is_enabled = true; > mdev->is_inserting = true; > > - /* do ACPI magic */ > - ar->gpe.sts[0] |= ACPI_MEMORY_HOTPLUG_STATUS; > - acpi_update_sci(ar, irq); > - return; > + /* Do ACPI magic */ > + acpi_send_gpe_event(ar, irq, ACPI_MEMORY_HOTPLUG_STATUS); > } > > static const VMStateDescription vmstate_memhp_sts = { > diff --git a/include/hw/acpi/acpi.h b/include/hw/acpi/acpi.h > index 1f678b4..7a0a209 100644 > --- a/include/hw/acpi/acpi.h > +++ b/include/hw/acpi/acpi.h > @@ -172,6 +172,9 @@ void acpi_gpe_reset(ACPIREGS *ar); > void acpi_gpe_ioport_writeb(ACPIREGS *ar, uint32_t addr, uint32_t val); > uint32_t acpi_gpe_ioport_readb(ACPIREGS *ar, uint32_t addr); > > +void acpi_send_gpe_event(ACPIREGS *ar, qemu_irq irq, > + unsigned int hotplug_status); > + > void acpi_update_sci(ACPIREGS *acpi_regs, qemu_irq irq); > > /* acpi.c */