提交 ee951a37 编写于 作者: J Jan Kiszka 提交者: Aurelien Jarno

isa-bus: Remove bogus IRQ sharing check

Nothing prevented IRQ sharing on the ISA bus in principle. Not all
boards supported this, neither each and every card nor driver and OS.
Still, there existed valid IRQ sharing scenarios, (at least) two of them
can also be found in QEMU: >2 PC UARTs and the PREP IDE buses.

So remove this artificial restriction from our ISA model.
Signed-off-by: NJan Kiszka <jan.kiszka@siemens.com>
Signed-off-by: NAurelien Jarno <aurelien@aurel32.net>
上级 7096a96d
...@@ -713,7 +713,6 @@ static int hpet_init(SysBusDevice *dev) ...@@ -713,7 +713,6 @@ static int hpet_init(SysBusDevice *dev)
s->capability |= (s->num_timers - 1) << HPET_ID_NUM_TIM_SHIFT; s->capability |= (s->num_timers - 1) << HPET_ID_NUM_TIM_SHIFT;
s->capability |= ((HPET_CLK_PERIOD) << 32); s->capability |= ((HPET_CLK_PERIOD) << 32);
isa_reserve_irq(RTC_ISA_IRQ);
qdev_init_gpio_in(&dev->qdev, hpet_handle_rtc_irq, 1); qdev_init_gpio_in(&dev->qdev, hpet_handle_rtc_irq, 1);
/* HPET Area */ /* HPET Area */
......
...@@ -514,7 +514,7 @@ static int pit_initfn(ISADevice *dev) ...@@ -514,7 +514,7 @@ static int pit_initfn(ISADevice *dev)
s = &pit->channels[0]; s = &pit->channels[0];
/* the timer 0 is connected to an IRQ */ /* the timer 0 is connected to an IRQ */
s->irq_timer = qemu_new_timer(vm_clock, pit_irq_timer, s); s->irq_timer = qemu_new_timer(vm_clock, pit_irq_timer, s);
s->irq = isa_reserve_irq(pit->irq); s->irq = isa_get_irq(pit->irq);
register_ioport_write(pit->iobase, 4, 1, pit_ioport_write, pit); register_ioport_write(pit->iobase, 4, 1, pit_ioport_write, pit);
register_ioport_read(pit->iobase, 3, 1, pit_ioport_read, pit); register_ioport_read(pit->iobase, 3, 1, pit_ioport_read, pit);
......
...@@ -122,7 +122,7 @@ static void pci_piix_init_ports(PCIIDEState *d) { ...@@ -122,7 +122,7 @@ static void pci_piix_init_ports(PCIIDEState *d) {
for (i = 0; i < 2; i++) { for (i = 0; i < 2; i++) {
ide_bus_new(&d->bus[i], &d->dev.qdev, i); ide_bus_new(&d->bus[i], &d->dev.qdev, i);
ide_init_ioport(&d->bus[i], port_info[i].iobase, port_info[i].iobase2); ide_init_ioport(&d->bus[i], port_info[i].iobase, port_info[i].iobase2);
ide_init2(&d->bus[i], isa_reserve_irq(port_info[i].isairq)); ide_init2(&d->bus[i], isa_get_irq(port_info[i].isairq));
bmdma_init(&d->bus[i], &d->bmdma[i]); bmdma_init(&d->bus[i], &d->bmdma[i]);
d->bmdma[i].bus = &d->bus[i]; d->bmdma[i].bus = &d->bus[i];
......
...@@ -145,7 +145,7 @@ static void vt82c686b_init_ports(PCIIDEState *d) { ...@@ -145,7 +145,7 @@ static void vt82c686b_init_ports(PCIIDEState *d) {
for (i = 0; i < 2; i++) { for (i = 0; i < 2; i++) {
ide_bus_new(&d->bus[i], &d->dev.qdev, i); ide_bus_new(&d->bus[i], &d->dev.qdev, i);
ide_init_ioport(&d->bus[i], port_info[i].iobase, port_info[i].iobase2); ide_init_ioport(&d->bus[i], port_info[i].iobase, port_info[i].iobase2);
ide_init2(&d->bus[i], isa_reserve_irq(port_info[i].isairq)); ide_init2(&d->bus[i], isa_get_irq(port_info[i].isairq));
bmdma_init(&d->bus[i], &d->bmdma[i]); bmdma_init(&d->bus[i], &d->bmdma[i]);
d->bmdma[i].bus = &d->bus[i]; d->bmdma[i].bus = &d->bus[i];
......
...@@ -25,7 +25,6 @@ ...@@ -25,7 +25,6 @@
struct ISABus { struct ISABus {
BusState qbus; BusState qbus;
qemu_irq *irqs; qemu_irq *irqs;
uint32_t assigned;
}; };
static ISABus *isabus; static ISABus *isabus;
target_phys_addr_t isa_mem_base = 0; target_phys_addr_t isa_mem_base = 0;
...@@ -61,33 +60,24 @@ void isa_bus_irqs(qemu_irq *irqs) ...@@ -61,33 +60,24 @@ void isa_bus_irqs(qemu_irq *irqs)
} }
/* /*
* isa_reserve_irq() reserves the ISA irq and returns the corresponding * isa_get_irq() returns the corresponding qemu_irq entry for the i8259.
* qemu_irq entry for the i8259.
* *
* This function is only for special cases such as the 'ferr', and * This function is only for special cases such as the 'ferr', and
* temporary use for normal devices until they are converted to qdev. * temporary use for normal devices until they are converted to qdev.
*/ */
qemu_irq isa_reserve_irq(int isairq) qemu_irq isa_get_irq(int isairq)
{ {
if (isairq < 0 || isairq > 15) { if (isairq < 0 || isairq > 15) {
hw_error("isa irq %d invalid", isairq); hw_error("isa irq %d invalid", isairq);
} }
if (isabus->assigned & (1 << isairq)) {
hw_error("isa irq %d already assigned", isairq);
}
isabus->assigned |= (1 << isairq);
return isabus->irqs[isairq]; return isabus->irqs[isairq];
} }
void isa_init_irq(ISADevice *dev, qemu_irq *p, int isairq) void isa_init_irq(ISADevice *dev, qemu_irq *p, int isairq)
{ {
assert(dev->nirqs < ARRAY_SIZE(dev->isairq)); assert(dev->nirqs < ARRAY_SIZE(dev->isairq));
if (isabus->assigned & (1 << isairq)) {
hw_error("isa irq %d already assigned", isairq);
}
isabus->assigned |= (1 << isairq);
dev->isairq[dev->nirqs] = isairq; dev->isairq[dev->nirqs] = isairq;
*p = isabus->irqs[isairq]; *p = isa_get_irq(isairq);
dev->nirqs++; dev->nirqs++;
} }
......
...@@ -26,7 +26,7 @@ struct ISADeviceInfo { ...@@ -26,7 +26,7 @@ struct ISADeviceInfo {
ISABus *isa_bus_new(DeviceState *dev); ISABus *isa_bus_new(DeviceState *dev);
void isa_bus_irqs(qemu_irq *irqs); void isa_bus_irqs(qemu_irq *irqs);
qemu_irq isa_reserve_irq(int isairq); qemu_irq isa_get_irq(int isairq);
void isa_init_irq(ISADevice *dev, qemu_irq *p, int isairq); void isa_init_irq(ISADevice *dev, qemu_irq *p, int isairq);
void isa_init_ioport(ISADevice *dev, uint16_t ioport); void isa_init_ioport(ISADevice *dev, uint16_t ioport);
void isa_init_ioport_range(ISADevice *dev, uint16_t start, uint16_t length); void isa_init_ioport_range(ISADevice *dev, uint16_t start, uint16_t length);
......
...@@ -919,7 +919,7 @@ void mips_malta_init (ram_addr_t ram_size, ...@@ -919,7 +919,7 @@ void mips_malta_init (ram_addr_t ram_size,
isa_bus_irqs(i8259); isa_bus_irqs(i8259);
pci_piix4_ide_init(pci_bus, hd, piix4_devfn + 1); pci_piix4_ide_init(pci_bus, hd, piix4_devfn + 1);
usb_uhci_piix4_init(pci_bus, piix4_devfn + 2); usb_uhci_piix4_init(pci_bus, piix4_devfn + 2);
smbus = piix4_pm_init(pci_bus, piix4_devfn + 3, 0x1100, isa_reserve_irq(9), smbus = piix4_pm_init(pci_bus, piix4_devfn + 3, 0x1100, isa_get_irq(9),
NULL, NULL, 0); NULL, NULL, 0);
eeprom_buf = qemu_mallocz(8 * 256); /* XXX: make this persistent */ eeprom_buf = qemu_mallocz(8 * 256); /* XXX: make this persistent */
for (i = 0; i < 8; i++) { for (i = 0; i < 8; i++) {
......
...@@ -113,7 +113,7 @@ static void pc_init1(ram_addr_t ram_size, ...@@ -113,7 +113,7 @@ static void pc_init1(ram_addr_t ram_size,
} }
isa_bus_irqs(isa_irq); isa_bus_irqs(isa_irq);
pc_register_ferr_irq(isa_reserve_irq(13)); pc_register_ferr_irq(isa_get_irq(13));
pc_vga_init(pci_enabled? pci_bus: NULL); pc_vga_init(pci_enabled? pci_bus: NULL);
...@@ -169,7 +169,7 @@ static void pc_init1(ram_addr_t ram_size, ...@@ -169,7 +169,7 @@ static void pc_init1(ram_addr_t ram_size,
smi_irq = qemu_allocate_irqs(pc_acpi_smi_interrupt, first_cpu, 1); smi_irq = qemu_allocate_irqs(pc_acpi_smi_interrupt, first_cpu, 1);
/* TODO: Populate SPD eeprom data. */ /* TODO: Populate SPD eeprom data. */
smbus = piix4_pm_init(pci_bus, piix3_devfn + 3, 0xb100, smbus = piix4_pm_init(pci_bus, piix3_devfn + 3, 0xb100,
isa_reserve_irq(9), *cmos_s3, *smi_irq, isa_get_irq(9), *cmos_s3, *smi_irq,
kvm_enabled()); kvm_enabled());
for (i = 0; i < 8; i++) { for (i = 0; i < 8; i++) {
DeviceState *eeprom; DeviceState *eeprom;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册