|
@@ -51,7 +51,7 @@ static void isa_superio_realize(DeviceState *dev, Error **errp)
|
|
} else {
|
|
} else {
|
|
name = g_strdup_printf("parallel%d", i);
|
|
name = g_strdup_printf("parallel%d", i);
|
|
}
|
|
}
|
|
- isa = isa_create(bus, "isa-parallel");
|
|
|
|
|
|
+ isa = isa_new("isa-parallel");
|
|
d = DEVICE(isa);
|
|
d = DEVICE(isa);
|
|
qdev_prop_set_uint32(d, "index", i);
|
|
qdev_prop_set_uint32(d, "index", i);
|
|
if (k->parallel.get_iobase) {
|
|
if (k->parallel.get_iobase) {
|
|
@@ -63,7 +63,7 @@ static void isa_superio_realize(DeviceState *dev, Error **errp)
|
|
}
|
|
}
|
|
qdev_prop_set_chr(d, "chardev", chr);
|
|
qdev_prop_set_chr(d, "chardev", chr);
|
|
object_property_add_child(OBJECT(dev), name, OBJECT(isa));
|
|
object_property_add_child(OBJECT(dev), name, OBJECT(isa));
|
|
- qdev_init_nofail(d);
|
|
|
|
|
|
+ isa_realize_and_unref(isa, bus, &error_fatal);
|
|
sio->parallel[i] = isa;
|
|
sio->parallel[i] = isa;
|
|
trace_superio_create_parallel(i,
|
|
trace_superio_create_parallel(i,
|
|
k->parallel.get_iobase ?
|
|
k->parallel.get_iobase ?
|
|
@@ -90,7 +90,7 @@ static void isa_superio_realize(DeviceState *dev, Error **errp)
|
|
} else {
|
|
} else {
|
|
name = g_strdup_printf("serial%d", i);
|
|
name = g_strdup_printf("serial%d", i);
|
|
}
|
|
}
|
|
- isa = isa_create(bus, TYPE_ISA_SERIAL);
|
|
|
|
|
|
+ isa = isa_new(TYPE_ISA_SERIAL);
|
|
d = DEVICE(isa);
|
|
d = DEVICE(isa);
|
|
qdev_prop_set_uint32(d, "index", i);
|
|
qdev_prop_set_uint32(d, "index", i);
|
|
if (k->serial.get_iobase) {
|
|
if (k->serial.get_iobase) {
|
|
@@ -102,7 +102,7 @@ static void isa_superio_realize(DeviceState *dev, Error **errp)
|
|
}
|
|
}
|
|
qdev_prop_set_chr(d, "chardev", chr);
|
|
qdev_prop_set_chr(d, "chardev", chr);
|
|
object_property_add_child(OBJECT(dev), name, OBJECT(isa));
|
|
object_property_add_child(OBJECT(dev), name, OBJECT(isa));
|
|
- qdev_init_nofail(d);
|
|
|
|
|
|
+ isa_realize_and_unref(isa, bus, &error_fatal);
|
|
sio->serial[i] = isa;
|
|
sio->serial[i] = isa;
|
|
trace_superio_create_serial(i,
|
|
trace_superio_create_serial(i,
|
|
k->serial.get_iobase ?
|
|
k->serial.get_iobase ?
|
|
@@ -115,7 +115,7 @@ static void isa_superio_realize(DeviceState *dev, Error **errp)
|
|
|
|
|
|
/* Floppy disc */
|
|
/* Floppy disc */
|
|
if (!k->floppy.is_enabled || k->floppy.is_enabled(sio, 0)) {
|
|
if (!k->floppy.is_enabled || k->floppy.is_enabled(sio, 0)) {
|
|
- isa = isa_create(bus, "isa-fdc");
|
|
|
|
|
|
+ isa = isa_new("isa-fdc");
|
|
d = DEVICE(isa);
|
|
d = DEVICE(isa);
|
|
if (k->floppy.get_iobase) {
|
|
if (k->floppy.get_iobase) {
|
|
qdev_prop_set_uint32(d, "iobase", k->floppy.get_iobase(sio, 0));
|
|
qdev_prop_set_uint32(d, "iobase", k->floppy.get_iobase(sio, 0));
|
|
@@ -136,7 +136,7 @@ static void isa_superio_realize(DeviceState *dev, Error **errp)
|
|
&error_fatal);
|
|
&error_fatal);
|
|
}
|
|
}
|
|
object_property_add_child(OBJECT(sio), "isa-fdc", OBJECT(isa));
|
|
object_property_add_child(OBJECT(sio), "isa-fdc", OBJECT(isa));
|
|
- qdev_init_nofail(d);
|
|
|
|
|
|
+ isa_realize_and_unref(isa, bus, &error_fatal);
|
|
sio->floppy = isa;
|
|
sio->floppy = isa;
|
|
trace_superio_create_floppy(0,
|
|
trace_superio_create_floppy(0,
|
|
k->floppy.get_iobase ?
|
|
k->floppy.get_iobase ?
|
|
@@ -146,14 +146,14 @@ static void isa_superio_realize(DeviceState *dev, Error **errp)
|
|
}
|
|
}
|
|
|
|
|
|
/* Keyboard, mouse */
|
|
/* Keyboard, mouse */
|
|
- isa = isa_create(bus, TYPE_I8042);
|
|
|
|
|
|
+ isa = isa_new(TYPE_I8042);
|
|
object_property_add_child(OBJECT(sio), TYPE_I8042, OBJECT(isa));
|
|
object_property_add_child(OBJECT(sio), TYPE_I8042, OBJECT(isa));
|
|
- qdev_init_nofail(DEVICE(isa));
|
|
|
|
|
|
+ isa_realize_and_unref(isa, bus, &error_fatal);
|
|
sio->kbc = isa;
|
|
sio->kbc = isa;
|
|
|
|
|
|
/* IDE */
|
|
/* IDE */
|
|
if (k->ide.count && (!k->ide.is_enabled || k->ide.is_enabled(sio, 0))) {
|
|
if (k->ide.count && (!k->ide.is_enabled || k->ide.is_enabled(sio, 0))) {
|
|
- isa = isa_create(bus, "isa-ide");
|
|
|
|
|
|
+ isa = isa_new("isa-ide");
|
|
d = DEVICE(isa);
|
|
d = DEVICE(isa);
|
|
if (k->ide.get_iobase) {
|
|
if (k->ide.get_iobase) {
|
|
qdev_prop_set_uint32(d, "iobase", k->ide.get_iobase(sio, 0));
|
|
qdev_prop_set_uint32(d, "iobase", k->ide.get_iobase(sio, 0));
|
|
@@ -164,7 +164,7 @@ static void isa_superio_realize(DeviceState *dev, Error **errp)
|
|
if (k->ide.get_irq) {
|
|
if (k->ide.get_irq) {
|
|
qdev_prop_set_uint32(d, "irq", k->ide.get_irq(sio, 0));
|
|
qdev_prop_set_uint32(d, "irq", k->ide.get_irq(sio, 0));
|
|
}
|
|
}
|
|
- qdev_init_nofail(d);
|
|
|
|
|
|
+ isa_realize_and_unref(isa, bus, &error_fatal);
|
|
object_property_add_child(OBJECT(sio), "isa-ide", OBJECT(isa));
|
|
object_property_add_child(OBJECT(sio), "isa-ide", OBJECT(isa));
|
|
sio->ide = isa;
|
|
sio->ide = isa;
|
|
trace_superio_create_ide(0,
|
|
trace_superio_create_ide(0,
|