mirror of https://github.com/xqemu/xqemu.git
serial: Convert serial_mm_init to MemoryRegion
Signed-off-by: Richard Henderson <rth@twiddle.net> Signed-off-by: Avi Kivity <avi@redhat.com>
This commit is contained in:
parent
06dccb82df
commit
8e8ffc44e8
145
hw/serial.c
145
hw/serial.c
|
@ -28,6 +28,7 @@
|
||||||
#include "pc.h"
|
#include "pc.h"
|
||||||
#include "qemu-timer.h"
|
#include "qemu-timer.h"
|
||||||
#include "sysemu.h"
|
#include "sysemu.h"
|
||||||
|
#include "exec-memory.h"
|
||||||
|
|
||||||
//#define DEBUG_SERIAL
|
//#define DEBUG_SERIAL
|
||||||
|
|
||||||
|
@ -153,11 +154,11 @@ struct SerialState {
|
||||||
int poll_msl;
|
int poll_msl;
|
||||||
|
|
||||||
struct QEMUTimer *modem_status_poll;
|
struct QEMUTimer *modem_status_poll;
|
||||||
|
MemoryRegion io;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct ISASerialState {
|
typedef struct ISASerialState {
|
||||||
ISADevice dev;
|
ISADevice dev;
|
||||||
MemoryRegion io;
|
|
||||||
uint32_t index;
|
uint32_t index;
|
||||||
uint32_t iobase;
|
uint32_t iobase;
|
||||||
uint32_t isairq;
|
uint32_t isairq;
|
||||||
|
@ -786,8 +787,8 @@ static int serial_isa_initfn(ISADevice *dev)
|
||||||
serial_init_core(s);
|
serial_init_core(s);
|
||||||
qdev_set_legacy_instance_id(&dev->qdev, isa->iobase, 3);
|
qdev_set_legacy_instance_id(&dev->qdev, isa->iobase, 3);
|
||||||
|
|
||||||
memory_region_init_io(&isa->io, &serial_io_ops, s, "serial", 8);
|
memory_region_init_io(&s->io, &serial_io_ops, s, "serial", 8);
|
||||||
isa_register_ioport(dev, &isa->io, isa->iobase);
|
isa_register_ioport(dev, &s->io, isa->iobase);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -821,115 +822,37 @@ SerialState *serial_init(int base, qemu_irq irq, int baudbase,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Memory mapped interface */
|
/* Memory mapped interface */
|
||||||
static uint32_t serial_mm_readb(void *opaque, target_phys_addr_t addr)
|
static uint64_t serial_mm_read(void *opaque, target_phys_addr_t addr,
|
||||||
|
unsigned size)
|
||||||
{
|
{
|
||||||
SerialState *s = opaque;
|
SerialState *s = opaque;
|
||||||
|
return serial_ioport_read(s, addr >> s->it_shift);
|
||||||
return serial_ioport_read(s, addr >> s->it_shift) & 0xFF;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void serial_mm_writeb(void *opaque, target_phys_addr_t addr,
|
static void serial_mm_write(void *opaque, target_phys_addr_t addr,
|
||||||
uint32_t value)
|
uint64_t value, unsigned size)
|
||||||
{
|
{
|
||||||
SerialState *s = opaque;
|
SerialState *s = opaque;
|
||||||
|
value &= ~0u >> (32 - (size * 8));
|
||||||
serial_ioport_write(s, addr >> s->it_shift, value & 0xFF);
|
|
||||||
}
|
|
||||||
|
|
||||||
static uint32_t serial_mm_readw_be(void *opaque, target_phys_addr_t addr)
|
|
||||||
{
|
|
||||||
SerialState *s = opaque;
|
|
||||||
uint32_t val;
|
|
||||||
|
|
||||||
val = serial_ioport_read(s, addr >> s->it_shift) & 0xFFFF;
|
|
||||||
val = bswap16(val);
|
|
||||||
return val;
|
|
||||||
}
|
|
||||||
|
|
||||||
static uint32_t serial_mm_readw_le(void *opaque, target_phys_addr_t addr)
|
|
||||||
{
|
|
||||||
SerialState *s = opaque;
|
|
||||||
uint32_t val;
|
|
||||||
|
|
||||||
val = serial_ioport_read(s, addr >> s->it_shift) & 0xFFFF;
|
|
||||||
return val;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void serial_mm_writew_be(void *opaque, target_phys_addr_t addr,
|
|
||||||
uint32_t value)
|
|
||||||
{
|
|
||||||
SerialState *s = opaque;
|
|
||||||
|
|
||||||
value = bswap16(value);
|
|
||||||
serial_ioport_write(s, addr >> s->it_shift, value & 0xFFFF);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void serial_mm_writew_le(void *opaque, target_phys_addr_t addr,
|
|
||||||
uint32_t value)
|
|
||||||
{
|
|
||||||
SerialState *s = opaque;
|
|
||||||
|
|
||||||
serial_ioport_write(s, addr >> s->it_shift, value & 0xFFFF);
|
|
||||||
}
|
|
||||||
|
|
||||||
static uint32_t serial_mm_readl_be(void *opaque, target_phys_addr_t addr)
|
|
||||||
{
|
|
||||||
SerialState *s = opaque;
|
|
||||||
uint32_t val;
|
|
||||||
|
|
||||||
val = serial_ioport_read(s, addr >> s->it_shift);
|
|
||||||
val = bswap32(val);
|
|
||||||
return val;
|
|
||||||
}
|
|
||||||
|
|
||||||
static uint32_t serial_mm_readl_le(void *opaque, target_phys_addr_t addr)
|
|
||||||
{
|
|
||||||
SerialState *s = opaque;
|
|
||||||
uint32_t val;
|
|
||||||
|
|
||||||
val = serial_ioport_read(s, addr >> s->it_shift);
|
|
||||||
return val;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void serial_mm_writel_be(void *opaque, target_phys_addr_t addr,
|
|
||||||
uint32_t value)
|
|
||||||
{
|
|
||||||
SerialState *s = opaque;
|
|
||||||
|
|
||||||
value = bswap32(value);
|
|
||||||
serial_ioport_write(s, addr >> s->it_shift, value);
|
serial_ioport_write(s, addr >> s->it_shift, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void serial_mm_writel_le(void *opaque, target_phys_addr_t addr,
|
static const MemoryRegionOps serial_mm_ops[3] = {
|
||||||
uint32_t value)
|
[DEVICE_NATIVE_ENDIAN] = {
|
||||||
{
|
.read = serial_mm_read,
|
||||||
SerialState *s = opaque;
|
.write = serial_mm_write,
|
||||||
|
.endianness = DEVICE_NATIVE_ENDIAN,
|
||||||
serial_ioport_write(s, addr >> s->it_shift, value);
|
},
|
||||||
}
|
[DEVICE_LITTLE_ENDIAN] = {
|
||||||
|
.read = serial_mm_read,
|
||||||
static CPUReadMemoryFunc * const serial_mm_read_be[] = {
|
.write = serial_mm_write,
|
||||||
&serial_mm_readb,
|
.endianness = DEVICE_LITTLE_ENDIAN,
|
||||||
&serial_mm_readw_be,
|
},
|
||||||
&serial_mm_readl_be,
|
[DEVICE_BIG_ENDIAN] = {
|
||||||
};
|
.read = serial_mm_read,
|
||||||
|
.write = serial_mm_write,
|
||||||
static CPUWriteMemoryFunc * const serial_mm_write_be[] = {
|
.endianness = DEVICE_BIG_ENDIAN,
|
||||||
&serial_mm_writeb,
|
},
|
||||||
&serial_mm_writew_be,
|
|
||||||
&serial_mm_writel_be,
|
|
||||||
};
|
|
||||||
|
|
||||||
static CPUReadMemoryFunc * const serial_mm_read_le[] = {
|
|
||||||
&serial_mm_readb,
|
|
||||||
&serial_mm_readw_le,
|
|
||||||
&serial_mm_readl_le,
|
|
||||||
};
|
|
||||||
|
|
||||||
static CPUWriteMemoryFunc * const serial_mm_write_le[] = {
|
|
||||||
&serial_mm_writeb,
|
|
||||||
&serial_mm_writew_le,
|
|
||||||
&serial_mm_writel_le,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
SerialState *serial_mm_init (target_phys_addr_t base, int it_shift,
|
SerialState *serial_mm_init (target_phys_addr_t base, int it_shift,
|
||||||
|
@ -938,7 +861,7 @@ SerialState *serial_mm_init (target_phys_addr_t base, int it_shift,
|
||||||
int be)
|
int be)
|
||||||
{
|
{
|
||||||
SerialState *s;
|
SerialState *s;
|
||||||
int s_io_memory;
|
enum device_endian end;
|
||||||
|
|
||||||
s = g_malloc0(sizeof(SerialState));
|
s = g_malloc0(sizeof(SerialState));
|
||||||
|
|
||||||
|
@ -950,17 +873,11 @@ SerialState *serial_mm_init (target_phys_addr_t base, int it_shift,
|
||||||
serial_init_core(s);
|
serial_init_core(s);
|
||||||
vmstate_register(NULL, base, &vmstate_serial, s);
|
vmstate_register(NULL, base, &vmstate_serial, s);
|
||||||
|
|
||||||
|
end = (be ? DEVICE_BIG_ENDIAN : DEVICE_LITTLE_ENDIAN);
|
||||||
|
memory_region_init_io(&s->io, &serial_mm_ops[end], s,
|
||||||
|
"serial", 8 << it_shift);
|
||||||
if (ioregister) {
|
if (ioregister) {
|
||||||
if (be) {
|
memory_region_add_subregion(get_system_memory(), base, &s->io);
|
||||||
s_io_memory = cpu_register_io_memory(serial_mm_read_be,
|
|
||||||
serial_mm_write_be, s,
|
|
||||||
DEVICE_NATIVE_ENDIAN);
|
|
||||||
} else {
|
|
||||||
s_io_memory = cpu_register_io_memory(serial_mm_read_le,
|
|
||||||
serial_mm_write_le, s,
|
|
||||||
DEVICE_NATIVE_ENDIAN);
|
|
||||||
}
|
|
||||||
cpu_register_physical_memory(base, 8 << it_shift, s_io_memory);
|
|
||||||
}
|
}
|
||||||
serial_update_msl(s);
|
serial_update_msl(s);
|
||||||
return s;
|
return s;
|
||||||
|
|
Loading…
Reference in New Issue