aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/ide/ide-io.c4
-rw-r--r--drivers/ide/ide-iops.c9
-rw-r--r--drivers/ide/ide-probe.c4
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))