aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ata/libata-sff.c
diff options
context:
space:
mode:
authorTejun Heo <htejun@gmail.com>2008-04-07 09:47:19 -0400
committerJeff Garzik <jgarzik@redhat.com>2008-04-17 15:44:23 -0400
commit57c9efdfb3cee5d4564fcb5f70555e2edb1bc52a (patch)
treec2289500f093736853a94d2d9577036658676498 /drivers/ata/libata-sff.c
parent9dadd45b24145d6aee2fabb28d7aef972301892b (diff)
libata: implement and use sata_std_hardreset()
Implement sata_std_hardreset(), which simply wraps around sata_link_hardreset(). sata_std_hardreset() becomes new standard hardreset method for sata_port_ops and sata_sff_hardreset() moves from ata_base_port_ops to ata_sff_port_ops, which is where it really belongs. ata_is_builtin_hardreset() is added so that both ata_std_error_handler() and ata_sff_error_handler() skip both builtin hardresets if SCR isn't accessible. piix_sidpr_hardreset() in ata_piix.c is identical to sata_std_hardreset() in functionality and got replaced with the standard function. Signed-off-by: Tejun Heo <htejun@gmail.com>
Diffstat (limited to 'drivers/ata/libata-sff.c')
-rw-r--r--drivers/ata/libata-sff.c9
1 files changed, 4 insertions, 5 deletions
diff --git a/drivers/ata/libata-sff.c b/drivers/ata/libata-sff.c
index 0b97e84d3af6..f464ca1fa261 100644
--- a/drivers/ata/libata-sff.c
+++ b/drivers/ata/libata-sff.c
@@ -49,6 +49,7 @@ const struct ata_port_operations ata_sff_port_ops = {
49 .thaw = ata_sff_thaw, 49 .thaw = ata_sff_thaw,
50 .prereset = ata_sff_prereset, 50 .prereset = ata_sff_prereset,
51 .softreset = ata_sff_softreset, 51 .softreset = ata_sff_softreset,
52 .hardreset = sata_sff_hardreset,
52 .postreset = ata_sff_postreset, 53 .postreset = ata_sff_postreset,
53 .error_handler = ata_sff_error_handler, 54 .error_handler = ata_sff_error_handler,
54 .post_internal_cmd = ata_sff_post_internal_cmd, 55 .post_internal_cmd = ata_sff_post_internal_cmd,
@@ -2031,14 +2032,12 @@ void ata_sff_error_handler(struct ata_port *ap)
2031 2032
2032 /* PIO and DMA engines have been stopped, perform recovery */ 2033 /* PIO and DMA engines have been stopped, perform recovery */
2033 2034
2034 /* ata_sff_softreset and sata_sff_hardreset are inherited to 2035 /* Ignore ata_sff_softreset if ctl isn't accessible and
2035 * all SFF drivers from ata_sff_port_ops. Ignore softreset if 2036 * built-in hardresets if SCR access isn't available.
2036 * ctl isn't accessible. Ignore hardreset if SCR access isn't
2037 * available.
2038 */ 2037 */
2039 if (softreset == ata_sff_softreset && !ap->ioaddr.ctl_addr) 2038 if (softreset == ata_sff_softreset && !ap->ioaddr.ctl_addr)
2040 softreset = NULL; 2039 softreset = NULL;
2041 if (hardreset == sata_sff_hardreset && !sata_scr_valid(&ap->link)) 2040 if (ata_is_builtin_hardreset(hardreset) && !sata_scr_valid(&ap->link))
2042 hardreset = NULL; 2041 hardreset = NULL;
2043 2042
2044 ata_do_eh(ap, ap->ops->prereset, softreset, hardreset, 2043 ata_do_eh(ap, ap->ops->prereset, softreset, hardreset,