From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:34522) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1TmnXG-0007fD-75 for qemu-devel@nongnu.org; Sun, 23 Dec 2012 10:32:21 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1TmnXE-0007RD-1X for qemu-devel@nongnu.org; Sun, 23 Dec 2012 10:32:18 -0500 Received: from smtp1-g21.free.fr ([2a01:e0c:1:1599::10]:43016) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1TmnXD-0007Qx-FG for qemu-devel@nongnu.org; Sun, 23 Dec 2012 10:32:15 -0500 From: =?UTF-8?q?Herv=C3=A9=20Poussineau?= Date: Sun, 23 Dec 2012 16:32:43 +0100 Message-Id: <1356276769-7357-4-git-send-email-hpoussin@reactos.org> In-Reply-To: <1356276769-7357-1-git-send-email-hpoussin@reactos.org> References: <1356276769-7357-1-git-send-email-hpoussin@reactos.org> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: quoted-printable Subject: [Qemu-devel] [RFC 3/8] uhci: do not use old_portio-style callbacks List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: =?UTF-8?q?Andreas=20F=C3=A4rber?= , =?UTF-8?q?Herv=C3=A9=20Poussineau?= , Gerd Hoffmann Signed-off-by: Herv=C3=A9 Poussineau --- hw/usb/hcd-uhci.c | 43 +++++++++++++++++++++++++++++++++---------- 1 file changed, 33 insertions(+), 10 deletions(-) diff --git a/hw/usb/hcd-uhci.c b/hw/usb/hcd-uhci.c index d053791..cc47635 100644 --- a/hw/usb/hcd-uhci.c +++ b/hw/usb/hcd-uhci.c @@ -1213,18 +1213,41 @@ static void uhci_frame_timer(void *opaque) qemu_mod_timer(s->frame_timer, s->expire_time); } =20 -static const MemoryRegionPortio uhci_portio[] =3D { - { 0, 32, 2, .write =3D uhci_ioport_writew, }, - { 0, 32, 2, .read =3D uhci_ioport_readw, }, - { 0, 32, 4, .write =3D uhci_ioport_writel, }, - { 0, 32, 4, .read =3D uhci_ioport_readl, }, - { 0, 32, 1, .write =3D uhci_ioport_writeb, }, - { 0, 32, 1, .read =3D uhci_ioport_readb, }, - PORTIO_END_OF_LIST() -}; +static uint64_t uhci_ioport_read(void *opaque, hwaddr addr, unsigned int= size) +{ + switch (size) { + case 1: + return uhci_ioport_readb(opaque, (uint32_t)addr); + case 2: + return uhci_ioport_readw(opaque, (uint32_t)addr); + case 4: + return uhci_ioport_readl(opaque, (uint32_t)addr); + default: + return ~0UL; + } +} + +static void uhci_ioport_write(void *opaque, hwaddr addr, uint64_t data, + unsigned int size) +{ + switch (size) { + case 1: + uhci_ioport_writeb(opaque, (uint32_t)addr, (uint32_t)data); + break; + case 2: + uhci_ioport_writew(opaque, (uint32_t)addr, (uint32_t)data); + break; + case 4: + uhci_ioport_writel(opaque, (uint32_t)addr, (uint32_t)data); + break; + default: + break; + } +} =20 static const MemoryRegionOps uhci_ioport_ops =3D { - .old_portio =3D uhci_portio, + .read =3D uhci_ioport_read, + .write =3D uhci_ioport_write, }; =20 static USBPortOps uhci_port_ops =3D { --=20 1.7.10.4