From 9d5e77a22f1b8b502a11aa6288334c2787d8dbc8 Mon Sep 17 00:00:00 2001 From: Isaku Yamahata Date: Thu, 18 Jun 2009 19:57:00 +0900 Subject: [PATCH] acpi.c: make qemu_system_device_hot_add piix independent. introruce piix4_device_hot_add() for piix4 specific code and make qemu_system_device_hot_add() generic. Signed-off-by: Isaku Yamahata Signed-off-by: Anthony Liguori --- hw/acpi.c | 20 ++++++++++++++++++-- hw/pc.c | 2 +- hw/pc.h | 7 +++++-- sysemu.h | 3 ++- 4 files changed, 26 insertions(+), 6 deletions(-) diff --git a/hw/acpi.c b/hw/acpi.c index fccae69dd6..5928fe74d5 100644 --- a/hw/acpi.c +++ b/hw/acpi.c @@ -714,7 +714,9 @@ static void pciej_write(void *opaque, uint32_t addr, uint32_t val) #endif } -void qemu_system_hot_add_init(void) +static void piix4_device_hot_add(int bus, int slot, int state); + +void piix4_acpi_system_hot_add_init(void) { register_ioport_write(GPE_BASE, 4, 1, gpe_writeb, &gpe); register_ioport_read(GPE_BASE, 4, 1, gpe_readb, &gpe); @@ -724,6 +726,8 @@ void qemu_system_hot_add_init(void) register_ioport_write(PCI_EJ_BASE, 4, 4, pciej_write, NULL); register_ioport_read(PCI_EJ_BASE, 4, 4, pciej_read, NULL); + + qemu_system_device_hot_add_register(piix4_device_hot_add); } static void enable_device(struct pci_status *p, struct gpe_regs *g, int slot) @@ -738,7 +742,7 @@ static void disable_device(struct pci_status *p, struct gpe_regs *g, int slot) p->down |= (1 << slot); } -void qemu_system_device_hot_add(int bus, int slot, int state) +static void piix4_device_hot_add(int bus, int slot, int state) { pci0_status.up = 0; pci0_status.down = 0; @@ -752,6 +756,18 @@ void qemu_system_device_hot_add(int bus, int slot, int state) } } +static qemu_system_device_hot_add_t device_hot_add_callback; +void qemu_system_device_hot_add_register(qemu_system_device_hot_add_t callback) +{ + device_hot_add_callback = callback; +} + +void qemu_system_device_hot_add(int pcibus, int slot, int state) +{ + if (device_hot_add_callback) + device_hot_add_callback(pcibus, slot, state); +} + struct acpi_table_header { char signature [4]; /* ACPI signature (4 ASCII characters) */ diff --git a/hw/pc.c b/hw/pc.c index 3521d29ae5..4515b024ca 100644 --- a/hw/pc.c +++ b/hw/pc.c @@ -1081,7 +1081,7 @@ static void pc_init1(ram_addr_t ram_size, pci_nic_init(pci_bus, nd, -1, "ne2k_pci"); } - qemu_system_hot_add_init(); + piix4_acpi_system_hot_add_init(); if (drive_get_max_bus(IF_IDE) >= MAX_IDE_BUS) { fprintf(stderr, "qemu: too many IDE bus\n"); diff --git a/hw/pc.h b/hw/pc.h index 0afffa2caa..9fbae20763 100644 --- a/hw/pc.h +++ b/hw/pc.h @@ -108,11 +108,14 @@ extern int acpi_enabled; extern char *acpi_tables; extern size_t acpi_tables_len; +void acpi_bios_init(void); +int acpi_table_add(const char *table_desc); + +/* acpi_piix.c */ i2c_bus *piix4_pm_init(PCIBus *bus, int devfn, uint32_t smb_io_base, qemu_irq sci_irq); void piix4_smbus_register_device(SMBusDevice *dev, uint8_t addr); -void acpi_bios_init(void); -int acpi_table_add(const char *table_desc); +void piix4_acpi_system_hot_add_init(void); /* hpet.c */ extern int no_hpet; diff --git a/sysemu.h b/sysemu.h index fe24415cd7..403b35ed3a 100644 --- a/sysemu.h +++ b/sysemu.h @@ -194,7 +194,8 @@ extern int drive_add(const char *file, const char *fmt, ...); extern int drive_init(struct drive_opt *arg, int snapshot, void *machine); /* acpi */ -void qemu_system_hot_add_init(void); +typedef void (*qemu_system_device_hot_add_t)(int pcibus, int slot, int state); +void qemu_system_device_hot_add_register(qemu_system_device_hot_add_t callback); void qemu_system_device_hot_add(int pcibus, int slot, int state); /* device-hotplug */