Add parallel memory mapped interface, by Herve Poussineau.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2988 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
parent
630530a652
commit
d60532ca8f
@ -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);
|
serial_mm_init(serial_base[i], 0, i8259[serial_irq[i]], serial_hds[i], 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (i = 0; i < MAX_PARALLEL_PORTS; i++) {
|
/* Parallel port */
|
||||||
if (parallel_hds[i]) {
|
if (parallel_hds[0]) parallel_mm_init(0x80008000, 0, i8259[1], parallel_hds[0]);
|
||||||
/* FIXME: memory mapped! parallel_init(0x80008000, i8259[17], parallel_hds[i]); */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Sound card */
|
/* Sound card */
|
||||||
/* FIXME: missing Jazz sound, IRQ 18 */
|
/* FIXME: missing Jazz sound, IRQ 18 */
|
||||||
|
100
hw/parallel.c
100
hw/parallel.c
@ -71,6 +71,9 @@ struct ParallelState {
|
|||||||
int hw_driver;
|
int hw_driver;
|
||||||
int epp_timeout;
|
int epp_timeout;
|
||||||
uint32_t last_read_offset; /* For debugging */
|
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)
|
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;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If fd is zero, it means that the parallel device uses the console */
|
static void parallel_reset(ParallelState *s, qemu_irq irq, CharDriverState *chr)
|
||||||
ParallelState *parallel_init(int base, qemu_irq irq, CharDriverState *chr)
|
|
||||||
{
|
{
|
||||||
ParallelState *s;
|
|
||||||
uint8_t dummy;
|
|
||||||
|
|
||||||
s = qemu_mallocz(sizeof(ParallelState));
|
|
||||||
if (!s)
|
|
||||||
return NULL;
|
|
||||||
s->datar = ~0;
|
s->datar = ~0;
|
||||||
s->dataw = ~0;
|
s->dataw = ~0;
|
||||||
s->status = PARA_STS_BUSY;
|
s->status = PARA_STS_BUSY;
|
||||||
@ -423,6 +419,18 @@ ParallelState *parallel_init(int base, qemu_irq irq, CharDriverState *chr)
|
|||||||
s->hw_driver = 0;
|
s->hw_driver = 0;
|
||||||
s->epp_timeout = 0;
|
s->epp_timeout = 0;
|
||||||
s->last_read_offset = ~0U;
|
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) {
|
if (qemu_chr_ioctl(chr, CHR_IOCTL_PP_READ_STATUS, &dummy) == 0) {
|
||||||
s->hw_driver = 1;
|
s->hw_driver = 1;
|
||||||
@ -445,3 +453,79 @@ ParallelState *parallel_init(int base, qemu_irq irq, CharDriverState *chr)
|
|||||||
}
|
}
|
||||||
return s;
|
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;
|
||||||
|
}
|
||||||
|
1
vl.h
1
vl.h
@ -1089,6 +1089,7 @@ void serial_mm_writel (void *opaque, target_phys_addr_t addr, uint32_t value);
|
|||||||
|
|
||||||
typedef struct ParallelState ParallelState;
|
typedef struct ParallelState ParallelState;
|
||||||
ParallelState *parallel_init(int base, qemu_irq irq, CharDriverState *chr);
|
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 */
|
/* i8259.c */
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user