qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH v4 20/37] mips: use sysbus_mmio_get_region() instead of inter


From: Philippe Mathieu-Daudé
Subject: Re: [PATCH v4 20/37] mips: use sysbus_mmio_get_region() instead of internal fields
Date: Sun, 15 Dec 2019 06:39:20 +0100
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.2.2

On 11/20/19 4:24 PM, Marc-André Lureau wrote:
Register the memory region with sysbus_init_mmio() and look it up with
sysbus_mmio_get_region() to avoid accessing internal device fields.

Suggested-by: Peter Maydell <address@hidden>
Signed-off-by: Marc-André Lureau <address@hidden>
---
  hw/char/serial.c       | 1 +
  hw/mips/mips_mipssim.c | 3 ++-
  2 files changed, 3 insertions(+), 1 deletion(-)

diff --git a/hw/char/serial.c b/hw/char/serial.c
index 23f0b02516..02c545ff8c 100644
--- a/hw/char/serial.c
+++ b/hw/char/serial.c
@@ -993,6 +993,7 @@ static void serial_io_realize(DeviceState *dev, Error 
**errp)
      qdev_init_nofail(DEVICE(s));
memory_region_init_io(&s->io, NULL, &serial_io_ops, s, "serial", 8);
+    sysbus_init_mmio(SYS_BUS_DEVICE(sio), &s->io);
      sysbus_init_irq(SYS_BUS_DEVICE(sio), &s->irq);
  }
diff --git a/hw/mips/mips_mipssim.c b/hw/mips/mips_mipssim.c
index 2c2c7f25b2..84c03dd035 100644
--- a/hw/mips/mips_mipssim.c
+++ b/hw/mips/mips_mipssim.c
@@ -227,7 +227,8 @@ mips_mipssim_init(MachineState *machine)
          qdev_set_legacy_instance_id(dev, 0x3f8, 2);
          qdev_init_nofail(dev);
          sysbus_connect_irq(SYS_BUS_DEVICE(dev), 0, env->irq[4]);
-        sysbus_add_io(SYS_BUS_DEVICE(dev), 0x3f8, &SERIAL_IO(dev)->serial.io);
+        sysbus_add_io(SYS_BUS_DEVICE(dev), 0x3f8,
+                      sysbus_mmio_get_region(SYS_BUS_DEVICE(dev), 0));

TIL sysbus_add_io(), nice.
Reviewed-by: Philippe Mathieu-Daudé <address@hidden>

      }
if (nd_table[0].used)





reply via email to

[Prev in Thread] Current Thread [Next in Thread]