aboutsummaryrefslogtreecommitdiff
path: root/hw/ide
diff options
context:
space:
mode:
authorMark Cave-Ayland <mark.cave-ayland@ilande.co.uk>2020-03-13 08:24:44 +0000
committerJohn Snow <jsnow@redhat.com>2020-03-16 21:08:21 -0400
commit1a519323d3e8425f0cf58fc85a346237edf8aeac (patch)
tree3ebdd46fbf11f921d3f98b0a796b63f1e5522fe5 /hw/ide
parent20042479810511895d94f2f6ec8455fe0d0a2ce3 (diff)
downloadqemu-1a519323d3e8425f0cf58fc85a346237edf8aeac.zip
qemu-1a519323d3e8425f0cf58fc85a346237edf8aeac.tar.gz
qemu-1a519323d3e8425f0cf58fc85a346237edf8aeac.tar.bz2
via-ide: always use legacy IRQ 14/15 routing
The existing code uses fixed PCI IRQ routing on IRQ 14 rather than legacy IRQ 14/15 routing as documented in the datasheet. With the changes in this patchset guest OSs now correctly detect and configure the VIA controller in legacy IRQ routing mode, allowing the incorrect fixed PCI IRQ routing to be removed. Note that this fixed legacy IRQ 14/15 routing is identical to similar behaviour in the early PIIX IDE controllers. Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk> Tested-by: BALATON Zoltan <balaton@eik.bme.hu> Signed-off-by: BALATON Zoltan <balaton@eik.bme.hu> Message-id: 20200313082444.2439-8-mark.cave-ayland@ilande.co.uk Signed-off-by: John Snow <jsnow@redhat.com>
Diffstat (limited to 'hw/ide')
-rw-r--r--hw/ide/via.c5
1 files changed, 1 insertions, 4 deletions
diff --git a/hw/ide/via.c b/hw/ide/via.c
index 3c4d474..8de4945 100644
--- a/hw/ide/via.c
+++ b/hw/ide/via.c
@@ -113,10 +113,7 @@ static void via_ide_set_irq(void *opaque, int n, int level)
}
level = (d->config[0x70] & 0x80) || (d->config[0x78] & 0x80);
- n = pci_get_byte(d->config + PCI_INTERRUPT_LINE);
- if (n) {
- qemu_set_irq(isa_get_irq(NULL, n), level);
- }
+ qemu_set_irq(isa_get_irq(NULL, 14 + n), level);
}
static void via_ide_reset(DeviceState *dev)