]> git.proxmox.com Git - mirror_qemu.git/commitdiff
serial: Replace register_ioport_*
authorJulien Grall <julien.grall@citrix.com>
Wed, 19 Sep 2012 11:50:07 +0000 (12:50 +0100)
committerAndreas Färber <afaerber@suse.de>
Tue, 4 Dec 2012 13:50:22 +0000 (14:50 +0100)
Replace all register_ioport_*() with a MemoryRegion.
This permits to use the new Memory stuff like listeners.

For more flexibility, the IO address space is passed as an argument.

Signed-off-by: Julien Grall <julien.grall@citrix.com>
Acked-by: Avi Kivity <avi@redhat.com>
[AF: Rebased onto serial split]
Signed-off-by: Andreas Färber <afaerber@suse.de>
hw/mips_mipssim.c
hw/serial.c
hw/serial.h

index a95a3c1f1136f1eb69c1d5fe2779fa7985c19b45..20b5f1a58cd165007f90e811e4590f106b092157 100644 (file)
@@ -217,7 +217,8 @@ mips_mipssim_init(QEMUMachineInitArgs *args)
     /* A single 16450 sits at offset 0x3f8. It is attached to
        MIPS CPU INT2, which is interrupt 4. */
     if (serial_hds[0])
-        serial_init(0x3f8, env->irq[4], 115200, serial_hds[0]);
+        serial_init(0x3f8, env->irq[4], 115200, serial_hds[0],
+                    get_system_io());
 
     if (nd_table[0].used)
         /* MIPSnet uses the MIPS CPU INT0, which is interrupt 2. */
index 60283eab91babe935ced01c9bb9cfbb2f4f82f28..07a2a11931d39595d321425a9094a3c86ba3c2da 100644 (file)
@@ -718,7 +718,7 @@ const MemoryRegionOps serial_io_ops = {
 };
 
 SerialState *serial_init(int base, qemu_irq irq, int baudbase,
-                         CharDriverState *chr)
+                         CharDriverState *chr, MemoryRegion *system_io)
 {
     SerialState *s;
 
@@ -732,7 +732,7 @@ SerialState *serial_init(int base, qemu_irq irq, int baudbase,
     vmstate_register(NULL, base, &vmstate_serial, s);
 
     memory_region_init_io(&s->io, &serial_io_ops, s, "serial", 8);
-    memory_region_add_subregion(get_system_io(), base, &s->io);
+    memory_region_add_subregion(system_io, base, &s->io);
 
     return s;
 }
index f1e3c4aaa72ef7981b4c285ccb73a457f10909dd..ed1a5cd43e6e6e8f20ed1dd125ce7976b20372e7 100644 (file)
@@ -89,7 +89,7 @@ void serial_set_frequency(SerialState *s, uint32_t frequency);
 
 /* legacy pre qom */
 SerialState *serial_init(int base, qemu_irq irq, int baudbase,
-                         CharDriverState *chr);
+                         CharDriverState *chr, MemoryRegion *system_io);
 SerialState *serial_mm_init(MemoryRegion *address_space,
                             hwaddr base, int it_shift,
                             qemu_irq irq, int baudbase,