diff options
author | Tejun Heo <htejun@gmail.com> | 2008-04-07 09:47:19 -0400 |
---|---|---|
committer | Jeff Garzik <jgarzik@redhat.com> | 2008-04-17 15:44:23 -0400 |
commit | 57c9efdfb3cee5d4564fcb5f70555e2edb1bc52a (patch) | |
tree | c2289500f093736853a94d2d9577036658676498 /drivers/ata/libata-eh.c | |
parent | 9dadd45b24145d6aee2fabb28d7aef972301892b (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-eh.c')
-rw-r--r-- | drivers/ata/libata-eh.c | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/drivers/ata/libata-eh.c b/drivers/ata/libata-eh.c index f4f9c2783821..21687bbd9a70 100644 --- a/drivers/ata/libata-eh.c +++ b/drivers/ata/libata-eh.c | |||
@@ -2857,11 +2857,8 @@ void ata_std_error_handler(struct ata_port *ap) | |||
2857 | struct ata_port_operations *ops = ap->ops; | 2857 | struct ata_port_operations *ops = ap->ops; |
2858 | ata_reset_fn_t hardreset = ops->hardreset; | 2858 | ata_reset_fn_t hardreset = ops->hardreset; |
2859 | 2859 | ||
2860 | /* sata_std_hardreset is inherited to all drivers from | 2860 | /* ignore built-in hardreset if SCR access is not available */ |
2861 | * ata_base_port_ops. Ignore it if SCR access is not | 2861 | if (ata_is_builtin_hardreset(hardreset) && !sata_scr_valid(&ap->link)) |
2862 | * available. | ||
2863 | */ | ||
2864 | if (hardreset == sata_sff_hardreset && !sata_scr_valid(&ap->link)) | ||
2865 | hardreset = NULL; | 2862 | hardreset = NULL; |
2866 | 2863 | ||
2867 | ata_do_eh(ap, ops->prereset, ops->softreset, hardreset, ops->postreset); | 2864 | ata_do_eh(ap, ops->prereset, ops->softreset, hardreset, ops->postreset); |