|
@@ -105,13 +105,13 @@ static void umc_set_speeds (u8 speeds[])
|
|
|
|
|
|
static void umc_set_pio_mode(ide_drive_t *drive, const u8 pio)
|
|
static void umc_set_pio_mode(ide_drive_t *drive, const u8 pio)
|
|
{
|
|
{
|
|
|
|
+ ide_hwif_t *hwif = drive->hwif;
|
|
unsigned long flags;
|
|
unsigned long flags;
|
|
- ide_hwgroup_t *hwgroup = ide_hwifs[HWIF(drive)->index^1].hwgroup;
|
|
|
|
|
|
|
|
printk("%s: setting umc8672 to PIO mode%d (speed %d)\n",
|
|
printk("%s: setting umc8672 to PIO mode%d (speed %d)\n",
|
|
drive->name, pio, pio_to_umc[pio]);
|
|
drive->name, pio, pio_to_umc[pio]);
|
|
spin_lock_irqsave(&ide_lock, flags);
|
|
spin_lock_irqsave(&ide_lock, flags);
|
|
- if (hwgroup && hwgroup->handler != NULL) {
|
|
|
|
|
|
+ if (hwif->mate && hwif->mate->hwgroup->handler) {
|
|
printk(KERN_ERR "umc8672: other interface is busy: exiting tune_umc()\n");
|
|
printk(KERN_ERR "umc8672: other interface is busy: exiting tune_umc()\n");
|
|
} else {
|
|
} else {
|
|
current_speeds[drive->name[2] - 'a'] = pio_to_umc[pio];
|
|
current_speeds[drive->name[2] - 'a'] = pio_to_umc[pio];
|