Bartlomiej Zolnierkiewicz <bzolnier@xxxxxxxxx> wrote: > On Wednesday 17 September 2008 09:38:37 Elias Oltmanns wrote: >> On user request (through sysfs), the IDLE IMMEDIATE command with UNLOAD > >> FEATURE as specified in ATA-7 is issued to the device and processing of >> the request queue is stopped thereafter until the specified timeout >> expires or user space asks to resume normal operation. This is supposed >> to prevent the heads of a hard drive from accidentally crashing onto the >> platter when a heavy shock is anticipated (like a falling laptop expected >> to hit the floor). Port resets are deferred whenever a device on that >> port is in the parked state. >> >> Signed-off-by: Elias Oltmanns <eo@xxxxxxxxxxxxxx> > > applied I'm very sorry for responding so late to Tejun's concerns but I got bitten by the uaccess bug in recent linux-next discussed on LKML. @Bart, one isue raised by Tejun actually applies to this ide patch as well. Even though the problem is considerably more complex in the libata case than I had bargained for, we are lucky in the ide case. Still, we need to move prepar_to_wait() to the top of the while loop. Can you please include the following interdiff? It also gets rid of a superfluous variable. Thanks, Elias --- diff --git a/drivers/ide/ide-iops.c b/drivers/ide/ide-iops.c index 7e7a1f0..0eb6284 100644 --- a/drivers/ide/ide-iops.c +++ b/drivers/ide/ide-iops.c @@ -1115,11 +1115,11 @@ static ide_startstop_t do_reset1 (ide_drive_t *drive, int do_not_try_atapi) /* We must not disturb devices in the IDE_DFLAG_PARKED state. */ do { unsigned long now; - int i; + prepare_to_wait(&ide_park_wq, &wait, TASK_UNINTERRUPTIBLE); timeout = jiffies; - for (i = 0; i < MAX_DRIVES; i++) { - ide_drive_t *tdrive = &hwif->drives[i]; + for (unit = 0; unit < MAX_DRIVES; unit++) { + ide_drive_t *tdrive = &hwif->drives[unit]; if (tdrive->dev_flags & IDE_DFLAG_PRESENT && tdrive->dev_flags & IDE_DFLAG_PARKED && @@ -1132,7 +1132,6 @@ static ide_startstop_t do_reset1 (ide_drive_t *drive, int do_not_try_atapi) break; spin_unlock_irqrestore(&ide_lock, flags); - prepare_to_wait(&ide_park_wq, &wait, TASK_UNINTERRUPTIBLE); timeout = schedule_timeout_uninterruptible(timeout - now); spin_lock_irqsave(&ide_lock, flags); } while (timeout); -- To unsubscribe from this list: send the line "unsubscribe linux-ide" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html