[PATCH] libata: set PIO-0 after successful EH reset
authorTejun Heo <htejun@gmail.com>
Wed, 31 May 2006 09:27:23 +0000 (18:27 +0900)
committerTejun Heo <htejun@gmail.com>
Wed, 31 May 2006 09:27:23 +0000 (18:27 +0900)
Set ata_device->pio_mode to XFER_PIO_0 after a successful reset.  This
is to keep EH resets consistent with probe resets as updated by the
commit b6079ca409bf88c248992e96510dd6f610f7ed89.  Note that, with
soon-to-follow hotplug update, EH resets will include probe resets.

Signed-off-by: Tejun Heo <htejun@gmail.com>
drivers/scsi/libata-eh.c

index 71b45ad2c1247d3907588dbf0a677dfec877b873..b88f492eab125d797abf4ae0cbf32c1b2919c471 100644 (file)
@@ -1287,7 +1287,7 @@ static int ata_eh_reset(struct ata_port *ap, ata_reset_fn_t softreset,
        unsigned int classes[ATA_MAX_DEVICES];
        int tries = ATA_EH_RESET_TRIES;
        ata_reset_fn_t reset;
-       int rc;
+       int i, rc;
 
        if (softreset && (!hardreset || (!sata_set_spd_needed(ap) &&
                                         !(ehc->i.action & ATA_EH_HARDRESET))))
@@ -1319,6 +1319,12 @@ static int ata_eh_reset(struct ata_port *ap, ata_reset_fn_t softreset,
        }
 
        if (rc == 0) {
+               /* After the reset, the device state is PIO 0 and the
+                * controller state is undefined.  Record the mode.
+                */
+               for (i = 0; i < ATA_MAX_DEVICES; i++)
+                       ap->device[i].pio_mode = XFER_PIO_0;
+
                if (postreset)
                        postreset(ap, classes);