[PATCH] libata: PIO 0
Ensure the pio_mode is always setup. Don't do any setup on the controller b just ensure the mode reporting is valid to avoid tons of special cases in PATA driver code when mode switching on the fly. Signed-off-by: Alan Cox <alan@redhat.com> Signed-off-by: Jeff Garzik <jeff@garzik.org>
This commit is contained in:
parent
1f3461a726
commit
b6079ca409
|
@ -1498,6 +1498,12 @@ static int ata_bus_probe(struct ata_port *ap)
|
||||||
if (classes[i] == ATA_DEV_UNKNOWN)
|
if (classes[i] == ATA_DEV_UNKNOWN)
|
||||||
classes[i] = ATA_DEV_NONE;
|
classes[i] = ATA_DEV_NONE;
|
||||||
|
|
||||||
|
/* 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;
|
||||||
|
|
||||||
/* read IDENTIFY page and configure devices */
|
/* read IDENTIFY page and configure devices */
|
||||||
for (i = 0; i < ATA_MAX_DEVICES; i++) {
|
for (i = 0; i < ATA_MAX_DEVICES; i++) {
|
||||||
dev = &ap->device[i];
|
dev = &ap->device[i];
|
||||||
|
|
Loading…
Reference in New Issue