aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTejun Heo <htejun@gmail.com>2006-03-10 21:42:34 -0500
committerJeff Garzik <jeff@garzik.org>2006-03-11 19:29:42 -0500
commit10d996ad1990ec2338c463042db6d5ef4f347187 (patch)
treea06a602f278f820475f16523e12927b5abb980c4
parent75deb6fa985bd3162b9472f1fc394e23294da816 (diff)
[PATCH] sata_sil24: exit early from softreset if SStatus reports no device
sata_sil24 softreset routine used to check sata_dev_present() after SRST is complete in the hope that SRST may do some good even when SStatus reports no device. This is okay as long as SRST timeout is short (> 100ms in the current code) but it seems that not all SATA devices are happy with short SRST timeout. This patch makes softreset exit early without performing actual SRST if SStatus reports no device in preparation for lengthening SRST timeout. Signed-off-by: Tejun Heo <htejun@gmail.com> Signed-off-by: Jeff Garzik <jeff@garzik.org>
-rw-r--r--drivers/scsi/sata_sil24.c22
1 files changed, 14 insertions, 8 deletions
diff --git a/drivers/scsi/sata_sil24.c b/drivers/scsi/sata_sil24.c
index 8fb62427be84..fa1a5ac60639 100644
--- a/drivers/scsi/sata_sil24.c
+++ b/drivers/scsi/sata_sil24.c
@@ -440,6 +440,12 @@ static int sil24_softreset(struct ata_port *ap, int verbose,
440 440
441 DPRINTK("ENTER\n"); 441 DPRINTK("ENTER\n");
442 442
443 if (!sata_dev_present(ap)) {
444 DPRINTK("PHY reports no device\n");
445 *class = ATA_DEV_NONE;
446 goto out;
447 }
448
443 /* temporarily turn off IRQs during SRST */ 449 /* temporarily turn off IRQs during SRST */
444 irq_enable = readl(port + PORT_IRQ_ENABLE_SET); 450 irq_enable = readl(port + PORT_IRQ_ENABLE_SET);
445 writel(irq_enable, port + PORT_IRQ_ENABLE_CLR); 451 writel(irq_enable, port + PORT_IRQ_ENABLE_CLR);
@@ -469,18 +475,18 @@ static int sil24_softreset(struct ata_port *ap, int verbose,
469 /* restore IRQs */ 475 /* restore IRQs */
470 writel(irq_enable, port + PORT_IRQ_ENABLE_SET); 476 writel(irq_enable, port + PORT_IRQ_ENABLE_SET);
471 477
472 if (sata_dev_present(ap)) { 478 if (!(irq_stat & PORT_IRQ_COMPLETE)) {
473 if (!(irq_stat & PORT_IRQ_COMPLETE)) { 479 DPRINTK("EXIT, srst failed\n");
474 DPRINTK("EXIT, srst failed\n"); 480 return -EIO;
475 return -EIO;
476 }
477
478 sil24_update_tf(ap);
479 *class = ata_dev_classify(&pp->tf);
480 } 481 }
482
483 sil24_update_tf(ap);
484 *class = ata_dev_classify(&pp->tf);
485
481 if (*class == ATA_DEV_UNKNOWN) 486 if (*class == ATA_DEV_UNKNOWN)
482 *class = ATA_DEV_NONE; 487 *class = ATA_DEV_NONE;
483 488
489 out:
484 DPRINTK("EXIT, class=%u\n", *class); 490 DPRINTK("EXIT, class=%u\n", *class);
485 return 0; 491 return 0;
486} 492}