parallel: convert isa to qdev
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
907265dbb6
commit
021f067459
@ -945,7 +945,7 @@ void mips_malta_init (ram_addr_t ram_size,
|
|||||||
serial_init(0x3f8, isa_reserve_irq(4), 115200, serial_hds[0]);
|
serial_init(0x3f8, isa_reserve_irq(4), 115200, serial_hds[0]);
|
||||||
serial_init(0x2f8, isa_reserve_irq(3), 115200, serial_hds[1]);
|
serial_init(0x2f8, isa_reserve_irq(3), 115200, serial_hds[1]);
|
||||||
if (parallel_hds[0])
|
if (parallel_hds[0])
|
||||||
parallel_init(0x378, isa_reserve_irq(7), parallel_hds[0]);
|
parallel_init(0, parallel_hds[0]);
|
||||||
for(i = 0; i < MAX_FD; i++) {
|
for(i = 0; i < MAX_FD; i++) {
|
||||||
dinfo = drive_get(IF_FLOPPY, 0, i);
|
dinfo = drive_get(IF_FLOPPY, 0, i);
|
||||||
fd[i] = dinfo ? dinfo->bdrv : NULL;
|
fd[i] = dinfo ? dinfo->bdrv : NULL;
|
||||||
|
@ -78,6 +78,13 @@ struct ParallelState {
|
|||||||
int it_shift;
|
int it_shift;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
typedef struct ISAParallelState {
|
||||||
|
ISADevice dev;
|
||||||
|
uint32_t iobase;
|
||||||
|
uint32_t isairq;
|
||||||
|
ParallelState state;
|
||||||
|
} ISAParallelState;
|
||||||
|
|
||||||
static void parallel_update_irq(ParallelState *s)
|
static void parallel_update_irq(ParallelState *s)
|
||||||
{
|
{
|
||||||
if (s->irq_pending)
|
if (s->irq_pending)
|
||||||
@ -438,19 +445,23 @@ static void parallel_reset(void *opaque)
|
|||||||
s->last_read_offset = ~0U;
|
s->last_read_offset = ~0U;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If fd is zero, it means that the parallel device uses the console */
|
static int parallel_isa_initfn(ISADevice *dev)
|
||||||
ParallelState *parallel_init(int base, qemu_irq irq, CharDriverState *chr)
|
|
||||||
{
|
{
|
||||||
ParallelState *s;
|
ISAParallelState *isa = DO_UPCAST(ISAParallelState, dev, dev);
|
||||||
|
ParallelState *s = &isa->state;
|
||||||
|
int base = isa->iobase;
|
||||||
uint8_t dummy;
|
uint8_t dummy;
|
||||||
|
|
||||||
s = qemu_mallocz(sizeof(ParallelState));
|
if (!s->chr) {
|
||||||
s->irq = irq;
|
fprintf(stderr, "Can't create parallel device, empty char device\n");
|
||||||
s->chr = chr;
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
isa_init_irq(dev, &s->irq, isa->isairq);
|
||||||
parallel_reset(s);
|
parallel_reset(s);
|
||||||
qemu_register_reset(parallel_reset, s);
|
qemu_register_reset(parallel_reset, s);
|
||||||
|
|
||||||
if (qemu_chr_ioctl(chr, CHR_IOCTL_PP_READ_STATUS, &dummy) == 0) {
|
if (qemu_chr_ioctl(s->chr, CHR_IOCTL_PP_READ_STATUS, &dummy) == 0) {
|
||||||
s->hw_driver = 1;
|
s->hw_driver = 1;
|
||||||
s->status = dummy;
|
s->status = dummy;
|
||||||
}
|
}
|
||||||
@ -469,7 +480,22 @@ ParallelState *parallel_init(int base, qemu_irq irq, CharDriverState *chr)
|
|||||||
register_ioport_write(base, 8, 1, parallel_ioport_write_sw, s);
|
register_ioport_write(base, 8, 1, parallel_ioport_write_sw, s);
|
||||||
register_ioport_read(base, 8, 1, parallel_ioport_read_sw, s);
|
register_ioport_read(base, 8, 1, parallel_ioport_read_sw, s);
|
||||||
}
|
}
|
||||||
return s;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const int isa_parallel_io[MAX_PARALLEL_PORTS] = { 0x378, 0x278, 0x3bc };
|
||||||
|
|
||||||
|
ParallelState *parallel_init(int index, CharDriverState *chr)
|
||||||
|
{
|
||||||
|
ISADevice *dev;
|
||||||
|
|
||||||
|
dev = isa_create("isa-parallel");
|
||||||
|
qdev_prop_set_uint32(&dev->qdev, "iobase", isa_parallel_io[index]);
|
||||||
|
qdev_prop_set_uint32(&dev->qdev, "irq", 7);
|
||||||
|
qdev_prop_set_chr(&dev->qdev, "chardev", chr);
|
||||||
|
if (qdev_init(&dev->qdev) != 0)
|
||||||
|
return NULL;
|
||||||
|
return &DO_UPCAST(ISAParallelState, dev, dev)->state;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Memory mapped interface */
|
/* Memory mapped interface */
|
||||||
@ -547,3 +573,22 @@ ParallelState *parallel_mm_init(target_phys_addr_t base, int it_shift, qemu_irq
|
|||||||
cpu_register_physical_memory(base, 8 << it_shift, io_sw);
|
cpu_register_physical_memory(base, 8 << it_shift, io_sw);
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static ISADeviceInfo parallel_isa_info = {
|
||||||
|
.qdev.name = "isa-parallel",
|
||||||
|
.qdev.size = sizeof(ISAParallelState),
|
||||||
|
.init = parallel_isa_initfn,
|
||||||
|
.qdev.props = (Property[]) {
|
||||||
|
DEFINE_PROP_HEX32("iobase", ISAParallelState, iobase, 0x378),
|
||||||
|
DEFINE_PROP_UINT32("irq", ISAParallelState, isairq, 7),
|
||||||
|
DEFINE_PROP_CHR("chardev", ISAParallelState, state.chr),
|
||||||
|
DEFINE_PROP_END_OF_LIST(),
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static void parallel_register_devices(void)
|
||||||
|
{
|
||||||
|
isa_qdev_register(¶llel_isa_info);
|
||||||
|
}
|
||||||
|
|
||||||
|
device_init(parallel_register_devices)
|
||||||
|
3
hw/pc.c
3
hw/pc.c
@ -1340,8 +1340,7 @@ static void pc_init1(ram_addr_t ram_size,
|
|||||||
|
|
||||||
for(i = 0; i < MAX_PARALLEL_PORTS; i++) {
|
for(i = 0; i < MAX_PARALLEL_PORTS; i++) {
|
||||||
if (parallel_hds[i]) {
|
if (parallel_hds[i]) {
|
||||||
parallel_init(parallel_io[i], isa_reserve_irq(parallel_irq[i]),
|
parallel_init(i, parallel_hds[i]);
|
||||||
parallel_hds[i]);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
2
hw/pc.h
2
hw/pc.h
@ -16,7 +16,7 @@ SerialState *serial_mm_init (target_phys_addr_t base, int it_shift,
|
|||||||
/* parallel.c */
|
/* parallel.c */
|
||||||
|
|
||||||
typedef struct ParallelState ParallelState;
|
typedef struct ParallelState ParallelState;
|
||||||
ParallelState *parallel_init(int base, qemu_irq irq, CharDriverState *chr);
|
ParallelState *parallel_init(int index, CharDriverState *chr);
|
||||||
ParallelState *parallel_mm_init(target_phys_addr_t base, int it_shift, qemu_irq irq, CharDriverState *chr);
|
ParallelState *parallel_mm_init(target_phys_addr_t base, int it_shift, qemu_irq irq, CharDriverState *chr);
|
||||||
|
|
||||||
/* i8259.c */
|
/* i8259.c */
|
||||||
|
@ -610,8 +610,7 @@ static void sun4uv_init(ram_addr_t RAM_size,
|
|||||||
|
|
||||||
for(i = 0; i < MAX_PARALLEL_PORTS; i++) {
|
for(i = 0; i < MAX_PARALLEL_PORTS; i++) {
|
||||||
if (parallel_hds[i]) {
|
if (parallel_hds[i]) {
|
||||||
parallel_init(parallel_io[i], NULL/*parallel_irq[i]*/,
|
parallel_init(i, parallel_hds[i]);
|
||||||
parallel_hds[i]);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user