From patchwork Mon Aug 24 14:16:53 2009 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Juan Quintela X-Patchwork-Id: 31947 Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Received: from lists.gnu.org (lists.gnu.org [199.232.76.165]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (Client did not present a certificate) by bilbo.ozlabs.org (Postfix) with ESMTPS id 6F8E6B7B5F for ; Tue, 25 Aug 2009 00:42:19 +1000 (EST) Received: from localhost ([127.0.0.1]:47661 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1MfakN-0001Os-TZ for incoming@patchwork.ozlabs.org; Mon, 24 Aug 2009 10:42:11 -0400 Received: from mailman by lists.gnu.org with tmda-scanned (Exim 4.43) id 1MfaOX-0007a8-IA for qemu-devel@nongnu.org; Mon, 24 Aug 2009 10:19:38 -0400 Received: from exim by lists.gnu.org with spam-scanned (Exim 4.43) id 1MfaOS-0007Rq-My for qemu-devel@nongnu.org; Mon, 24 Aug 2009 10:19:36 -0400 Received: from [199.232.76.173] (port=41044 helo=monty-python.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1MfaOS-0007RW-HN for qemu-devel@nongnu.org; Mon, 24 Aug 2009 10:19:32 -0400 Received: from mx20.gnu.org ([199.232.41.8]:7001) by monty-python.gnu.org with esmtps (TLS-1.0:RSA_AES_256_CBC_SHA1:32) (Exim 4.60) (envelope-from ) id 1MfaOS-0000HO-41 for qemu-devel@nongnu.org; Mon, 24 Aug 2009 10:19:32 -0400 Received: from mx1.redhat.com ([209.132.183.28]) by mx20.gnu.org with esmtp (Exim 4.60) (envelope-from ) id 1MfaOR-0001Jh-CL for qemu-devel@nongnu.org; Mon, 24 Aug 2009 10:19:31 -0400 Received: from int-mx04.intmail.prod.int.phx2.redhat.com (int-mx04.intmail.prod.int.phx2.redhat.com [10.5.11.17]) by mx1.redhat.com (8.13.8/8.13.8) with ESMTP id n7OEJUVb023890 for ; Mon, 24 Aug 2009 10:19:30 -0400 Received: from localhost.localdomain (vpn1-4-157.ams2.redhat.com [10.36.4.157]) by int-mx04.intmail.prod.int.phx2.redhat.com (8.13.8/8.13.8) with ESMTP id n7OEJJYD029317; Mon, 24 Aug 2009 10:19:29 -0400 From: Juan Quintela To: qemu-devel@nongnu.org Date: Mon, 24 Aug 2009 16:16:53 +0200 Message-Id: <61e830d0e800d333c639d81ffcd0884a5bb1b1aa.1251122302.git.quintela@redhat.com> In-Reply-To: References: In-Reply-To: References: X-Scanned-By: MIMEDefang 2.67 on 10.5.11.17 X-Detected-Operating-System: by mx20.gnu.org: Genre and OS details not recognized. X-detected-operating-system: by monty-python.gnu.org: GNU/Linux 2.6, seldom 2.4 (older, 4) Subject: [Qemu-devel] [PATCH 08/13] Introduce PIIX3IrqState for piix3 irq's state X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: qemu-devel.nongnu.org List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org Errors-To: qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org Signed-off-by: Juan Quintela --- hw/piix_pci.c | 12 +++++++++--- 1 files changed, 9 insertions(+), 3 deletions(-) diff --git a/hw/piix_pci.c b/hw/piix_pci.c index 29bd92c..0443a1d 100644 --- a/hw/piix_pci.c +++ b/hw/piix_pci.c @@ -37,6 +37,10 @@ typedef struct PIIX3State { PCIDevice dev; } PIIX3State; +typedef struct PIIX3IrqState { + qemu_irq *pic; +} PIIX3IrqState; + struct PCII440FXState { PCIDevice dev; target_phys_addr_t isa_page_descs[384 / 4]; @@ -217,11 +221,13 @@ PCIBus *i440fx_init(PCII440FXState **pi440fx_state, qemu_irq *pic) PCIBus *b; PCIDevice *d; I440FXState *s; + PIIX3IrqState *irq_state = qemu_malloc(sizeof(*irq_state)); + irq_state->pic = pic; dev = qdev_create(NULL, "i440FX-pcihost"); s = FROM_SYSBUS(I440FXState, sysbus_from_qdev(dev)); b = pci_register_bus(&s->busdev.qdev, "pci.0", - piix3_set_irq, pci_slot_get_pirq, pic, 0, 4); + piix3_set_irq, pci_slot_get_pirq, irq_state, 0, 4); s->bus = b; qdev_init(dev); @@ -238,7 +244,7 @@ static PIIX3State *piix3_dev; static void piix3_set_irq(void *opaque, int irq_num, int level) { int i, pic_irq, pic_level; - qemu_irq *pic = opaque; + PIIX3IrqState *irq_state = opaque; pci_irq_levels[irq_num] = level; @@ -253,7 +259,7 @@ static void piix3_set_irq(void *opaque, int irq_num, int level) if (pic_irq == piix3_dev->dev.config[0x60 + i]) pic_level |= pci_irq_levels[i]; } - qemu_set_irq(pic[pic_irq], pic_level); + qemu_set_irq(irq_state->pic[pic_irq], pic_level); } }