diff options
Diffstat (limited to 'drivers/ide/ide-iops.c')
-rw-r--r-- | drivers/ide/ide-iops.c | 54 |
1 files changed, 4 insertions, 50 deletions
diff --git a/drivers/ide/ide-iops.c b/drivers/ide/ide-iops.c index affbc603987a..317c5dadd7c0 100644 --- a/drivers/ide/ide-iops.c +++ b/drivers/ide/ide-iops.c | |||
@@ -289,65 +289,19 @@ no_80w: | |||
289 | 289 | ||
290 | int ide_driveid_update(ide_drive_t *drive) | 290 | int ide_driveid_update(ide_drive_t *drive) |
291 | { | 291 | { |
292 | ide_hwif_t *hwif = drive->hwif; | ||
293 | const struct ide_tp_ops *tp_ops = hwif->tp_ops; | ||
294 | u16 *id; | 292 | u16 *id; |
295 | unsigned long flags; | 293 | int rc; |
296 | int use_altstatus = 0, rc; | ||
297 | u8 a, uninitialized_var(s); | ||
298 | 294 | ||
299 | id = kmalloc(SECTOR_SIZE, GFP_ATOMIC); | 295 | id = kmalloc(SECTOR_SIZE, GFP_ATOMIC); |
300 | if (id == NULL) | 296 | if (id == NULL) |
301 | return 0; | 297 | return 0; |
302 | 298 | ||
303 | /* | ||
304 | * Re-read drive->id for possible DMA mode | ||
305 | * change (copied from ide-probe.c) | ||
306 | */ | ||
307 | |||
308 | SELECT_MASK(drive, 1); | 299 | SELECT_MASK(drive, 1); |
309 | tp_ops->set_irq(hwif, 0); | 300 | rc = ide_dev_read_id(drive, ATA_CMD_ID_ATA, id); |
310 | msleep(50); | 301 | SELECT_MASK(drive, 0); |
311 | |||
312 | if (hwif->io_ports.ctl_addr && | ||
313 | (hwif->host_flags & IDE_HFLAG_BROKEN_ALTSTATUS) == 0) { | ||
314 | a = tp_ops->read_altstatus(hwif); | ||
315 | s = tp_ops->read_status(hwif); | ||
316 | if ((a ^ s) & ~ATA_IDX) | ||
317 | /* ancient Seagate drives, broken interfaces */ | ||
318 | printk(KERN_INFO "%s: probing with STATUS(0x%02x) " | ||
319 | "instead of ALTSTATUS(0x%02x)\n", | ||
320 | drive->name, s, a); | ||
321 | else | ||
322 | /* use non-intrusive polling */ | ||
323 | use_altstatus = 1; | ||
324 | } | ||
325 | |||
326 | tp_ops->exec_command(hwif, ATA_CMD_ID_ATA); | ||
327 | |||
328 | if (ide_busy_sleep(hwif, WAIT_WORSTCASE / 2, use_altstatus)) { | ||
329 | rc = 1; | ||
330 | goto out_err; | ||
331 | } | ||
332 | |||
333 | msleep(50); /* wait for IRQ and ATA_DRQ */ | ||
334 | |||
335 | s = tp_ops->read_status(hwif); | ||
336 | 302 | ||
337 | if (!OK_STAT(s, ATA_DRQ, BAD_R_STAT)) { | 303 | if (rc) |
338 | rc = 2; | ||
339 | goto out_err; | 304 | goto out_err; |
340 | } | ||
341 | |||
342 | local_irq_save(flags); | ||
343 | tp_ops->input_data(drive, NULL, id, SECTOR_SIZE); | ||
344 | local_irq_restore(flags); | ||
345 | |||
346 | (void)tp_ops->read_status(hwif); /* clear drive IRQ */ | ||
347 | |||
348 | ide_fix_driveid(id); | ||
349 | |||
350 | SELECT_MASK(drive, 0); | ||
351 | 305 | ||
352 | drive->id[ATA_ID_UDMA_MODES] = id[ATA_ID_UDMA_MODES]; | 306 | drive->id[ATA_ID_UDMA_MODES] = id[ATA_ID_UDMA_MODES]; |
353 | drive->id[ATA_ID_MWDMA_MODES] = id[ATA_ID_MWDMA_MODES]; | 307 | drive->id[ATA_ID_MWDMA_MODES] = id[ATA_ID_MWDMA_MODES]; |