From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:39025) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1T4G0v-0002oo-Po for qemu-devel@nongnu.org; Wed, 22 Aug 2012 14:50:51 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1T4G0q-00061O-Rf for qemu-devel@nongnu.org; Wed, 22 Aug 2012 14:50:49 -0400 Received: from smtp.citrix.com ([66.165.176.89]:14068) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1T4G0q-000618-Ll for qemu-devel@nongnu.org; Wed, 22 Aug 2012 14:50:44 -0400 From: Julien Grall Date: Wed, 22 Aug 2012 13:27:08 +0100 Message-ID: MIME-Version: 1.0 Content-Type: text/plain Subject: [Qemu-devel] [PATCH V5 0/8] memory: unifiy ioport registration List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: Julien Grall , avi@redhat.com, Stefano.Stabellini@eu.citrix.com This is the fifth version of patch series about ioport registration. The fourth version was sent few months ago (https://lists.gnu.org/archive/html/qemu-devel/2012-04/msg01396.html). Some part of QEMU still use register_ioport* functions to register ioport. These functions doesn't allow to use Memory Listener on it. Modifications between V1 and V2: - Remove the use of get_system_io. Instead of use isa and pci IO address space. - Avoid allocation of PortioList. Use the different device structure. - Still remove register_ioport* (hw/dma.c, hw/apm.c, hw/acpi_piix4.c). - Use MemoryRegion when we have only a range of ioport. - For some functions, add IO address space as argument. - Add isa_address_space_io function Modifications between V2 and V3: - Remove some register_ioport_* on hw/vt82c686.c. - Split smb ioport part in new patch. - Still replace MemoryRegion when we have only a range of ioport. - Fix read/write ioports prototype to be compliant with memory callback. Modifications between V3 and V4: - Fix compilation in hw/dma.c - Fix address conversion (hw/dma.c, hw/acpi_piix4.c) with MemorySection. Indeed the new version use offset from MemorySection start instead of 0. Modifications between V4 and V4: - Rebase on qemu upstream. - Forget some ioport_register_* in acpi_piix4.c. - Register 0x3b0 - 0x3df range for cirrus instead of ioport by ioport. Julien Grall (8): isa: add isa_address_space_io hw/acpi_piix4.c: replace register_ioport* hw/cirrus_vga.c: replace register_ioport* hw/serial.c: replace register_ioport* hw/pc.c: replace register_ioport* hw/dma.c: replace register_ioport* hw/apm.c: replace register_ioport* smb: replace_register_ioport* hw/acpi_piix4.c | 160 +++++++++++++++++++++++++++++++++++++++++------------ hw/apm.c | 24 ++++++-- hw/apm.h | 5 +- hw/cirrus_vga.c | 42 ++++++++------ hw/dma.c | 108 ++++++++++++++++++++++++------------ hw/isa-bus.c | 5 ++ hw/isa.h | 1 + hw/mips_mipssim.c | 3 +- hw/pc.c | 58 ++++++++++++++----- hw/pc.h | 2 +- hw/pm_smbus.c | 7 +- hw/pm_smbus.h | 6 +- hw/serial.c | 8 ++- hw/vt82c686.c | 20 ++++++- 14 files changed, 325 insertions(+), 124 deletions(-) -- Julien Grall