diff --git a/hw/isa-bus.c b/hw/isa-bus.c index 3cc17b28f2e1389c4764b2be146aed1eb485bfb0..4ecc0f839967056d76838a0d82334e8395eb8211 100644 --- a/hw/isa-bus.c +++ b/hw/isa-bus.c @@ -109,7 +109,7 @@ void isa_qdev_register(ISADeviceInfo *info) qdev_register(&info->qdev); } -ISADevice *isa_create_simple(const char *name) +ISADevice *isa_create(const char *name) { DeviceState *dev; @@ -118,10 +118,21 @@ ISADevice *isa_create_simple(const char *name) return NULL; } dev = qdev_create(&isabus->qbus, name); - qdev_init(dev); return DO_UPCAST(ISADevice, qdev, dev); } +ISADevice *isa_create_simple(const char *name) +{ + ISADevice *dev; + + dev = isa_create(name); + if (qdev_init(&dev->qdev) != 0) { + qdev_free(&dev->qdev); + return NULL; + } + return dev; +} + static void isabus_dev_print(Monitor *mon, DeviceState *dev, int indent) { ISADevice *d = DO_UPCAST(ISADevice, qdev, dev); diff --git a/hw/isa.h b/hw/isa.h index 4582ff90c0a90116d31d87760e99cf0796d4c0dd..655ad62c1d8464ff84d96f651692ce76855d8862 100644 --- a/hw/isa.h +++ b/hw/isa.h @@ -27,6 +27,7 @@ void isa_bus_irqs(qemu_irq *irqs); qemu_irq isa_reserve_irq(int isairq); void isa_init_irq(ISADevice *dev, qemu_irq *p, int isairq); void isa_qdev_register(ISADeviceInfo *info); +ISADevice *isa_create(const char *name); ISADevice *isa_create_simple(const char *name); extern target_phys_addr_t isa_mem_base;