Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 80d15a60 authored by Bartlomiej Zolnierkiewicz's avatar Bartlomiej Zolnierkiewicz
Browse files

ide: handle IDE_HFLAG[_FORCE]_LEGACY_IRQS in ide_pci_init_{one,two}()



Move handling of IDE_HFLAG[_FORCE]_LEGACY_IRQS from ide_init_port()
to ide_pci_init_{one,two}().

There should be no functional changes caused by this patch.

Signed-off-by: default avatarBartlomiej Zolnierkiewicz <bzolnier@gmail.com>
parent 1b166ae7
Loading
Loading
Loading
Loading
+0 −4
Original line number Diff line number Diff line
@@ -1183,10 +1183,6 @@ static void ide_init_port(ide_hwif_t *hwif, unsigned int port,
	if (d->init_iops)
		d->init_iops(hwif);

	if ((!hwif->irq && (d->host_flags & IDE_HFLAG_LEGACY_IRQS)) ||
	    (d->host_flags & IDE_HFLAG_FORCE_LEGACY_IRQS))
		hwif->irq = port ? 15 : 14;

	/* ->host_flags may be set by ->init_iops (or even earlier...) */
	hwif->host_flags |= d->host_flags;
	hwif->pio_mask = d->pio_mask;
+12 −0
Original line number Diff line number Diff line
@@ -570,6 +570,12 @@ int ide_pci_init_one(struct pci_dev *dev, const struct ide_port_info *d,
	/* fixup IRQ */
	hw[1].irq = hw[0].irq = ret;

	if ((ret == 0 && (d->host_flags & IDE_HFLAG_LEGACY_IRQS)) ||
	    (d->host_flags & IDE_HFLAG_FORCE_LEGACY_IRQS)) {
		hw[0].irq = 14;
		hw[1].irq = 15;
	}

	ret = ide_host_register(host, d, hws);
	if (ret)
		ide_host_free(host);
@@ -620,6 +626,12 @@ int ide_pci_init_two(struct pci_dev *dev1, struct pci_dev *dev2,

		/* fixup IRQ */
		hw[i*2 + 1].irq = hw[i*2].irq = ret;

		if ((ret == 0 && (d->host_flags & IDE_HFLAG_LEGACY_IRQS)) ||
		    (d->host_flags & IDE_HFLAG_FORCE_LEGACY_IRQS)) {
			hw[i*2].irq = 14;
			hw[i*2 + 1].irq = 15;
		}
	}

	ret = ide_host_register(host, d, hws);