|
@@ -1241,12 +1241,16 @@ int ahci_host_activate(struct ata_host *host, int irq, unsigned int n_msis)
|
|
|
for (i = 0; i < host->n_ports; i++) {
|
|
|
struct ahci_port_priv *pp = host->ports[i]->private_data;
|
|
|
|
|
|
- /* pp is NULL for dummy ports */
|
|
|
- if (pp)
|
|
|
- rc = devm_request_threaded_irq(host->dev,
|
|
|
- irq + i, ahci_hw_interrupt,
|
|
|
- ahci_thread_fn, IRQF_SHARED,
|
|
|
- pp->irq_desc, host->ports[i]);
|
|
|
+ /* Do not receive interrupts sent by dummy ports */
|
|
|
+ if (!pp) {
|
|
|
+ disable_irq(irq + i);
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+
|
|
|
+ rc = devm_request_threaded_irq(host->dev, irq + i,
|
|
|
+ ahci_hw_interrupt,
|
|
|
+ ahci_thread_fn, IRQF_SHARED,
|
|
|
+ pp->irq_desc, host->ports[i]);
|
|
|
if (rc)
|
|
|
goto out_free_irqs;
|
|
|
}
|