mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-02 23:33:54 -06:00
hw/isa/superio: Factor out the floppy disc controller code from pc87312.c
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Message-Id: <20180308223946.26784-13-f4bug@amsat.org> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
cd9526ab7c
commit
6f6695b136
5 changed files with 58 additions and 32 deletions
|
@ -11,7 +11,10 @@
|
|||
*/
|
||||
#include "qemu/osdep.h"
|
||||
#include "qemu/error-report.h"
|
||||
#include "qapi/error.h"
|
||||
#include "sysemu/sysemu.h"
|
||||
#include "sysemu/block-backend.h"
|
||||
#include "sysemu/blockdev.h"
|
||||
#include "chardev/char.h"
|
||||
#include "hw/isa/superio.h"
|
||||
#include "hw/char/serial.h"
|
||||
|
@ -25,6 +28,7 @@ static void isa_superio_realize(DeviceState *dev, Error **errp)
|
|||
ISADevice *isa;
|
||||
DeviceState *d;
|
||||
Chardev *chr;
|
||||
DriveInfo *drive;
|
||||
char *name;
|
||||
int i;
|
||||
|
||||
|
@ -107,6 +111,38 @@ static void isa_superio_realize(DeviceState *dev, Error **errp)
|
|||
g_free(name);
|
||||
}
|
||||
}
|
||||
|
||||
/* Floppy disc */
|
||||
if (!k->floppy.is_enabled || k->floppy.is_enabled(sio, 0)) {
|
||||
isa = isa_create(bus, "isa-fdc");
|
||||
d = DEVICE(isa);
|
||||
if (k->floppy.get_iobase) {
|
||||
qdev_prop_set_uint32(d, "iobase", k->floppy.get_iobase(sio, 0));
|
||||
}
|
||||
if (k->floppy.get_irq) {
|
||||
qdev_prop_set_uint32(d, "irq", k->floppy.get_irq(sio, 0));
|
||||
}
|
||||
/* FIXME use a qdev drive property instead of drive_get() */
|
||||
drive = drive_get(IF_FLOPPY, 0, 0);
|
||||
if (drive != NULL) {
|
||||
qdev_prop_set_drive(d, "driveA", blk_by_legacy_dinfo(drive),
|
||||
&error_fatal);
|
||||
}
|
||||
/* FIXME use a qdev drive property instead of drive_get() */
|
||||
drive = drive_get(IF_FLOPPY, 0, 1);
|
||||
if (drive != NULL) {
|
||||
qdev_prop_set_drive(d, "driveB", blk_by_legacy_dinfo(drive),
|
||||
&error_fatal);
|
||||
}
|
||||
qdev_init_nofail(d);
|
||||
sio->floppy = isa;
|
||||
trace_superio_create_floppy(0,
|
||||
k->floppy.get_iobase ?
|
||||
k->floppy.get_iobase(sio, 0) : -1,
|
||||
k->floppy.get_irq ?
|
||||
k->floppy.get_irq(sio, 0) : -1);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
static void isa_superio_class_init(ObjectClass *oc, void *data)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue