aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi
diff options
context:
space:
mode:
authorTejun Heo <htejun@gmail.com>2005-10-05 22:43:29 -0400
committerJeff Garzik <jgarzik@pobox.com>2005-10-06 05:51:24 -0400
commitad6e90f6d0c4243cc35e07e2681a3323af533ce4 (patch)
tree3f9af49242301e69b43e1bb151d173f2152cf310 /drivers/scsi
parent012e060c95e547eceea4a12c6f58592473bf4011 (diff)
[PATCH] sil24: ignore non-error exception irqs
01_sil24_ignore-non-error-exception-irqs.patch Do not error-finish commands for non-error exception irqs - just ignore them. This is taken from Edward's driver. Signed-off-by: Tejun Heo <htejun@gmail.com> sata_sil24.c | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) Signed-off-by: Jeff Garzik <jgarzik@pobox.com>
Diffstat (limited to 'drivers/scsi')
-rw-r--r--drivers/scsi/sata_sil24.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/drivers/scsi/sata_sil24.c b/drivers/scsi/sata_sil24.c
index d8a2f5f04e8..571302dc48a 100644
--- a/drivers/scsi/sata_sil24.c
+++ b/drivers/scsi/sata_sil24.c
@@ -489,12 +489,21 @@ static void sil24_error_intr(struct ata_port *ap, u32 slot_stat)
489 u32 irq_stat, cmd_err, sstatus, serror; 489 u32 irq_stat, cmd_err, sstatus, serror;
490 490
491 irq_stat = readl(port + PORT_IRQ_STAT); 491 irq_stat = readl(port + PORT_IRQ_STAT);
492 writel(irq_stat, port + PORT_IRQ_STAT); /* clear irq */
493
494 if (!(irq_stat & PORT_IRQ_ERROR)) {
495 /* ignore non-completion, non-error irqs for now */
496 printk(KERN_WARNING DRV_NAME
497 "ata%u: non-error exception irq (irq_stat %x)\n",
498 ap->id, irq_stat);
499 return;
500 }
501
492 cmd_err = readl(port + PORT_CMD_ERR); 502 cmd_err = readl(port + PORT_CMD_ERR);
493 sstatus = readl(port + PORT_SSTATUS); 503 sstatus = readl(port + PORT_SSTATUS);
494 serror = readl(port + PORT_SERROR); 504 serror = readl(port + PORT_SERROR);
495 505
496 /* Clear IRQ/errors */ 506 /* Clear IRQ/errors */
497 writel(irq_stat, port + PORT_IRQ_STAT);
498 if (cmd_err) 507 if (cmd_err)
499 writel(cmd_err, port + PORT_CMD_ERR); 508 writel(cmd_err, port + PORT_CMD_ERR);
500 if (serror) 509 if (serror)