From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([140.186.70.92]:58596) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1QTcZl-0002br-Cu for qemu-devel@nongnu.org; Mon, 06 Jun 2011 12:22:50 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1QTcZj-00038A-6M for qemu-devel@nongnu.org; Mon, 06 Jun 2011 12:22:48 -0400 Received: from fmmailgate01.web.de ([217.72.192.221]:42881) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1QTcZi-00037n-En for qemu-devel@nongnu.org; Mon, 06 Jun 2011 12:22:46 -0400 From: =?UTF-8?q?Andreas=20F=C3=A4rber?= Date: Mon, 6 Jun 2011 18:20:51 +0200 Message-Id: <1307377259-41434-3-git-send-email-andreas.faerber@web.de> In-Reply-To: <1307377259-41434-2-git-send-email-andreas.faerber@web.de> References: <1307377259-41434-1-git-send-email-andreas.faerber@web.de> <1307377259-41434-2-git-send-email-andreas.faerber@web.de> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: andreas.faerber@web.de Content-Transfer-Encoding: quoted-printable Subject: [Qemu-devel] [RFC 02/10] isa: Allow to un-associate an IRQ 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?= , hpoussin@reactos.org, kraxel@redhat.com Signed-off-by: Andreas F=C3=A4rber --- hw/isa-bus.c | 14 ++++++++++++++ hw/isa.h | 1 + 2 files changed, 15 insertions(+), 0 deletions(-) diff --git a/hw/isa-bus.c b/hw/isa-bus.c index 46716ad..acccadb 100644 --- a/hw/isa-bus.c +++ b/hw/isa-bus.c @@ -80,6 +80,20 @@ void isa_init_irq(ISADevice *dev, qemu_irq *p, int isa= irq) dev->nirqs++; } =20 +void isa_discard_irq(ISADevice *dev, int isairq) +{ + int i, j; + for (i =3D 0; i < dev->nirqs; i++) { + if (dev->isairq[i] =3D=3D isairq) { + for (j =3D i + 1; j < dev->nirqs; j++) { + dev->isairq[j - 1] =3D dev->isairq[j]; + } + dev->nirqs--; + break; + } + } +} + static void isa_init_ioport_one(ISADevice *dev, uint16_t ioport) { assert(dev->nioports < ARRAY_SIZE(dev->ioports)); diff --git a/hw/isa.h b/hw/isa.h index 1b41a27..789d91c 100644 --- a/hw/isa.h +++ b/hw/isa.h @@ -28,6 +28,7 @@ ISABus *isa_bus_new(DeviceState *dev); void isa_bus_irqs(qemu_irq *irqs); qemu_irq isa_get_irq(int isairq); void isa_init_irq(ISADevice *dev, qemu_irq *p, int isairq); +void isa_discard_irq(ISADevice *dev, int isairq); void isa_init_ioport(ISADevice *dev, uint16_t ioport); void isa_init_ioport_range(ISADevice *dev, uint16_t start, uint16_t leng= th); void isa_discard_ioport_range(ISADevice *dev, uint16_t start, uint16_t l= ength); --=20 1.7.5.3