diff options
author | ths <ths@c046a42c-6fe2-441c-8c8c-71466251a162> | 2007-06-18 18:55:46 +0000 |
---|---|---|
committer | ths <ths@c046a42c-6fe2-441c-8c8c-71466251a162> | 2007-06-18 18:55:46 +0000 |
commit | d60532ca8f551d226b2a1cab46fb4d6611ee0ea8 (patch) | |
tree | e5983b5186ecf7329399444fbcaf7219678ef00c | |
parent | 630530a6529bc3da9ab8aead7053dc753cb9ac77 (diff) |
Add parallel memory mapped interface, by Herve Poussineau.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2988 c046a42c-6fe2-441c-8c8c-71466251a162
-rw-r--r-- | hw/mips_pica61.c | 7 | ||||
-rw-r--r-- | hw/parallel.c | 100 | ||||
-rw-r--r-- | vl.h | 1 |
3 files changed, 95 insertions, 13 deletions
diff --git a/hw/mips_pica61.c b/hw/mips_pica61.c index 2925b69cc0..17c7a0f173 100644 --- a/hw/mips_pica61.c +++ b/hw/mips_pica61.c @@ -151,11 +151,8 @@ void mips_pica61_init (int ram_size, int vga_ram_size, int boot_device, serial_mm_init(serial_base[i], 0, i8259[serial_irq[i]], serial_hds[i], 1); } } - for (i = 0; i < MAX_PARALLEL_PORTS; i++) { - if (parallel_hds[i]) { - /* FIXME: memory mapped! parallel_init(0x80008000, i8259[17], parallel_hds[i]); */ - } - } + /* Parallel port */ + if (parallel_hds[0]) parallel_mm_init(0x80008000, 0, i8259[1], parallel_hds[0]); /* Sound card */ /* FIXME: missing Jazz sound, IRQ 18 */ diff --git a/hw/parallel.c b/hw/parallel.c index e8e533bc74..f05daf3c33 100644 --- a/hw/parallel.c +++ b/hw/parallel.c @@ -71,6 +71,9 @@ struct ParallelState { int hw_driver; int epp_timeout; uint32_t last_read_offset; /* For debugging */ + /* Memory-mapped interface */ + target_phys_addr_t base; + int it_shift; }; static void parallel_update_irq(ParallelState *s) @@ -400,15 +403,8 @@ static uint32_t parallel_ioport_ecp_read(void *opaque, uint32_t addr) return ret; } -/* If fd is zero, it means that the parallel device uses the console */ -ParallelState *parallel_init(int base, qemu_irq irq, CharDriverState *chr) +static void parallel_reset(ParallelState *s, qemu_irq irq, CharDriverState *chr) { - ParallelState *s; - uint8_t dummy; - - s = qemu_mallocz(sizeof(ParallelState)); - if (!s) - return NULL; s->datar = ~0; s->dataw = ~0; s->status = PARA_STS_BUSY; @@ -423,6 +419,18 @@ ParallelState *parallel_init(int base, qemu_irq irq, CharDriverState *chr) s->hw_driver = 0; s->epp_timeout = 0; s->last_read_offset = ~0U; +} + +/* If fd is zero, it means that the parallel device uses the console */ +ParallelState *parallel_init(int base, qemu_irq irq, CharDriverState *chr) +{ + ParallelState *s; + uint8_t dummy; + + s = qemu_mallocz(sizeof(ParallelState)); + if (!s) + return NULL; + parallel_reset(s, irq, chr); if (qemu_chr_ioctl(chr, CHR_IOCTL_PP_READ_STATUS, &dummy) == 0) { s->hw_driver = 1; @@ -445,3 +453,79 @@ ParallelState *parallel_init(int base, qemu_irq irq, CharDriverState *chr) } return s; } + +/* Memory mapped interface */ +uint32_t parallel_mm_readb (void *opaque, target_phys_addr_t addr) +{ + ParallelState *s = opaque; + + return parallel_ioport_read_sw(s, (addr - s->base) >> s->it_shift) & 0xFF; +} + +void parallel_mm_writeb (void *opaque, + target_phys_addr_t addr, uint32_t value) +{ + ParallelState *s = opaque; + + parallel_ioport_write_sw(s, (addr - s->base) >> s->it_shift, value & 0xFF); +} + +uint32_t parallel_mm_readw (void *opaque, target_phys_addr_t addr) +{ + ParallelState *s = opaque; + + return parallel_ioport_read_sw(s, (addr - s->base) >> s->it_shift) & 0xFFFF; +} + +void parallel_mm_writew (void *opaque, + target_phys_addr_t addr, uint32_t value) +{ + ParallelState *s = opaque; + + parallel_ioport_write_sw(s, (addr - s->base) >> s->it_shift, value & 0xFFFF); +} + +uint32_t parallel_mm_readl (void *opaque, target_phys_addr_t addr) +{ + ParallelState *s = opaque; + + return parallel_ioport_read_sw(s, (addr - s->base) >> s->it_shift); +} + +void parallel_mm_writel (void *opaque, + target_phys_addr_t addr, uint32_t value) +{ + ParallelState *s = opaque; + + parallel_ioport_write_sw(s, (addr - s->base) >> s->it_shift, value); +} + +static CPUReadMemoryFunc *parallel_mm_read_sw[] = { + ¶llel_mm_readb, + ¶llel_mm_readw, + ¶llel_mm_readl, +}; + +static CPUWriteMemoryFunc *parallel_mm_write_sw[] = { + ¶llel_mm_writeb, + ¶llel_mm_writew, + ¶llel_mm_writel, +}; + +/* If fd is zero, it means that the parallel device uses the console */ +ParallelState *parallel_mm_init(target_phys_addr_t base, int it_shift, qemu_irq irq, CharDriverState *chr) +{ + ParallelState *s; + int io_sw; + + s = qemu_mallocz(sizeof(ParallelState)); + if (!s) + return NULL; + parallel_reset(s, irq, chr); + s->base = base; + s->it_shift = it_shift; + + io_sw = cpu_register_io_memory(0, parallel_mm_read_sw, parallel_mm_write_sw, s); + cpu_register_physical_memory(base, 8 << it_shift, io_sw); + return s; +} @@ -1089,6 +1089,7 @@ void serial_mm_writel (void *opaque, target_phys_addr_t addr, uint32_t value); typedef struct ParallelState ParallelState; ParallelState *parallel_init(int base, qemu_irq irq, CharDriverState *chr); +ParallelState *parallel_mm_init(target_phys_addr_t base, int it_shift, qemu_irq irq, CharDriverState *chr); /* i8259.c */ |