diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-06-15 16:53:20 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-06-15 16:53:33 -0700 | 
| commit | 066519068ad2fbe98c7f45552b1f592903a9c8c8 (patch) | |
| tree | a1c286887f60482325a6b18d9ca4373b5e9428bd /drivers/ide/legacy | |
| parent | b92dea67cc66970cda6b5b11895d08e35b4618e7 (diff) | |
| parent | 0cbccbc30a60ff60dbeb203154f1f527c632de9b (diff) | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/bart/ide-2.6tip-x86-delay-2008-06-23_09.02_Montip-sched-2008-06-16_09.25_Montip-sched-2008-06-16_09.15_Montip-pci-for-jesse-2008-06-16_09.25_Montip-mm-xen-2008-06-23_08.59_Mon
* git://git.kernel.org/pub/scm/linux/kernel/git/bart/ide-2.6:
  ide-generic: don't probe all legacy ISA IDE ports by default
  ide-cs: fix releasing I/O resources
  ide-cs: fix probing and add warm-plug support
  ide-pmac: remove bogus comment about pmac_ide_setup_device()
  ide-pmac: add ->cable_detect method
  ide-pmac: bugfix for media-bay support rework
  opti621: add PIO 4 support
  opti621: use pre-calculated PIO timings
  opti621: program devices timings separately in ->set_pio_mode
  opti621: use PCI clock value provided by controller
  opti621: remove DMA support
  opti621: disable read prefetch
Diffstat (limited to 'drivers/ide/legacy')
| -rw-r--r-- | drivers/ide/legacy/ide-cs.c | 41 | 
1 files changed, 20 insertions, 21 deletions
| diff --git a/drivers/ide/legacy/ide-cs.c b/drivers/ide/legacy/ide-cs.c index aa2ea3deac85..f633b6b3c7f3 100644 --- a/drivers/ide/legacy/ide-cs.c +++ b/drivers/ide/legacy/ide-cs.c @@ -135,13 +135,17 @@ static void ide_detach(struct pcmcia_device *link)  {      ide_info_t *info = link->priv;      ide_hwif_t *hwif = info->hwif; +    unsigned long data_addr, ctl_addr;      DEBUG(0, "ide_detach(0x%p)\n", link); +    data_addr = hwif->io_ports.data_addr; +    ctl_addr  = hwif->io_ports.ctl_addr; +      ide_release(link); -    release_region(hwif->io_ports.ctl_addr, 1); -    release_region(hwif->io_ports.data_addr, 8); +    release_region(ctl_addr, 1); +    release_region(data_addr, 8);      kfree(info);  } /* ide_detach */ @@ -194,6 +198,16 @@ static ide_hwif_t *idecs_register(unsigned long io, unsigned long ctl,      if (hwif->present)  	return hwif; +    /* retry registration in case device is still spinning up */ +    for (i = 0; i < 10; i++) { +	msleep(100); +	ide_port_scan(hwif); +	if (hwif->present) +	    return hwif; +    } + +    return hwif; +  out_release:      release_region(ctl, 1);      release_region(io, 8); @@ -222,7 +236,7 @@ static int ide_config(struct pcmcia_device *link)  	cistpl_cftable_entry_t dflt;      } *stk = NULL;      cistpl_cftable_entry_t *cfg; -    int i, pass, last_ret = 0, last_fn = 0, is_kme = 0; +    int pass, last_ret = 0, last_fn = 0, is_kme = 0;      unsigned long io_base, ctl_base;      ide_hwif_t *hwif; @@ -319,30 +333,15 @@ static int ide_config(struct pcmcia_device *link)      if (is_kme)  	outb(0x81, ctl_base+1); -    /* retry registration in case device is still spinning up */ -    for (i = 0; i < 10; i++) { -	hwif = idecs_register(io_base, ctl_base, link->irq.AssignedIRQ, link); -	if (hwif) -	    break; -	if (link->io.NumPorts1 == 0x20) { +     hwif = idecs_register(io_base, ctl_base, link->irq.AssignedIRQ, link); +     if (hwif == NULL && link->io.NumPorts1 == 0x20) {  	    outb(0x02, ctl_base + 0x10);  	    hwif = idecs_register(io_base + 0x10, ctl_base + 0x10,  				  link->irq.AssignedIRQ, link); -	    if (hwif) { -		io_base += 0x10; -		ctl_base += 0x10; -		break; -	    } -	} -	msleep(100);      } -    if (hwif == NULL) { -	printk(KERN_NOTICE "ide-cs: ide_register() at 0x%3lx & 0x%3lx" -	       ", irq %u failed\n", io_base, ctl_base, -	       link->irq.AssignedIRQ); +    if (hwif == NULL)  	goto failed; -    }      info->ndev = 1;      sprintf(info->node.dev_name, "hd%c", 'a' + hwif->index * 2); | 
