[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [RFC v5 78/86] sh_pci: convert to memory API
From: |
Avi Kivity |
Subject: |
[Qemu-devel] [RFC v5 78/86] sh_pci: convert to memory API |
Date: |
Wed, 20 Jul 2011 19:50:28 +0300 |
Signed-off-by: Avi Kivity <address@hidden>
---
hw/sh_pci.c | 63 +++++++++++++++++++++++++++++++++++++++-------------------
1 files changed, 42 insertions(+), 21 deletions(-)
diff --git a/hw/sh_pci.c b/hw/sh_pci.c
index cd86501..76061bb 100644
--- a/hw/sh_pci.c
+++ b/hw/sh_pci.c
@@ -33,13 +33,16 @@ typedef struct SHPCIState {
PCIBus *bus;
PCIDevice *dev;
qemu_irq irq[4];
- int memconfig;
+ MemoryRegion memconfig_p4;
+ MemoryRegion memconfig_a7;
+ MemoryRegion isa;
uint32_t par;
uint32_t mbr;
uint32_t iobr;
} SHPCIState;
-static void sh_pci_reg_write (void *p, target_phys_addr_t addr, uint32_t val)
+static void sh_pci_reg_write (void *p, target_phys_addr_t addr, uint64_t val,
+ unsigned size)
{
SHPCIState *pcic = p;
switch(addr) {
@@ -54,10 +57,10 @@ static void sh_pci_reg_write (void *p, target_phys_addr_t
addr, uint32_t val)
break;
case 0x1c8:
if ((val & 0xfffc0000) != (pcic->iobr & 0xfffc0000)) {
- cpu_register_physical_memory(pcic->iobr & 0xfffc0000, 0x40000,
- IO_MEM_UNASSIGNED);
+ memory_region_del_subregion(get_system_memory(), &pcic->isa);
pcic->iobr = val & 0xfffc0001;
- isa_mmio_init(pcic->iobr & 0xfffc0000, 0x40000);
+ memory_region_add_subregion(get_system_memory(),
+ pcic->iobr & 0xfffc0000, &pcic->isa);
}
break;
case 0x220:
@@ -66,7 +69,8 @@ static void sh_pci_reg_write (void *p, target_phys_addr_t
addr, uint32_t val)
}
}
-static uint32_t sh_pci_reg_read (void *p, target_phys_addr_t addr)
+static uint64_t sh_pci_reg_read (void *p, target_phys_addr_t addr,
+ unsigned size)
{
SHPCIState *pcic = p;
switch(addr) {
@@ -84,14 +88,14 @@ static uint32_t sh_pci_reg_read (void *p,
target_phys_addr_t addr)
return 0;
}
-typedef struct {
- CPUReadMemoryFunc * const r[3];
- CPUWriteMemoryFunc * const w[3];
-} MemOp;
-
-static MemOp sh_pci_reg = {
- { NULL, NULL, sh_pci_reg_read },
- { NULL, NULL, sh_pci_reg_write },
+static const MemoryRegionOps sh_pci_reg_ops = {
+ .read = sh_pci_reg_read,
+ .write = sh_pci_reg_write,
+ .endianness = DEVICE_NATIVE_ENDIAN,
+ .valid = {
+ .min_access_size = 4,
+ .max_access_size = 4,
+ },
};
static int sh_pci_map_irq(PCIDevice *d, int irq_num)
@@ -110,11 +114,23 @@ static void sh_pci_map(SysBusDevice *dev,
target_phys_addr_t base)
{
SHPCIState *s = FROM_SYSBUS(SHPCIState, dev);
- cpu_register_physical_memory(P4ADDR(base), 0x224, s->memconfig);
- cpu_register_physical_memory(A7ADDR(base), 0x224, s->memconfig);
-
+ memory_region_add_subregion(get_system_memory(),
+ P4ADDR(base),
+ &s->memconfig_p4);
+ memory_region_add_subregion(get_system_memory(),
+ A7ADDR(base),
+ &s->memconfig_a7);
s->iobr = 0xfe240000;
- isa_mmio_init(s->iobr, 0x40000);
+ memory_region_add_subregion(get_system_memory(), s->iobr, &s->isa);
+}
+
+static void sh_pci_unmap(SysBusDevice *dev, target_phys_addr_t base)
+{
+ SHPCIState *s = FROM_SYSBUS(SHPCIState, dev);
+
+ memory_region_del_subregion(get_system_memory(), &s->memconfig_p4);
+ memory_region_del_subregion(get_system_memory(), &s->memconfig_a7);
+ memory_region_del_subregion(get_system_memory(), &s->isa);
}
static int sh_pci_init_device(SysBusDevice *dev)
@@ -132,9 +148,14 @@ static int sh_pci_init_device(SysBusDevice *dev)
get_system_memory(),
get_system_io(),
PCI_DEVFN(0, 0), 4);
- s->memconfig = cpu_register_io_memory(sh_pci_reg.r, sh_pci_reg.w,
- s, DEVICE_NATIVE_ENDIAN);
- sysbus_init_mmio_cb(dev, 0x224, sh_pci_map);
+ memory_region_init_io(&s->memconfig_p4, &sh_pci_reg_ops, s,
+ "sh_pci", 0x224);
+ memory_region_init_alias(&s->memconfig_a7, "sh_pci.2", &s->memconfig_a7,
+ 0, 0x224);
+ isa_mmio_setup(&s->isa, 0x40000);
+ sysbus_init_mmio_cb2(dev, sh_pci_map, sh_pci_unmap);
+ sysbus_init_mmio_region(dev, &s->memconfig_a7);
+ sysbus_init_mmio_region(dev, &s->isa);
s->dev = pci_create_simple(s->bus, PCI_DEVFN(0, 0), "sh_pci_host");
return 0;
}
--
1.7.5.3
- [Qemu-devel] [RFC v5 42/86] virtio-pci: convert to memory API, (continued)
- [Qemu-devel] [RFC v5 42/86] virtio-pci: convert to memory API, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 31/86] Integrate I/O memory regions into qemu, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 24/86] vmsvga: don't remember pci BAR address in callback any more, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 33/86] pci: pass I/O address space to new PCI bus, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 20/86] pci: add MemoryRegion based BAR management API, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 21/86] sysbus: add MemoryRegion based memory management API, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 84/86] pci: add pci_address_space(), Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 03/86] memory: implement dirty tracking, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 66/86] arm_sysctl: convert to memory API, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 14/86] exec.c: initialize memory map, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 78/86] sh_pci: convert to memory API,
Avi Kivity <=
- [Qemu-devel] [RFC v5 62/86] Introduce QEMU_NEW(), Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 38/86] eepro100: convert to memory API, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 30/86] cirrus: simplify linear framebuffer access functions, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 23/86] pci: add API to get a BAR's mapped address, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 36/86] ac97: convert to memory API, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 76/86] stellaris_enet: convert to memory API, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 72/86] onenand: convert to memory API, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 32/86] exec.c: fix initialization of system I/O memory region, Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 60/86] pci: rename pci_register_bar_region() to pci_register_bar(), Avi Kivity, 2011/07/20
- [Qemu-devel] [RFC v5 06/86] memory: abstract address space operations, Avi Kivity, 2011/07/20