diff options
author | Tejun Heo <htejun@gmail.com> | 2008-04-07 09:47:18 -0400 |
---|---|---|
committer | Jeff Garzik <jgarzik@redhat.com> | 2008-04-17 15:44:22 -0400 |
commit | 0aa1113d544226bc2c4a20d6ac1d71170512a361 (patch) | |
tree | 503b33b0805424d312abddd3535c941bb85c03bc /drivers/ata/libata-core.c | |
parent | 288623a06c652239d2f57d271af12bb024cf7218 (diff) |
libata: separate out ata_std_prereset() from ata_sff_prereset()
Separate out generic ATA portion from ata_sff_prereset() into
ata_std_prereset() and implement ata_sff_prereset() using the std
version. Waiting for device readiness is the only SFF specific part.
ata_base_port_ops now has ata_std_prereset() for its prereset and
ata_sff_port_ops overrides it to ata_sff_prereset(). This change can
affect pdc_adma, ahci, sata_fsl and sata_sil24. pdc_adma implements
its own prereset using ata_sff_prereset() and the rest has hardreset
and thus are unaffected by this change.
This change reflects real world situation. There is no generic way to
wait for device readiness for non-SFF controllers and some of them
don't have any mechanism for that. Non-sff drivers which don't have
hardreset should wrap ata_std_prereset() and wait for device readiness
itself but there's no such driver now and isn't likely to be popular
in the future either.
Signed-off-by: Tejun Heo <htejun@gmail.com>
Diffstat (limited to 'drivers/ata/libata-core.c')
-rw-r--r-- | drivers/ata/libata-core.c | 17 |
1 files changed, 4 insertions, 13 deletions
diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c index fd912ccb90f8..5f771bb44332 100644 --- a/drivers/ata/libata-core.c +++ b/drivers/ata/libata-core.c | |||
@@ -74,7 +74,7 @@ const unsigned long sata_deb_timing_hotplug[] = { 25, 500, 2000 }; | |||
74 | const unsigned long sata_deb_timing_long[] = { 100, 2000, 5000 }; | 74 | const unsigned long sata_deb_timing_long[] = { 100, 2000, 5000 }; |
75 | 75 | ||
76 | const struct ata_port_operations ata_base_port_ops = { | 76 | const struct ata_port_operations ata_base_port_ops = { |
77 | .prereset = ata_sff_prereset, | 77 | .prereset = ata_std_prereset, |
78 | .hardreset = sata_sff_hardreset, | 78 | .hardreset = sata_sff_hardreset, |
79 | .postreset = ata_sff_postreset, | 79 | .postreset = ata_sff_postreset, |
80 | .error_handler = ata_std_error_handler, | 80 | .error_handler = ata_std_error_handler, |
@@ -3416,7 +3416,7 @@ int sata_link_resume(struct ata_link *link, const unsigned long *params, | |||
3416 | } | 3416 | } |
3417 | 3417 | ||
3418 | /** | 3418 | /** |
3419 | * ata_sff_prereset - prepare for reset | 3419 | * ata_std_prereset - prepare for reset |
3420 | * @link: ATA link to be reset | 3420 | * @link: ATA link to be reset |
3421 | * @deadline: deadline jiffies for the operation | 3421 | * @deadline: deadline jiffies for the operation |
3422 | * | 3422 | * |
@@ -3432,7 +3432,7 @@ int sata_link_resume(struct ata_link *link, const unsigned long *params, | |||
3432 | * RETURNS: | 3432 | * RETURNS: |
3433 | * 0 on success, -errno otherwise. | 3433 | * 0 on success, -errno otherwise. |
3434 | */ | 3434 | */ |
3435 | int ata_sff_prereset(struct ata_link *link, unsigned long deadline) | 3435 | int ata_std_prereset(struct ata_link *link, unsigned long deadline) |
3436 | { | 3436 | { |
3437 | struct ata_port *ap = link->ap; | 3437 | struct ata_port *ap = link->ap; |
3438 | struct ata_eh_context *ehc = &link->eh_context; | 3438 | struct ata_eh_context *ehc = &link->eh_context; |
@@ -3452,16 +3452,6 @@ int ata_sff_prereset(struct ata_link *link, unsigned long deadline) | |||
3452 | "link for reset (errno=%d)\n", rc); | 3452 | "link for reset (errno=%d)\n", rc); |
3453 | } | 3453 | } |
3454 | 3454 | ||
3455 | /* wait for !BSY if we don't know that no device is attached */ | ||
3456 | if (!ata_link_offline(link)) { | ||
3457 | rc = ata_sff_wait_ready(ap, deadline); | ||
3458 | if (rc && rc != -ENODEV) { | ||
3459 | ata_link_printk(link, KERN_WARNING, "device not ready " | ||
3460 | "(errno=%d), forcing hardreset\n", rc); | ||
3461 | ehc->i.action |= ATA_EH_HARDRESET; | ||
3462 | } | ||
3463 | } | ||
3464 | |||
3465 | return 0; | 3455 | return 0; |
3466 | } | 3456 | } |
3467 | 3457 | ||
@@ -6104,6 +6094,7 @@ EXPORT_SYMBOL_GPL(ata_dev_disable); | |||
6104 | EXPORT_SYMBOL_GPL(sata_set_spd); | 6094 | EXPORT_SYMBOL_GPL(sata_set_spd); |
6105 | EXPORT_SYMBOL_GPL(sata_link_debounce); | 6095 | EXPORT_SYMBOL_GPL(sata_link_debounce); |
6106 | EXPORT_SYMBOL_GPL(sata_link_resume); | 6096 | EXPORT_SYMBOL_GPL(sata_link_resume); |
6097 | EXPORT_SYMBOL_GPL(ata_std_prereset); | ||
6107 | EXPORT_SYMBOL_GPL(sata_link_hardreset); | 6098 | EXPORT_SYMBOL_GPL(sata_link_hardreset); |
6108 | EXPORT_SYMBOL_GPL(ata_dev_classify); | 6099 | EXPORT_SYMBOL_GPL(ata_dev_classify); |
6109 | EXPORT_SYMBOL_GPL(ata_dev_pair); | 6100 | EXPORT_SYMBOL_GPL(ata_dev_pair); |