aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/ide/ide-devsets.c2
-rw-r--r--drivers/ide/ide-probe.c2
-rw-r--r--drivers/ide/ide-xfer-mode.c3
-rw-r--r--include/linux/ide.h1
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, ... */