aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGerd Hoffmann <kraxel@redhat.com>2009-09-10 11:43:29 +0200
committermalc <av1474@comtv.ru>2009-09-10 19:47:59 +0400
commit924f6d72d3787e56961498f8c97d13bf87c84a36 (patch)
tree41990b4318cf64638943b22e5b8957ff3b93dd50
parent787aa97a3eae76f14696ceab5555f06d784aeeea (diff)
qdev: add isa_create() function
Like isa_create_simple, but doesn't call qdev_init, so one can set properties after creating and before initializing the device. Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
-rw-r--r--hw/isa-bus.c15
-rw-r--r--hw/isa.h1
2 files changed, 14 insertions, 2 deletions
diff --git a/hw/isa-bus.c b/hw/isa-bus.c
index 3cc17b28f2..4ecc0f8399 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 4582ff90c0..655ad62c1d 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;