On 2012-09-04 09:28, Julien Grall wrote: > This is the eighth version of patch series about ioport registration. > > 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 V5: > - Rebase on qemu upstream; > - Forget some ioport_register_* in acpi_piix4.c; > - Register 0x3b0 - 0x3df range for cirrus instead of ioport by ioport. > > Modifications between V5 and V6: > - Add read function on cirrus ioport (forget on the previous patch); > - Rework PM memory range handling; > - Fix PCI_BASE in acpi_piix4.c (wrong conversion during port); > - Rewrite isa_address_space_io to use ISA bus address space; > - Fix compilation in vt82c686.c. > > Modifications between V6 and V7: > - acpi_piix4: use memory_region_set_enabled instead of a boolean. I'm not > sure about this modification (adviced by Avi); > - Fix device endianness in acpi_piix4 (reported by Avi); > - Avoid dependencies between patches and reorder it (reported by Jan). > Some code moved from acpi_piix4 patch to smb/apm patches; > > Modifications between V7 and V8: > - Fix device endianness in smb patch, I forgot some on previous version; > - Register pm io region at initialization with default value instead > of at first call to pm_io_space_update (reported by Jan). > > Julien Grall (8): > isa: add isa_address_space_io > hw/apm.c: replace register_ioport* > smb: replace_register_ioport* > 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/acpi_piix4.c | 165 +++++++++++++++++++++++++++++++++++++++++----------- > hw/apm.c | 24 ++++++-- > hw/apm.h | 5 +- > hw/cirrus_vga.c | 50 ++++++++++------- > hw/dma.c | 108 +++++++++++++++++++++++------------ > hw/isa-bus.c | 9 +++ > 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, 341 insertions(+), 125 deletions(-) >
Was just testing v7, and it broke my Win7 guest under KVM. Need it for work now, will test v8 / bisect later. Jan -- Siemens AG, Corporate Technology, CT RTC ITP SDP-DE Corporate Competence Center Embedded Linux