diff options
author | Tejun Heo <htejun@gmail.com> | 2007-12-07 18:47:01 -0500 |
---|---|---|
committer | Jeff Garzik <jeff@garzik.org> | 2007-12-17 20:33:11 -0500 |
commit | f7fe7ad4bcaba17f05d5cbf1119772c645783b08 (patch) | |
tree | b267cfb43c39aa7a038b13acf620bd1e0cab29a8 /drivers/ata/libata-core.c | |
parent | 8cf32ac6578a70025be1103466da9d1d6141429e (diff) |
libata: clear link->eh_info.serror from ata_std_postreset()
link->eh_info.serror is used to cache SError for controllers which
need it cleared from interrupt handler to clear IRQ. It also should
be cleared after reset just like SError itself.
Make ata_std_postreset() clear link->eh_info.serror too and update
sata_sil such that it doesn't care about bookkeeping the value.
Signed-off-by: Tejun Heo <htejun@gmail.com>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
Diffstat (limited to 'drivers/ata/libata-core.c')
-rw-r--r-- | drivers/ata/libata-core.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c index e4dea8623a71..b0d1dc3cdb2d 100644 --- a/drivers/ata/libata-core.c +++ b/drivers/ata/libata-core.c | |||
@@ -3923,6 +3923,7 @@ void ata_std_postreset(struct ata_link *link, unsigned int *classes) | |||
3923 | /* clear SError */ | 3923 | /* clear SError */ |
3924 | if (sata_scr_read(link, SCR_ERROR, &serror) == 0) | 3924 | if (sata_scr_read(link, SCR_ERROR, &serror) == 0) |
3925 | sata_scr_write(link, SCR_ERROR, serror); | 3925 | sata_scr_write(link, SCR_ERROR, serror); |
3926 | link->eh_info.serror = 0; | ||
3926 | 3927 | ||
3927 | /* is double-select really necessary? */ | 3928 | /* is double-select really necessary? */ |
3928 | if (classes[0] != ATA_DEV_NONE) | 3929 | if (classes[0] != ATA_DEV_NONE) |