diff options
| author | Tejun Heo <htejun@gmail.com> | 2007-08-06 05:36:23 -0400 |
|---|---|---|
| committer | Jeff Garzik <jeff@garzik.org> | 2007-10-12 14:55:32 -0400 |
| commit | cf1b86c8ab41fe2b2a2eb59c9a2ea9a7e463653a (patch) | |
| tree | 10ef03fb1cae89d7415a5788dc330b4088b4234b /drivers/ata/libata-eh.c | |
| parent | 8989805d6d176aa32c0e9a68a536aa4c8ef5231c (diff) | |
libata-link: update ata_scsi_error() to handle PMP links
Update ata_scsi_error() to handle PMP links. As error conditions can
occur on both host and PMP links, __ata_port_for_each_link() is used.
Signed-off-by: Tejun Heo <htejun@gmail.com>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
Diffstat (limited to 'drivers/ata/libata-eh.c')
| -rw-r--r-- | drivers/ata/libata-eh.c | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/drivers/ata/libata-eh.c b/drivers/ata/libata-eh.c index eb4c0593b406..45eb932c3935 100644 --- a/drivers/ata/libata-eh.c +++ b/drivers/ata/libata-eh.c | |||
| @@ -363,6 +363,8 @@ void ata_scsi_error(struct Scsi_Host *host) | |||
| 363 | repeat: | 363 | repeat: |
| 364 | /* invoke error handler */ | 364 | /* invoke error handler */ |
| 365 | if (ap->ops->error_handler) { | 365 | if (ap->ops->error_handler) { |
| 366 | struct ata_link *link; | ||
| 367 | |||
| 366 | /* kill fast drain timer */ | 368 | /* kill fast drain timer */ |
| 367 | del_timer_sync(&ap->fastdrain_timer); | 369 | del_timer_sync(&ap->fastdrain_timer); |
| 368 | 370 | ||
| @@ -372,9 +374,11 @@ void ata_scsi_error(struct Scsi_Host *host) | |||
| 372 | /* fetch & clear EH info */ | 374 | /* fetch & clear EH info */ |
| 373 | spin_lock_irqsave(ap->lock, flags); | 375 | spin_lock_irqsave(ap->lock, flags); |
| 374 | 376 | ||
| 375 | memset(&ap->link.eh_context, 0, sizeof(ap->link.eh_context)); | 377 | __ata_port_for_each_link(link, ap) { |
| 376 | ap->link.eh_context.i = ap->link.eh_info; | 378 | memset(&link->eh_context, 0, sizeof(link->eh_context)); |
| 377 | memset(&ap->link.eh_info, 0, sizeof(ap->link.eh_info)); | 379 | link->eh_context.i = link->eh_info; |
| 380 | memset(&link->eh_info, 0, sizeof(link->eh_info)); | ||
| 381 | } | ||
| 378 | 382 | ||
| 379 | ap->pflags |= ATA_PFLAG_EH_IN_PROGRESS; | 383 | ap->pflags |= ATA_PFLAG_EH_IN_PROGRESS; |
| 380 | ap->pflags &= ~ATA_PFLAG_EH_PENDING; | 384 | ap->pflags &= ~ATA_PFLAG_EH_PENDING; |
| @@ -410,7 +414,8 @@ void ata_scsi_error(struct Scsi_Host *host) | |||
| 410 | } | 414 | } |
| 411 | 415 | ||
| 412 | /* this run is complete, make sure EH info is clear */ | 416 | /* this run is complete, make sure EH info is clear */ |
| 413 | memset(&ap->link.eh_info, 0, sizeof(ap->link.eh_info)); | 417 | __ata_port_for_each_link(link, ap) |
| 418 | memset(&link->eh_info, 0, sizeof(link->eh_info)); | ||
| 414 | 419 | ||
| 415 | /* Clear host_eh_scheduled while holding ap->lock such | 420 | /* Clear host_eh_scheduled while holding ap->lock such |
| 416 | * that if exception occurs after this point but | 421 | * that if exception occurs after this point but |
