diff options
-rw-r--r-- | drivers/ide/ide-devsets.c | 2 | ||||
-rw-r--r-- | drivers/ide/ide-probe.c | 2 | ||||
-rw-r--r-- | drivers/ide/ide-xfer-mode.c | 3 | ||||
-rw-r--r-- | include/linux/ide.h | 1 |
4 files changed, 8 insertions, 0 deletions
diff --git a/drivers/ide/ide-devsets.c b/drivers/ide/ide-devsets.c index 1099bf7cf968..cb3341ce655c 100644 --- a/drivers/ide/ide-devsets.c +++ b/drivers/ide/ide-devsets.c | |||
@@ -105,6 +105,8 @@ static int set_pio_mode(ide_drive_t *drive, int arg) | |||
105 | return -ENOSYS; | 105 | return -ENOSYS; |
106 | 106 | ||
107 | if (set_pio_mode_abuse(drive->hwif, arg)) { | 107 | if (set_pio_mode_abuse(drive->hwif, arg)) { |
108 | drive->pio_mode = arg + XFER_PIO_0; | ||
109 | |||
108 | if (arg == 8 || arg == 9) { | 110 | if (arg == 8 || arg == 9) { |
109 | unsigned long flags; | 111 | unsigned long flags; |
110 | 112 | ||
diff --git a/drivers/ide/ide-probe.c b/drivers/ide/ide-probe.c index 4d76ba473097..9a9f10f4cf9f 100644 --- a/drivers/ide/ide-probe.c +++ b/drivers/ide/ide-probe.c | |||
@@ -1043,6 +1043,8 @@ static void ide_port_init_devices(ide_hwif_t *hwif) | |||
1043 | if (hwif->host_flags & IDE_HFLAG_NO_UNMASK_IRQS) | 1043 | if (hwif->host_flags & IDE_HFLAG_NO_UNMASK_IRQS) |
1044 | drive->dev_flags |= IDE_DFLAG_NO_UNMASK; | 1044 | drive->dev_flags |= IDE_DFLAG_NO_UNMASK; |
1045 | 1045 | ||
1046 | drive->pio_mode = XFER_PIO_0; | ||
1047 | |||
1046 | if (port_ops && port_ops->init_dev) | 1048 | if (port_ops && port_ops->init_dev) |
1047 | port_ops->init_dev(drive); | 1049 | port_ops->init_dev(drive); |
1048 | } | 1050 | } |
diff --git a/drivers/ide/ide-xfer-mode.c b/drivers/ide/ide-xfer-mode.c index 46d203ce60cc..cdae463f6b41 100644 --- a/drivers/ide/ide-xfer-mode.c +++ b/drivers/ide/ide-xfer-mode.c | |||
@@ -135,6 +135,7 @@ int ide_set_pio_mode(ide_drive_t *drive, const u8 mode) | |||
135 | * set transfer mode on the device in ->set_pio_mode method... | 135 | * set transfer mode on the device in ->set_pio_mode method... |
136 | */ | 136 | */ |
137 | if (port_ops->set_dma_mode == NULL) { | 137 | if (port_ops->set_dma_mode == NULL) { |
138 | drive->pio_mode = mode; | ||
138 | port_ops->set_pio_mode(drive, mode - XFER_PIO_0); | 139 | port_ops->set_pio_mode(drive, mode - XFER_PIO_0); |
139 | return 0; | 140 | return 0; |
140 | } | 141 | } |
@@ -142,9 +143,11 @@ int ide_set_pio_mode(ide_drive_t *drive, const u8 mode) | |||
142 | if (hwif->host_flags & IDE_HFLAG_POST_SET_MODE) { | 143 | if (hwif->host_flags & IDE_HFLAG_POST_SET_MODE) { |
143 | if (ide_config_drive_speed(drive, mode)) | 144 | if (ide_config_drive_speed(drive, mode)) |
144 | return -1; | 145 | return -1; |
146 | drive->pio_mode = mode; | ||
145 | port_ops->set_pio_mode(drive, mode - XFER_PIO_0); | 147 | port_ops->set_pio_mode(drive, mode - XFER_PIO_0); |
146 | return 0; | 148 | return 0; |
147 | } else { | 149 | } else { |
150 | drive->pio_mode = mode; | ||
148 | port_ops->set_pio_mode(drive, mode - XFER_PIO_0); | 151 | port_ops->set_pio_mode(drive, mode - XFER_PIO_0); |
149 | return ide_config_drive_speed(drive, mode); | 152 | return ide_config_drive_speed(drive, mode); |
150 | } | 153 | } |
diff --git a/include/linux/ide.h b/include/linux/ide.h index 0ec612959042..b5d2e9655059 100644 --- a/include/linux/ide.h +++ b/include/linux/ide.h | |||
@@ -515,6 +515,7 @@ struct ide_drive_s { | |||
515 | u8 init_speed; /* transfer rate set at boot */ | 515 | u8 init_speed; /* transfer rate set at boot */ |
516 | u8 current_speed; /* current transfer rate set */ | 516 | u8 current_speed; /* current transfer rate set */ |
517 | u8 desired_speed; /* desired transfer rate set */ | 517 | u8 desired_speed; /* desired transfer rate set */ |
518 | u8 pio_mode; /* for ->set_pio_mode _only_ */ | ||
518 | u8 dn; /* now wide spread use */ | 519 | u8 dn; /* now wide spread use */ |
519 | u8 acoustic; /* acoustic management */ | 520 | u8 acoustic; /* acoustic management */ |
520 | u8 media; /* disk, cdrom, tape, floppy, ... */ | 521 | u8 media; /* disk, cdrom, tape, floppy, ... */ |