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, ... */ |
