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

Commit 4031826b authored by Tejun Heo's avatar Tejun Heo Committed by Jeff Garzik
Browse files

libata: fix assigned IRQ reporting



host->irq and host->irq2 should be set before ata_host_register() for
IRQ reporting to work.  Move up host->irq assignment in
ata_host_activate() and add it to ata_pci_init_one() native path and
pata_cs5520.

The port info printing in ata_host_register() doesn't fit all the
different controllers.  It should probably be moved out to LLDs with
some helpers in the future.

Signed-off-by: default avatarTejun Heo <htejun@gmail.com>
Signed-off-by: default avatarJeff Garzik <jeff@garzik.org>
parent aa2e09da
Loading
Loading
Loading
Loading
+3 −3
Original line number Diff line number Diff line
@@ -6423,14 +6423,14 @@ int ata_host_activate(struct ata_host *host, int irq,
	if (rc)
		return rc;

	/* Used to print device info at probe */
	host->irq = irq;

	rc = ata_host_register(host, sht);
	/* if failed, just free the IRQ and leave ports alone */
	if (rc)
		devm_free_irq(host->dev, irq, host);

	/* Used to print device info at probe */
	host->irq = irq;

	return rc;
}

+3 −2
Original line number Diff line number Diff line
@@ -1065,10 +1065,11 @@ int ata_pci_init_one(struct pci_dev *pdev,
	if (rc)
		goto err_out;

	if (!legacy_mode)
	if (!legacy_mode) {
		rc = devm_request_irq(dev, pdev->irq, pi->port_ops->irq_handler,
				      IRQF_SHARED, DRV_NAME, host);
	else {
		host->irq = pdev->irq;
	} else {
		irq_handler_t handler[2] = { host->ops->irq_handler,
					     host->ops->irq_handler };
		unsigned int irq_flags[2] = { IRQF_SHARED, IRQF_SHARED };
+5 −0
Original line number Diff line number Diff line
@@ -284,6 +284,11 @@ static int __devinit cs5520_init_one(struct pci_dev *pdev, const struct pci_devi
				      ata_interrupt, 0, DRV_NAME, host);
		if (rc)
			return rc;

		if (i == 0)
			host->irq = irq[0];
		else
			host->irq2 = irq[1];
	}

	return ata_host_register(host, &cs5520_sht);