rtl8139: convert PIO to new memory api read/write
Signed-off-by: Alexander Graf <agraf@suse.de>
This commit is contained in:
parent
d540bfe0e7
commit
1bebb0ad17
78
hw/rtl8139.c
78
hw/rtl8139.c
@ -3187,38 +3187,6 @@ static uint32_t rtl8139_io_readl(void *opaque, uint8_t addr)
|
|||||||
|
|
||||||
/* */
|
/* */
|
||||||
|
|
||||||
static void rtl8139_ioport_writeb(void *opaque, uint32_t addr, uint32_t val)
|
|
||||||
{
|
|
||||||
rtl8139_io_writeb(opaque, addr & 0xFF, val);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void rtl8139_ioport_writew(void *opaque, uint32_t addr, uint32_t val)
|
|
||||||
{
|
|
||||||
rtl8139_io_writew(opaque, addr & 0xFF, val);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void rtl8139_ioport_writel(void *opaque, uint32_t addr, uint32_t val)
|
|
||||||
{
|
|
||||||
rtl8139_io_writel(opaque, addr & 0xFF, val);
|
|
||||||
}
|
|
||||||
|
|
||||||
static uint32_t rtl8139_ioport_readb(void *opaque, uint32_t addr)
|
|
||||||
{
|
|
||||||
return rtl8139_io_readb(opaque, addr & 0xFF);
|
|
||||||
}
|
|
||||||
|
|
||||||
static uint32_t rtl8139_ioport_readw(void *opaque, uint32_t addr)
|
|
||||||
{
|
|
||||||
return rtl8139_io_readw(opaque, addr & 0xFF);
|
|
||||||
}
|
|
||||||
|
|
||||||
static uint32_t rtl8139_ioport_readl(void *opaque, uint32_t addr)
|
|
||||||
{
|
|
||||||
return rtl8139_io_readl(opaque, addr & 0xFF);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* */
|
|
||||||
|
|
||||||
static void rtl8139_mmio_writeb(void *opaque, hwaddr addr, uint32_t val)
|
static void rtl8139_mmio_writeb(void *opaque, hwaddr addr, uint32_t val)
|
||||||
{
|
{
|
||||||
rtl8139_io_writeb(opaque, addr & 0xFF, val);
|
rtl8139_io_writeb(opaque, addr & 0xFF, val);
|
||||||
@ -3386,18 +3354,44 @@ static const VMStateDescription vmstate_rtl8139 = {
|
|||||||
/***********************************************************/
|
/***********************************************************/
|
||||||
/* PCI RTL8139 definitions */
|
/* PCI RTL8139 definitions */
|
||||||
|
|
||||||
static const MemoryRegionPortio rtl8139_portio[] = {
|
static void rtl8139_ioport_write(void *opaque, hwaddr addr,
|
||||||
{ 0, 0x100, 1, .read = rtl8139_ioport_readb, },
|
uint64_t val, unsigned size)
|
||||||
{ 0, 0x100, 1, .write = rtl8139_ioport_writeb, },
|
{
|
||||||
{ 0, 0x100, 2, .read = rtl8139_ioport_readw, },
|
switch (size) {
|
||||||
{ 0, 0x100, 2, .write = rtl8139_ioport_writew, },
|
case 1:
|
||||||
{ 0, 0x100, 4, .read = rtl8139_ioport_readl, },
|
rtl8139_io_writeb(opaque, addr, val);
|
||||||
{ 0, 0x100, 4, .write = rtl8139_ioport_writel, },
|
break;
|
||||||
PORTIO_END_OF_LIST()
|
case 2:
|
||||||
};
|
rtl8139_io_writew(opaque, addr, val);
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
rtl8139_io_writel(opaque, addr, val);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint64_t rtl8139_ioport_read(void *opaque, hwaddr addr,
|
||||||
|
unsigned size)
|
||||||
|
{
|
||||||
|
switch (size) {
|
||||||
|
case 1:
|
||||||
|
return rtl8139_io_readb(opaque, addr);
|
||||||
|
case 2:
|
||||||
|
return rtl8139_io_readw(opaque, addr);
|
||||||
|
case 4:
|
||||||
|
return rtl8139_io_readl(opaque, addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
static const MemoryRegionOps rtl8139_io_ops = {
|
static const MemoryRegionOps rtl8139_io_ops = {
|
||||||
.old_portio = rtl8139_portio,
|
.read = rtl8139_ioport_read,
|
||||||
|
.write = rtl8139_ioport_write,
|
||||||
|
.impl = {
|
||||||
|
.min_access_size = 1,
|
||||||
|
.max_access_size = 4,
|
||||||
|
},
|
||||||
.endianness = DEVICE_LITTLE_ENDIAN,
|
.endianness = DEVICE_LITTLE_ENDIAN,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user