diff options
author | Tejun Heo <htejun@gmail.com> | 2006-02-02 04:20:00 -0500 |
---|---|---|
committer | Jeff Garzik <jgarzik@pobox.com> | 2006-02-09 01:59:52 -0500 |
commit | 8a19ac89edbe9b702c10fd2039b8cb2db4644a5f (patch) | |
tree | 9241f1ec6d1a8e713ca60e6e5d098a11beb0dfdf /drivers/scsi/libata-core.c | |
parent | 7944ea9522ce0ea32d57894b3dc2540b0bdca66e (diff) |
[PATCH] libata: implement ata_std_probeinit()
This patch implements the off-the-shelf probeinit component operation.
Currently, all it does is waking up the PHY if it's a SATA port.
Signed-off-by: Tejun Heo <htejun@gmail.com>
Signed-off-by: Jeff Garzik <jgarzik@pobox.com>
Diffstat (limited to 'drivers/scsi/libata-core.c')
-rw-r--r-- | drivers/scsi/libata-core.c | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/drivers/scsi/libata-core.c b/drivers/scsi/libata-core.c index c36c5a9a4617..14cdbb336dd5 100644 --- a/drivers/scsi/libata-core.c +++ b/drivers/scsi/libata-core.c | |||
@@ -2296,6 +2296,19 @@ static int sata_phy_resume(struct ata_port *ap) | |||
2296 | } | 2296 | } |
2297 | 2297 | ||
2298 | /** | 2298 | /** |
2299 | * ata_std_probeinit - initialize probing | ||
2300 | * @ap: port to be probed | ||
2301 | * | ||
2302 | * @ap is about to be probed. Initialize it. This function is | ||
2303 | * to be used as standard callback for ata_drive_probe_reset(). | ||
2304 | */ | ||
2305 | extern void ata_std_probeinit(struct ata_port *ap) | ||
2306 | { | ||
2307 | if (ap->flags & ATA_FLAG_SATA && ap->ops->scr_read) | ||
2308 | sata_phy_resume(ap); | ||
2309 | } | ||
2310 | |||
2311 | /** | ||
2299 | * ata_std_softreset - reset host port via ATA SRST | 2312 | * ata_std_softreset - reset host port via ATA SRST |
2300 | * @ap: port to reset | 2313 | * @ap: port to reset |
2301 | * @verbose: fail verbosely | 2314 | * @verbose: fail verbosely |
@@ -2485,7 +2498,7 @@ int ata_std_probe_reset(struct ata_port *ap, unsigned int *classes) | |||
2485 | if (ap->flags & ATA_FLAG_SATA && ap->ops->scr_read) | 2498 | if (ap->flags & ATA_FLAG_SATA && ap->ops->scr_read) |
2486 | hardreset = sata_std_hardreset; | 2499 | hardreset = sata_std_hardreset; |
2487 | 2500 | ||
2488 | return ata_drive_probe_reset(ap, NULL, | 2501 | return ata_drive_probe_reset(ap, ata_std_probeinit, |
2489 | ata_std_softreset, hardreset, | 2502 | ata_std_softreset, hardreset, |
2490 | ata_std_postreset, classes); | 2503 | ata_std_postreset, classes); |
2491 | } | 2504 | } |
@@ -5535,6 +5548,7 @@ EXPORT_SYMBOL_GPL(ata_port_probe); | |||
5535 | EXPORT_SYMBOL_GPL(sata_phy_reset); | 5548 | EXPORT_SYMBOL_GPL(sata_phy_reset); |
5536 | EXPORT_SYMBOL_GPL(__sata_phy_reset); | 5549 | EXPORT_SYMBOL_GPL(__sata_phy_reset); |
5537 | EXPORT_SYMBOL_GPL(ata_bus_reset); | 5550 | EXPORT_SYMBOL_GPL(ata_bus_reset); |
5551 | EXPORT_SYMBOL_GPL(ata_std_probeinit); | ||
5538 | EXPORT_SYMBOL_GPL(ata_std_softreset); | 5552 | EXPORT_SYMBOL_GPL(ata_std_softreset); |
5539 | EXPORT_SYMBOL_GPL(sata_std_hardreset); | 5553 | EXPORT_SYMBOL_GPL(sata_std_hardreset); |
5540 | EXPORT_SYMBOL_GPL(ata_std_postreset); | 5554 | EXPORT_SYMBOL_GPL(ata_std_postreset); |