diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/ide/ide-io.c | 4 | ||||
-rw-r--r-- | drivers/ide/ide-iops.c | 9 | ||||
-rw-r--r-- | drivers/ide/ide-probe.c | 4 |
3 files changed, 4 insertions, 13 deletions
diff --git a/drivers/ide/ide-io.c b/drivers/ide/ide-io.c index 33458fe7f490..4ea8419feeec 100644 --- a/drivers/ide/ide-io.c +++ b/drivers/ide/ide-io.c | |||
@@ -1469,12 +1469,8 @@ void ide_timer_expiry (unsigned long data) | |||
1469 | */ | 1469 | */ |
1470 | spin_unlock(&ide_lock); | 1470 | spin_unlock(&ide_lock); |
1471 | hwif = HWIF(drive); | 1471 | hwif = HWIF(drive); |
1472 | #if DISABLE_IRQ_NOSYNC | ||
1473 | disable_irq_nosync(hwif->irq); | ||
1474 | #else | ||
1475 | /* disable_irq_nosync ?? */ | 1472 | /* disable_irq_nosync ?? */ |
1476 | disable_irq(hwif->irq); | 1473 | disable_irq(hwif->irq); |
1477 | #endif /* DISABLE_IRQ_NOSYNC */ | ||
1478 | /* local CPU only, | 1474 | /* local CPU only, |
1479 | * as if we were handling an interrupt */ | 1475 | * as if we were handling an interrupt */ |
1480 | local_irq_disable(); | 1476 | local_irq_disable(); |
diff --git a/drivers/ide/ide-iops.c b/drivers/ide/ide-iops.c index 6a6d1c188030..617888048eed 100644 --- a/drivers/ide/ide-iops.c +++ b/drivers/ide/ide-iops.c | |||
@@ -1050,8 +1050,7 @@ static void ide_disk_pre_reset(ide_drive_t *drive) | |||
1050 | drive->special.all = 0; | 1050 | drive->special.all = 0; |
1051 | drive->special.b.set_geometry = legacy; | 1051 | drive->special.b.set_geometry = legacy; |
1052 | drive->special.b.recalibrate = legacy; | 1052 | drive->special.b.recalibrate = legacy; |
1053 | if (OK_TO_RESET_CONTROLLER) | 1053 | drive->mult_count = 0; |
1054 | drive->mult_count = 0; | ||
1055 | if (!drive->keep_settings && !drive->using_dma) | 1054 | if (!drive->keep_settings && !drive->using_dma) |
1056 | drive->mult_req = 0; | 1055 | drive->mult_req = 0; |
1057 | if (drive->mult_req != drive->mult_count) | 1056 | if (drive->mult_req != drive->mult_count) |
@@ -1136,7 +1135,6 @@ static ide_startstop_t do_reset1 (ide_drive_t *drive, int do_not_try_atapi) | |||
1136 | for (unit = 0; unit < MAX_DRIVES; ++unit) | 1135 | for (unit = 0; unit < MAX_DRIVES; ++unit) |
1137 | pre_reset(&hwif->drives[unit]); | 1136 | pre_reset(&hwif->drives[unit]); |
1138 | 1137 | ||
1139 | #if OK_TO_RESET_CONTROLLER | ||
1140 | if (!IDE_CONTROL_REG) { | 1138 | if (!IDE_CONTROL_REG) { |
1141 | spin_unlock_irqrestore(&ide_lock, flags); | 1139 | spin_unlock_irqrestore(&ide_lock, flags); |
1142 | return ide_stopped; | 1140 | return ide_stopped; |
@@ -1173,11 +1171,8 @@ static ide_startstop_t do_reset1 (ide_drive_t *drive, int do_not_try_atapi) | |||
1173 | * state when the disks are reset this way. At least, the Winbond | 1171 | * state when the disks are reset this way. At least, the Winbond |
1174 | * 553 documentation says that | 1172 | * 553 documentation says that |
1175 | */ | 1173 | */ |
1176 | if (hwif->resetproc != NULL) { | 1174 | if (hwif->resetproc) |
1177 | hwif->resetproc(drive); | 1175 | hwif->resetproc(drive); |
1178 | } | ||
1179 | |||
1180 | #endif /* OK_TO_RESET_CONTROLLER */ | ||
1181 | 1176 | ||
1182 | spin_unlock_irqrestore(&ide_lock, flags); | 1177 | spin_unlock_irqrestore(&ide_lock, flags); |
1183 | return ide_started; | 1178 | return ide_started; |
diff --git a/drivers/ide/ide-probe.c b/drivers/ide/ide-probe.c index 0dda7ac0d951..8e5d8dd315af 100644 --- a/drivers/ide/ide-probe.c +++ b/drivers/ide/ide-probe.c | |||
@@ -95,10 +95,10 @@ static void ide_disk_init_mult_count(ide_drive_t *drive) | |||
95 | #ifdef CONFIG_IDEDISK_MULTI_MODE | 95 | #ifdef CONFIG_IDEDISK_MULTI_MODE |
96 | id->multsect = ((id->max_multsect/2) > 1) ? id->max_multsect : 0; | 96 | id->multsect = ((id->max_multsect/2) > 1) ? id->max_multsect : 0; |
97 | id->multsect_valid = id->multsect ? 1 : 0; | 97 | id->multsect_valid = id->multsect ? 1 : 0; |
98 | drive->mult_req = id->multsect_valid ? id->max_multsect : INITIAL_MULT_COUNT; | 98 | drive->mult_req = id->multsect_valid ? id->max_multsect : 0; |
99 | drive->special.b.set_multmode = drive->mult_req ? 1 : 0; | 99 | drive->special.b.set_multmode = drive->mult_req ? 1 : 0; |
100 | #else /* original, pre IDE-NFG, per request of AC */ | 100 | #else /* original, pre IDE-NFG, per request of AC */ |
101 | drive->mult_req = INITIAL_MULT_COUNT; | 101 | drive->mult_req = 0; |
102 | if (drive->mult_req > id->max_multsect) | 102 | if (drive->mult_req > id->max_multsect) |
103 | drive->mult_req = id->max_multsect; | 103 | drive->mult_req = id->max_multsect; |
104 | if (drive->mult_req || ((id->multsect_valid & 1) && id->multsect)) | 104 | if (drive->mult_req || ((id->multsect_valid & 1) && id->multsect)) |